From 3c2ae1697637b8e7018a2cba29938f99a53ca157 Mon Sep 17 00:00:00 2001 From: Mark Watkins Date: Fri, 18 Oct 2013 14:56:44 +1000 Subject: [PATCH] Preparing for adding an unstable GIT branch --- sleepyhead/SleepLib/common.cpp | 27 ++++++++++++ sleepyhead/SleepLib/common.h | 14 ++++++ sleepyhead/SleepLib/preferences.cpp | 9 ++-- sleepyhead/SleepLib/preferences.h | 4 -- sleepyhead/daily.ui | 68 +++-------------------------- sleepyhead/mainwindow.cpp | 12 ++--- sleepyhead/newprofile.cpp | 2 +- sleepyhead/sleepyhead.pro | 17 +++++--- sleepyhead/summary.cpp | 7 ++- sleepyhead/version.h | 9 +++- 10 files changed, 85 insertions(+), 84 deletions(-) diff --git a/sleepyhead/SleepLib/common.cpp b/sleepyhead/SleepLib/common.cpp index 9fb98b30..3743bbb4 100644 --- a/sleepyhead/SleepLib/common.cpp +++ b/sleepyhead/SleepLib/common.cpp @@ -9,6 +9,33 @@ #include "profiles.h" +// Used by internal settings + + +const QString getDeveloperName() +{ + return STR_DeveloperName; +} + +const QString getAppName() +{ + QString name=STR_AppName; +#ifdef UNSTABLE_BUILD + name+=STR_Unstable; +#endif + return name; +} + +const QString getDefaultAppRoot() +{ + QString approot=STR_AppRoot; +#ifdef UNSTABLE_BUILD + approot+=STR_Unstable; +#endif + return approot; +} + + qint64 timezoneOffset() { static bool ok=false; static qint64 _TZ_offset=0; diff --git a/sleepyhead/SleepLib/common.h b/sleepyhead/SleepLib/common.h index 3e68015a..daf8761a 100644 --- a/sleepyhead/SleepLib/common.h +++ b/sleepyhead/SleepLib/common.h @@ -39,6 +39,17 @@ QString weightString(float kg, UnitSystem us=US_Undefined); //! \brief Mercilessly trash a directory bool removeDir(const QString & path); + +#ifdef UNSTABLE_BUILD +const QString STR_Unstable="-Unstable"; +#else +const QString STR_Unstable=""; +#endif + +const QString getAppName(); +const QString getDeveloperName(); +const QString getDefaultAppRoot(); + /////////////////////////////////////////////////////////////////////////////////////////////// // Preference Name Strings /////////////////////////////////////////////////////////////////////////////////////////////// @@ -78,6 +89,9 @@ const QString STR_MACH_ZEO="Zeo"; const QString STR_PREF_VersionString="VersionString"; const QString STR_PREF_Language="Language"; +const QString STR_AppName="SleepyHead"; +const QString STR_DeveloperName="Jedimark"; +const QString STR_AppRoot="SleepyHeadData"; /////////////////////////////////////////////////////////////////////////////////////////////// // Commonly used translatable text strings diff --git a/sleepyhead/SleepLib/preferences.cpp b/sleepyhead/SleepLib/preferences.cpp index 818b398b..e7eeda5e 100644 --- a/sleepyhead/SleepLib/preferences.cpp +++ b/sleepyhead/SleepLib/preferences.cpp @@ -22,6 +22,7 @@ License: GPL #include "lmcons.h" #endif +#include "common.h" #include "preferences.h" const QString & getUserName() @@ -56,7 +57,7 @@ const QString & getUserName() QString GetAppRoot() { - QSettings settings("Jedimark", "SleepyHead"); + QSettings settings(getDeveloperName(), getAppName()); QString HomeAppRoot=settings.value("Settings/AppRoot").toString(); @@ -67,7 +68,7 @@ QString GetAppRoot() #endif if (HomeAppRoot.isEmpty()) - HomeAppRoot=desktopFolder+"/"+AppRoot; + HomeAppRoot=desktopFolder+"/"+getDefaultAppRoot(); return HomeAppRoot; } @@ -179,7 +180,7 @@ bool Preferences::Open(QString filename) QDomElement root=doc.documentElement(); - if (root.tagName() != AppName) { + if (root.tagName() != STR_AppName) { return false; } @@ -273,7 +274,7 @@ bool Preferences::Save(QString filename) QDomDocument doc(p_name); - QDomElement droot = doc.createElement(AppName); + QDomElement droot = doc.createElement(STR_AppName); doc.appendChild( droot ); QDomElement root=doc.createElement(p_name); diff --git a/sleepyhead/SleepLib/preferences.h b/sleepyhead/SleepLib/preferences.h index 4031ef00..a2de5a8d 100644 --- a/sleepyhead/SleepLib/preferences.h +++ b/sleepyhead/SleepLib/preferences.h @@ -17,10 +17,6 @@ License: GPL #include #include - -const QString AppName="SleepyHead"; // Outer tag of XML files -const QString AppRoot="SleepyHeadData"; // The Folder Name - const QString STR_ext_XML=".xml"; extern QString GetAppRoot(); //returns app root path plus trailing path separator. diff --git a/sleepyhead/daily.ui b/sleepyhead/daily.ui index 72c237ca..305a1a0e 100644 --- a/sleepyhead/daily.ui +++ b/sleepyhead/daily.ui @@ -23,16 +23,7 @@ 0 - - 0 - - - 0 - - - 0 - - + 0 @@ -61,16 +52,7 @@ 0 - - 0 - - - 0 - - - 0 - - + 0 @@ -358,7 +340,7 @@ QToolButton:pressed { background: transparent; border: 2px solid transparent; border-radius: 8px; - width: 5em; + width: 6em; } #qt_calendar_monthbutton:hover { @@ -421,16 +403,7 @@ QToolButton:pressed { 0 - - 0 - - - 0 - - - 0 - - + 0 @@ -459,16 +432,7 @@ QToolButton:pressed { - - 4 - - - 4 - - - 4 - - + 4 @@ -525,16 +489,7 @@ QToolButton:pressed { 0 - - 0 - - - 0 - - - 0 - - + 0 @@ -868,16 +823,7 @@ QSlider::handle:horizontal { 6 - - 4 - - - 4 - - - 4 - - + 4 diff --git a/sleepyhead/mainwindow.cpp b/sleepyhead/mainwindow.cpp index 06b8c8cc..f869ad1b 100644 --- a/sleepyhead/mainwindow.cpp +++ b/sleepyhead/mainwindow.cpp @@ -90,7 +90,7 @@ MainWindow::MainWindow(QWidget *parent) : QString version=FullVersionString; if (QString(GIT_BRANCH)!="master") version+=QString(" ")+QString(GIT_BRANCH); - this->setWindowTitle(tr("SleepyHead")+QString(" v%1 ("+tr("Profile")+": %2)").arg(version).arg(PREF[STR_GEN_Profile].toString())); + this->setWindowTitle(STR_TR_SleepyHead+QString(" v%1 ("+tr("Profile")+": %2)").arg(version).arg(PREF[STR_GEN_Profile].toString())); //ui->tabWidget->setCurrentIndex(1); // Disable Screenshot on Mac Platform,as it doesn't work, and the system provides this functionality anyway. @@ -137,7 +137,7 @@ MainWindow::MainWindow(QWidget *parent) : first_load=true; // Using the dirty registry here. :( - QSettings settings("Jedimark", "SleepyHead"); + QSettings settings(getDeveloperName(), getAppName()); // Load previous Window geometry this->restoreGeometry(settings.value("MainWindow/geometry").toByteArray()); @@ -193,8 +193,8 @@ MainWindow::~MainWindow() if (systray) delete systray; // Save current window position - QSettings settings("Jedimark", "SleepyHead"); - settings.setValue("MainWindow/geometry", saveGeometry()); + QSettings settings(getDeveloperName(), getAppName()); + settings.setValue("MainWindow/geometry", saveGeometry()); if (daily) { daily->close(); @@ -231,7 +231,7 @@ void MainWindow::Notify(QString s,QString title,int ms) void MainWindow::Startup() { - qDebug() << PREF["AppName"].toString().toLatin1()+" v"+VersionString.toLatin1() << "built with Qt"<< QT_VERSION_STR << "on" << __DATE__ << __TIME__; + qDebug() << STR_TR_SleepyHeadVersion.toLocal8Bit().data() << "built with Qt"<< QT_VERSION_STR << "on" << __DATE__ << __TIME__; qstatus->setText(tr("Loading Data")); qprogress->show(); //qstatusbar->showMessage(tr("Loading Data"),0); @@ -599,7 +599,7 @@ void MainWindow::on_action_About_triggered() "" "
" "

