diff options
-rw-r--r-- | CMakeLists.txt | 6 | ||||
-rw-r--r-- | src/forms/aboutdialog.cpp | 51 | ||||
-rw-r--r-- | src/version.h.in | 10 |
3 files changed, 33 insertions, 34 deletions
diff --git a/CMakeLists.txt b/CMakeLists.txt index bb0c2ca..a0e6b9d 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -52,8 +52,10 @@ add_subdirectory(plugins/ProfileEditor) # configure a header file to pass version information # if you don't have git, or are building this off the source tarball, define versions in version.h.in -execute_process(COMMAND hg log -r '.' --template={latesttag} WORKING_DIRECTORY ${PROJECT_SOURCE_DIR} OUTPUT_VARIABLE VcsVersion OUTPUT_STRIP_TRAILING_WHITESPACE) -execute_process(COMMAND hg identify --id WORKING_DIRECTORY ${PROJECT_SOURCE_DIR} OUTPUT_VARIABLE VcsCommit OUTPUT_STRIP_TRAILING_WHITESPACE) +execute_process(COMMAND hg log -r '.' --template={latesttag} WORKING_DIRECTORY ${PROJECT_SOURCE_DIR} OUTPUT_VARIABLE VcsVersion OUTPUT_STRIP_TRAILING_WHITESPACE) +execute_process(COMMAND hg identify --id WORKING_DIRECTORY ${PROJECT_SOURCE_DIR} OUTPUT_VARIABLE VcsCommit OUTPUT_STRIP_TRAILING_WHITESPACE) +execute_process(COMMAND hg identify --num WORKING_DIRECTORY ${PROJECT_SOURCE_DIR} OUTPUT_VARIABLE VcsRevision OUTPUT_STRIP_TRAILING_WHITESPACE) +execute_process(COMMAND hg identify --branch WORKING_DIRECTORY ${PROJECT_SOURCE_DIR} OUTPUT_VARIABLE VcsBranch OUTPUT_STRIP_TRAILING_WHITESPACE) configure_file(src/version.h.in "${PROJECT_BINARY_DIR}/version.h") set(SourceCode diff --git a/src/forms/aboutdialog.cpp b/src/forms/aboutdialog.cpp index 93ee86b..eb32533 100644 --- a/src/forms/aboutdialog.cpp +++ b/src/forms/aboutdialog.cpp @@ -9,27 +9,24 @@ #include "aboutdialog.h" #include "ui_aboutdialog.h" #include "version.h" +#include <libconfig.h++> -constexpr const char *getCompiler() -{ +// The extra level of indirection will allow the preprocessor to expand the macros before they are converted to strings. +#define STR_HELPER(x) #x +#define STR(x) STR_HELPER(x) + +// compiler // clang also defines __GNUC__, so we need to check for clang first #if defined(__clang__) - return "Clang " __clang_version__; +#define compiler "Clang " __clang_version__ #elif defined(__GNUC__) - return "GCC " __VERSION__; +#define compiler "GCC " __VERSION__ #else - return "unknown compiler"; +#define compiler "unknown compiler"; #endif -} -inline const QString getLongVersion() -{ -#ifdef SMOLBOTE_DESCRIBE - return QString(SMOLBOTE_DESCRIBE); -#else - return qApp->applicationVersion(); -#endif -} +// libconfig +#define LIBCONFIG_VERSION_STR STR(LIBCONFIGXX_VER_MAJOR) "." STR(LIBCONFIGXX_VER_MINOR) "." STR(LIBCONFIGXX_VER_REVISION) AboutDialog::AboutDialog(QWidget *parent) : QDialog(parent) @@ -40,14 +37,13 @@ AboutDialog::AboutDialog(QWidget *parent) ui->icon->setPixmap(qApp->windowIcon().pixmap(72, 72)); - QLabel *aboutLabel = new QLabel(this); + auto *aboutLabel = new QLabel(this); aboutLabel->setWordWrap(true); - aboutLabel->setText(tr("<h2>smolbote %1</h2>" - "<p><i>yet another no-frills browser</i></p>") - .arg(qApp->applicationVersion())); + aboutLabel->setText(tr("<h2>smolbote " SMOLBOTE_VERSION "</h2>" + "<p><i>yet another no-frills browser</i></p>")); ui->toolBox->addItem(aboutLabel, tr("About")); - QLabel *licenseLabel = new QLabel(this); + auto *licenseLabel = new QLabel(this); licenseLabel->setWordWrap(true); licenseLabel->setText(tr("<p>Copyright (C) 2017 Xian Nox</p>" "<p>This program is free software, and you are welcome to use it under the conditions set by the GNU GPLv3:" @@ -61,18 +57,15 @@ AboutDialog::AboutDialog(QWidget *parent) "<p>You can find the full license text in LICENSE.md.</p>")); ui->toolBox->addItem(licenseLabel, tr("License")); - QLabel *libsLabel = new QLabel(this); + auto *libsLabel = new QLabel(this); libsLabel->setWordWrap(true); - libsLabel->setText(tr("<h3>Version %1</h3>" - "<p>" - "Based on Qt " QT_VERSION_STR "<br>" - "Compiled with %2" - "</p>" + libsLabel->setText(tr("<h3>Version " SMOLBOTE_DESCRIBE "</h3>" + "<p>Branch: " SMOLBOTE_BRANCH "<br>" + "Compiled with " compiler "</p>" "<p><ul>" - "<li>Qt %3</li>" - "<li>libconfig</li>" - "</ul></p>") - .arg(getLongVersion(), getCompiler(), qVersion())); + "<li>Qt " QT_VERSION_STR "</li>" + "<li>libconfig " LIBCONFIG_VERSION_STR "</li>" + "</ul></p>")); ui->toolBox->addItem(libsLabel, tr("Details")); } diff --git a/src/version.h.in b/src/version.h.in index 0f597ed..88008cf 100644 --- a/src/version.h.in +++ b/src/version.h.in @@ -1,9 +1,13 @@ #ifndef VERSION_H #define VERSION_H -// 0.2.1 +// Version: 1.2.3 #define SMOLBOTE_VERSION "@VcsVersion@" -// 0.2.1-0fd54a21a551+ -#define SMOLBOTE_DESCRIBE "@VcsVersion@-@VcsCommit@" + +// Describe: 1.2.3-r123-0123456789ab +#define SMOLBOTE_DESCRIBE "@VcsVersion@-r@VcsRevision@-@VcsCommit@" + +// Branch: default +#define SMOLBOTE_BRANCH "@VcsBranch@" #endif //VERSION_H |