diff --git a/oscar/SleepLib/common.cpp b/oscar/SleepLib/common.cpp
index 64660915..29964e7d 100644
--- a/oscar/SleepLib/common.cpp
+++ b/oscar/SleepLib/common.cpp
@@ -185,16 +185,9 @@ QString getGraphicsEngine()
QStringList buildInfo;
-QStringList makeBuildInfo (QString relinfo, QString forcedEngine){
- buildInfo << (STR_AppName + " " + getVersion() + " " + relinfo);
- buildInfo << (QObject::tr("Built with Qt") + " " + QT_VERSION_STR + " on " + __DATE__ + " " + __TIME__);
- QString branch = "";
- if (gitBranch() != "master") {
- branch = QObject::tr("Branch:") + " " + gitBranch() + ", ";
- }
- buildInfo << branch + (QObject::tr("Revision")) + " " + gitRevision();
- if (getAppName() != STR_AppName) // Report any non-standard app key
- buildInfo << (QObject::tr("App key:") + " " + getAppName());
+QStringList makeBuildInfo (QString forcedEngine){
+ // application name and version has already been added
+ buildInfo << (QObject::tr("Built with Qt %1 on %2").arg(QT_VERSION_STR).arg(getBuildDateTime()));
buildInfo << QString("");
buildInfo << (QObject::tr("Operating system:") + " " + QSysInfo::prettyProductName());
buildInfo << (QObject::tr("Graphics Engine:") + " " + getOpenGLVersionString());
@@ -202,6 +195,11 @@ QStringList makeBuildInfo (QString relinfo, QString forcedEngine){
if (forcedEngine != "")
buildInfo << forcedEngine;
+ buildInfo << QString("");
+ if (getAppName() != STR_AppName) // Report any non-standard app key
+ buildInfo << (QObject::tr("App key:") + " " + getAppName());
+ // Data directory will always be added, later.
+
return buildInfo;
}
diff --git a/oscar/SleepLib/common.h b/oscar/SleepLib/common.h
index 1815a829..bb111ade 100644
--- a/oscar/SleepLib/common.h
+++ b/oscar/SleepLib/common.h
@@ -44,7 +44,7 @@ QString getGraphicsEngine();
QString getOpenGLVersionString();
float getOpenGLVersion();
-QStringList makeBuildInfo(QString relinfo, QString forcedEngine);
+QStringList makeBuildInfo(QString forcedEngine);
QStringList getBuildInfo();
QStringList addBuildInfo (QString value);
diff --git a/oscar/aboutdialog.cpp b/oscar/aboutdialog.cpp
index 2458562c..093a7a63 100644
--- a/oscar/aboutdialog.cpp
+++ b/oscar/aboutdialog.cpp
@@ -30,16 +30,8 @@ AboutDialog::AboutDialog(QWidget *parent) :
ui->relnotesText->setHtml(getRelnotes());
ui->versionLabel->setText("");
-// QString gitrev = gitRevision();
-//
-// if (!gitrev.isEmpty()) {
-// gitrev = tr("Revision: %1").arg(QString("%1").arg(gitrev))+"
"
-// +tr("Branch: %1").arg(QString("%1").arg(gitBranch()))+"
"
-// +tr("Build Date: %1").arg(__DATE__)+"
"
-// +tr("Graphics Engine: %1").arg(getGraphicsEngine());
-// }
-
QString path = GetAppData();
+ // TODO: consider replacing gitrev below with a link or button to the System Information window
QString text = /* gitrev + */ "
"+tr("Show data folder")+"";
ui->infoLabel->setText(text);
diff --git a/oscar/main.cpp b/oscar/main.cpp
index d3f98090..57a1d7ec 100644
--- a/oscar/main.cpp
+++ b/oscar/main.cpp
@@ -340,14 +340,19 @@ int main(int argc, char *argv[]) {
initializeLogger();
QThread::msleep(50); // Logger takes a little bit to catch up
+ qDebug().noquote() << "OSCAR starting" << QDateTime::currentDateTime().toString();
+
#ifdef QT_DEBUG
QString relinfo = " debug";
#else
QString relinfo = "";
#endif
relinfo = "("+QSysInfo::kernelType()+" "+QSysInfo::currentCpuArchitecture()+relinfo+")";
- qDebug() << "OSCAR starting" << QDateTime::currentDateTime();
- qDebug().noquote() << STR_AppName << getVersion() << relinfo << "Built with Qt" << QT_VERSION_STR << __DATE__ << __TIME__;
+ relinfo = STR_AppName + " " + getVersion() + " " + relinfo;
+
+ qDebug().noquote() << relinfo;
+ qDebug().noquote() << "Built with Qt" << QT_VERSION_STR << "on" << getBuildDateTime();
+ addBuildInfo(relinfo); // immediately add it to the build info that's accessible from the UI
SetDateFormat();
@@ -365,7 +370,7 @@ int main(int argc, char *argv[]) {
// Moved buildInfo calls to after translation is available as makeBuildInfo includes tr() calls
- QStringList info = makeBuildInfo(relinfo, forcedEngine);
+ QStringList info = makeBuildInfo(forcedEngine);
for (int i = 0; i < info.size(); ++i)
qDebug().noquote() << info.at(i);
@@ -476,9 +481,8 @@ int main(int argc, char *argv[]) {
} // The folder doesn't exist
else
qDebug() << "AppData folder already exists, so ...";
- qDebug() << "Using " + GetAppData() + " as OSCAR data folder";
+ qDebug().noquote() << "Using " + GetAppData() + " as OSCAR data folder";
- addBuildInfo("");
QString path = GetAppData();
addBuildInfo(QObject::tr("Data directory:") + " " + path + "");
diff --git a/oscar/version.cpp b/oscar/version.cpp
index faf97a04..e19b275d 100644
--- a/oscar/version.cpp
+++ b/oscar/version.cpp
@@ -25,23 +25,18 @@ const QString PlatformString = "Linux";
const QString PlatformString = "Haiku";
#endif
-
-const QString & gitRevision()
-{
- return GIT_REVISION;
-}
-const QString & gitBranch()
-{
- return GIT_BRANCH;
-}
+// Technically this is the date and time that version.cpp was compiled, but since
+// it gets recompiled whenever git_info.h changes, it's about as close as we can
+// come without forcing recompiles every single build.
+static const QString s_BuildDateTime = __DATE__ " " __TIME__;
QString getPrereleaseSuffix()
{
QString suffix;
// Append branch if there is a branch specified
- if (gitBranch() != "master") {
- suffix += "-"+gitBranch();
+ if (GIT_BRANCH != "master") {
+ suffix += "-"+GIT_BRANCH;
}
// Append "-test" if not release or release candidate
@@ -54,6 +49,11 @@ QString getPrereleaseSuffix()
return suffix;
}
+const QString & getBuildDateTime()
+{
+ return s_BuildDateTime;
+}
+
// TODO: add preprocessor macros to build full version number including build metadata, accounting for tarball/non-git builds.
static const Version s_Version(VERSION "+" + GIT_BRANCH + "-" + GIT_REVISION);
diff --git a/oscar/version.h b/oscar/version.h
index b037193b..1e7484ef 100644
--- a/oscar/version.h
+++ b/oscar/version.h
@@ -51,8 +51,9 @@ protected:
//!brief Get the current version of the application.
const Version & getVersion();
+//!brief Get the date and time of the application was built.
+const QString & getBuildDateTime();
+
QString getPrereleaseSuffix();
-const QString & gitRevision();
-const QString & gitBranch();
#endif // VERSION_H