"+STR_TR_SleepyHead+" v%1.%2.%3-%4 (%8)

"+tr("Build Date")+": %5 %6
%7
"+tr("Data Folder Location")+": %9


"+ -tr("Copyright")+" ©2012 Mark Watkins (jedimark)
\n"+ +tr("Copyright")+" ©2013 Mark Watkins (jedimark)
\n"+ tr("This software is released under the GNU Public License v3.0
")+ "

"+tr("SleepyHead Project Page")+": http://sourceforge.net/projects/sleepyhead
"+ tr("SleepyHead Wiki")+": http://sleepyhead.sourceforge.net
"+ diff --git a/sleepyhead/newprofile.cpp b/sleepyhead/newprofile.cpp index fe7e58c7..44625944 100644 --- a/sleepyhead/newprofile.cpp +++ b/sleepyhead/newprofile.cpp @@ -92,7 +92,7 @@ void NewProfile::on_nextButton_clicked() { const QString xmlext=".xml"; - QSettings settings("Jedimark", "SleepyHead"); + QSettings settings(getDeveloperName(), getAppName()); int index=ui->stackedWidget->currentIndex(); switch(index) { diff --git a/sleepyhead/sleepyhead.pro b/sleepyhead/sleepyhead.pro index 6597c85c..f6d4295b 100644 --- a/sleepyhead/sleepyhead.pro +++ b/sleepyhead/sleepyhead.pro @@ -19,7 +19,6 @@ else:!use_bundled_libs:CONFIG += extserialport use_bundled_libs:DEFINES += USE_BUNDLED_LIBS - #static { # CONFIG += static # QTPLUGIN += qsvg qgif qpng @@ -37,11 +36,19 @@ TEMPLATE = app # GIT_VERSION = $$system(git describe --tags --long --abbrev=6 --dirty="*") -exists(.git):DEFINES += GIT_BRANCH=\\\"$$system(git rev-parse --abbrev-ref HEAD)\\\" -else:DEFINES += GIT_BRANCH=\\\"UNKNOWN\\\" +exists(../.git):{ + + DEFINES += GIT_BRANCH=\\\"$$system(git rev-parse --abbrev-ref HEAD)\\\" + DEFINES += GIT_REVISION=\\\"$$system(git rev-parse HEAD)\\\" + + equals(GIT_BRANCH,"unstable"):DEFINES += UNSTABLE_BUILD + +}else{ + DEFINES += GIT_BRANCH=\\\"UNKNOWN\\\" + DEFINES += GIT_REVISION=\\\"UNKNOWN\\\" +} + -exists(.git):DEFINES += GIT_REVISION=\\\"$$system(git rev-parse HEAD)\\\" -else:DEFINES += GIT_REVISION=\\\"UNKNOWN\\\" unix:!macx { LIBS += -lX11 -lz -lGLU diff --git a/sleepyhead/summary.cpp b/sleepyhead/summary.cpp index 4c298822..ad17db39 100644 --- a/sleepyhead/summary.cpp +++ b/sleepyhead/summary.cpp @@ -42,9 +42,14 @@ QString htmlHeader() "" "

" "

"+ -QObject::tr("SleepyHead")+" v"+VersionString+"

"+ +STR_TR_SleepyHeadVersion+""+ +#ifdef UNSTABLE_BUILD +QObject::tr("This is an unstable build so expect the possibility things will go wrong.")+"
"+ +QObject::tr("Please report bugs you find here to SleepyHead's developer mailing list.")+ +#else QObject::tr("This is a beta software and some functionality may not work as intended yet.")+"
"+ QObject::tr("Please report any bugs you find to SleepyHead's SourceForge page.")+ +#endif "
" "
" "
"); diff --git a/sleepyhead/version.h b/sleepyhead/version.h index 341e2c53..52477469 100644 --- a/sleepyhead/version.h +++ b/sleepyhead/version.h @@ -8,10 +8,15 @@ const int minor_version=9; const int revision_number=4; const int release_number=0; -const QString VersionString=QString().sprintf("%i.%i.%i",major_version,minor_version,revision_number); -const QString FullVersionString=QString().sprintf("%i.%i.%i-%i",major_version,minor_version,revision_number,release_number); +#ifdef UNSTABLE_BUILD +const QString ReleaseStatus="unstable"; +#else const QString ReleaseStatus="beta"; +#endif + +const QString VersionString=QString().sprintf("%i.%i.%i",major_version,minor_version,revision_number); +const QString FullVersionString=QString().sprintf("%i.%i.%i-%i",major_version,minor_version,revision_number,release_number)+" "+ReleaseStatus; #ifdef Q_OS_MAC const QString PlatformString="MacOSX";