mirror of
https://gitlab.com/pholy/OSCAR-code.git
synced 2025-04-05 02:30:44 +00:00
Clean up tr() strings a bit and hunt for untranslateables
This commit is contained in:
parent
9da8b2a7d3
commit
076e657ec1
@ -1,4 +1,4 @@
|
||||
/* MinutesAtPressure Graph Implementation
|
||||
/* MinutesAtPressure Graph Implementation
|
||||
*
|
||||
* Copyright (c) 2011-2018 Mark Watkins <mark@jedimark.net>
|
||||
*
|
||||
@ -309,7 +309,7 @@ void MinutesAtPressure::paint(QPainter &painter, gGraph &graph, const QRegion &r
|
||||
graph.renderText(label, left-8-w, bot+h/2-2 );
|
||||
bot -= peakmult;
|
||||
}
|
||||
label = QString("Peak %1").arg(qMax(ipap.peaktime, epap.peaktime)/60.0);
|
||||
label = QObject::tr("Peak %1").arg(qMax(ipap.peaktime, epap.peaktime)/60.0);
|
||||
graph.renderText(label, left, top+5 );
|
||||
|
||||
xstep /= 5.0;
|
||||
|
@ -1,4 +1,4 @@
|
||||
/* gGraph Implemntation
|
||||
/* gGraph Implemntation
|
||||
*
|
||||
* Copyright (c) 2011-2018 Mark Watkins <mark@jedimark.net>
|
||||
*
|
||||
@ -790,7 +790,7 @@ void gGraph::mouseMoveEvent(QMouseEvent *event)
|
||||
int ms(a % 1000);
|
||||
|
||||
if (d > 1) {
|
||||
m_selDurString.sprintf("%1.0f days", d);
|
||||
m_selDurString = tr("%1 days").arg(floor(d));
|
||||
} else {
|
||||
|
||||
m_selDurString.sprintf("%02i:%02i:%02i:%03i", h, m, s, ms);
|
||||
|
@ -1,4 +1,4 @@
|
||||
/* glcommon GL code & font stuff
|
||||
/* glcommon GL code & font stuff
|
||||
*
|
||||
* Copyright (c) 2011-2018 Mark Watkins <mark@jedimark.net>
|
||||
*
|
||||
@ -42,14 +42,11 @@ QColor brighten(QColor color, float mult)
|
||||
|
||||
}
|
||||
|
||||
#ifdef BUILD_WITH_MSVC
|
||||
|
||||
#if (_MSC_VER < 1800)
|
||||
#if defined(_MSC_VER) && (_MSC_VER < 1800)
|
||||
double round(double number)
|
||||
{
|
||||
return number < 0.0 ? ceil(number - 0.5) : floor(number + 0.5);
|
||||
}
|
||||
#endif
|
||||
#endif
|
||||
|
||||
|
||||
|
@ -62,11 +62,9 @@ const int max_history = 50;
|
||||
const double M_PI = 3.141592653589793;
|
||||
#endif
|
||||
|
||||
#ifdef BUILD_WITH_MSVC
|
||||
// Visual C++ earlier than 2013 doesn't have round in it's maths header..
|
||||
#if (_MSC_VER < 1800)
|
||||
#if defined(_MSC_VER) && (_MSC_VER < 1800)
|
||||
double round(double number);
|
||||
#endif
|
||||
#endif
|
||||
|
||||
#endif // GLCOMMON_H
|
||||
|
@ -18,13 +18,10 @@
|
||||
|
||||
#include "SleepLib/common.h"
|
||||
|
||||
#ifndef BUILD_WITH_MSVC
|
||||
# include <unistd.h>
|
||||
#endif
|
||||
|
||||
#ifdef _MSC_VER
|
||||
#include <QtZlib/zlib.h>
|
||||
#else
|
||||
#include <unistd.h>
|
||||
#include <zlib.h>
|
||||
#endif
|
||||
|
||||
@ -70,6 +67,7 @@ const QString getDefaultAppRoot()
|
||||
bool gfxEgnineIsSupported(GFXEngine e)
|
||||
{
|
||||
#if defined(Q_OS_WIN32)
|
||||
Q_UNUSED(e)
|
||||
return true;
|
||||
#else
|
||||
switch(e) {
|
||||
|
@ -1,4 +1,4 @@
|
||||
/* EDF Parser Header
|
||||
/* EDF Parser Header
|
||||
*
|
||||
* Copyright (c) 2011-2018 Mark Watkins <mark@jedimark.net>
|
||||
*
|
||||
@ -35,7 +35,7 @@ struct EDFHeader {
|
||||
char dur_data_records[8];
|
||||
char num_signals[4];
|
||||
}
|
||||
#ifndef BUILD_WITH_MSVC
|
||||
#ifndef _MSC_VER
|
||||
__attribute__((packed))
|
||||
#endif
|
||||
;
|
||||
|
@ -1,4 +1,4 @@
|
||||
/* SleepyHead AboutDialog Implementation
|
||||
/* SleepyHead AboutDialog Implementation
|
||||
*
|
||||
* Date created: 7/5/2018
|
||||
*
|
||||
@ -63,7 +63,7 @@ void AboutDialog::on_donateButton_clicked()
|
||||
QString AboutDialog::getRelnotes()
|
||||
{
|
||||
QFile clfile(":/docs/release_notes.html");
|
||||
QString changeLog = QObject::tr("Sorry, could not locate changelog.");
|
||||
QString changeLog = tr("Sorry, could not locate changelog.");
|
||||
if (clfile.open(QIODevice::ReadOnly)) {
|
||||
//Todo, write XML parser and only show the latest..
|
||||
//QTextStream ts(&clfile);
|
||||
@ -76,8 +76,8 @@ QString AboutDialog::getRelnotes()
|
||||
"<span style=\" font-size:14pt;\">"+tr("SleepyHead v%1").arg(VersionString)+"</span>"
|
||||
"<hr/>";
|
||||
if (ReleaseStatus != "r") {
|
||||
text += "<p><font color='red' size=+1><b>"+QObject::tr("Important:")+"</b></font> "
|
||||
"<font size=+1><i>"+QObject::tr("As this is a pre-release version, it is recommended that you <b>back up your data folder manually</b> before proceding, because attempting to roll back later may break things.")+"</i></font></p><hr/>";
|
||||
text += "<p><font color='red' size=+1><b>"+tr("Important:")+"</b></font> "
|
||||
"<font size=+1><i>"+tr("As this is a pre-release version, it is recommended that you <b>back up your data folder manually</b> before proceding, because attempting to roll back later may break things.")+"</i></font></p><hr/>";
|
||||
}
|
||||
text += changeLog;
|
||||
text += "</body></html>";
|
||||
@ -89,7 +89,7 @@ QString AboutDialog::getLicense()
|
||||
QString text;
|
||||
QString licenseFile = ":/docs/GPLv3-"+AppSetting->language();
|
||||
if (!QFile::exists(licenseFile)) {
|
||||
ui->licenceLabel->setText(QObject::tr("To see if the license text is available in your language, see %1.").arg("<a href=\"https://www.gnu.org/licenses/translations.en.html\">https://www.gnu.org/licenses/translations.en.html</a>\""));
|
||||
ui->licenceLabel->setText(tr("To see if the license text is available in your language, see %1.").arg("<a href=\"https://www.gnu.org/licenses/translations.en.html\">https://www.gnu.org/licenses/translations.en.html</a>"));
|
||||
ui->licenceLabel->setVisible(true);
|
||||
licenseFile = ":/docs/GPLv3-en_US";
|
||||
} else {
|
||||
|
@ -1 +1 @@
|
||||
const int build_number = 0;
|
||||
const int build_number = 2;
|
||||
|
@ -1,4 +1,4 @@
|
||||
/* Daily Panel
|
||||
/* Daily Panel
|
||||
*
|
||||
* Copyright (c) 2011-2018 Mark Watkins <mark@jedimark.net>
|
||||
*
|
||||
@ -123,7 +123,7 @@ Daily::Daily(QWidget *parent,gGraphView * shared)
|
||||
layout2->insertWidget(1,sessionbar,0);
|
||||
// add the sessionbar after it.
|
||||
|
||||
ui->tabWidget->insertTab(0,widget,QIcon(),"Details");
|
||||
ui->tabWidget->insertTab(0, widget, QIcon(), tr("Details"));
|
||||
|
||||
ui->graphFrame->setLayout(layout);
|
||||
//ui->graphMainArea->setLayout(layout);
|
||||
@ -163,7 +163,7 @@ Daily::Daily(QWidget *parent,gGraphView * shared)
|
||||
const QString STR_GRAPH_TAP = "TimeAtPressure";
|
||||
|
||||
// gGraph * SG;
|
||||
// graphlist[STR_GRAPH_DailySummary] = SG = new gGraph(STR_GRAPH_DailySummary, GraphView, QObject::tr("Summary"), QObject::tr("Summary of this daily information"), default_height);
|
||||
// graphlist[STR_GRAPH_DailySummary] = SG = new gGraph(STR_GRAPH_DailySummary, GraphView, tr("Summary"), tr("Summary of this daily information"), default_height);
|
||||
// SG->AddLayer(new gLabelArea(nullptr),LayerLeft,gYAxis::Margin);
|
||||
// SG->AddLayer(new gDailySummary());
|
||||
|
||||
@ -274,7 +274,7 @@ Daily::Daily(QWidget *parent,gGraphView * shared)
|
||||
pc->addPlot(CPAP_IPAPHi, square);
|
||||
|
||||
gGraph * TAP2;
|
||||
graphlist[STR_GRAPH_TAP] = TAP2 = new gGraph(STR_GRAPH_TAP, GraphView, QObject::tr("Time at Pressure"), QObject::tr("Time at Pressure"), default_height);
|
||||
graphlist[STR_GRAPH_TAP] = TAP2 = new gGraph(STR_GRAPH_TAP, GraphView, tr("Time at Pressure"), tr("Time at Pressure"), default_height);
|
||||
MinutesAtPressure * map;
|
||||
TAP2->AddLayer(map = new MinutesAtPressure());
|
||||
TAP2->AddLayer(new gLabelArea(map),LayerLeft,gYAxis::Margin);
|
||||
@ -872,7 +872,7 @@ QString Daily::getSessionInformation(Day * day)
|
||||
|
||||
Session *sess=*s;
|
||||
|
||||
QString tooltip = QObject::tr("Click to %1 this session.").arg(sess->enabled() ? QObject::tr("disable") : QObject::tr("enable"));
|
||||
QString tooltip = tr("Click to %1 this session.").arg(sess->enabled() ? tr("disable") : tr("enable"));
|
||||
html+=QString("<tr><td colspan=5 align=center>%2</td></tr>"
|
||||
"<tr>"
|
||||
"<td width=26>"
|
||||
@ -888,8 +888,8 @@ QString Daily::getSessionInformation(Day * day)
|
||||
"<td align=left>%3</td></tr>"
|
||||
)
|
||||
.arg((*s)->session())
|
||||
.arg(QObject::tr("%1 Session #%2").arg((*s)->machine()->loaderName()).arg((*s)->session(),8,10,QChar('0')))
|
||||
.arg(QString("%1h %2m %3s").arg(h,2,10,QChar('0')).arg(m,2,10,QChar('0')).arg(s1,2,10,QChar('0')))
|
||||
.arg(tr("%1 Session #%2").arg((*s)->machine()->loaderName()).arg((*s)->session(),8,10,QChar('0')))
|
||||
.arg(tr("%1h %2m %3s").arg(h,2,10,QChar('0')).arg(m,2,10,QChar('0')).arg(s1,2,10,QChar('0')))
|
||||
.arg((sess->enabled() ? "on" : "off"))
|
||||
.arg(fd.date().toString(Qt::SystemLocaleShortDate))
|
||||
.arg(fd.toString("HH:mm:ss"))
|
||||
@ -1457,7 +1457,7 @@ void Daily::Load(QDate date)
|
||||
pixmap.save(&buffer, "PNG");
|
||||
html += "<tr><td align=center><img src=\"data:image/png;base64," + byteArray.toBase64() + "\"></td></tr>\n";
|
||||
} else {
|
||||
html += "<tr><td align=center>Unable to display Pie Chart on this system</td></tr>\n";
|
||||
html += "<tr><td align=center>"+tr("Unable to display Pie Chart on this system")+"</td></tr>\n";
|
||||
}
|
||||
} else if (day->channelHasData(CPAP_Obstructive)
|
||||
|| day->channelHasData(CPAP_Hypopnea)
|
||||
@ -1532,7 +1532,6 @@ void Daily::Load(QDate date)
|
||||
const int maxcolors=sizeof(cols)/sizeof(QColor);
|
||||
QList<Session *>::iterator i;
|
||||
|
||||
// WebView trashes it without asking.. :(
|
||||
if (cpap) {
|
||||
int c=0;
|
||||
|
||||
|
@ -1,4 +1,4 @@
|
||||
/* SleepyHead Help Implementation
|
||||
/* SleepyHead Help Implementation
|
||||
*
|
||||
* Copyright (c) 2018 Mark Watkins <mark@jedimark.net>
|
||||
*
|
||||
@ -97,7 +97,7 @@ Help::Help(QWidget *parent) :
|
||||
|
||||
|
||||
if (!helpLoaded) {
|
||||
QString html = "<html><body><div align=\"center\" valign=\"center\"><img src=\"qrc://docs/sheep.png\"><br/><h2>No documentation available</h2></div></body></html>";
|
||||
QString html = "<html><body><div align=\"center\" valign=\"center\"><img src=\"qrc://docs/sheep.png\"><br/><h2>"+tr("No documentation available")+"</h2></div></body></html>";
|
||||
helpBrowser->setHtml(html);
|
||||
return;
|
||||
} else {
|
||||
@ -185,7 +185,7 @@ void Help::on_homeButton_clicked()
|
||||
void Help::on_searchComplete(int count)
|
||||
{
|
||||
if (!searchReady) {
|
||||
QString html = "<h1>Please wait a bit.. Indexing still in progress</h1>";
|
||||
QString html = "<h1>"+tr("Please wait a bit.. Indexing still in progress")+"</h1>";
|
||||
helpBrowser->setText(html);
|
||||
return;
|
||||
}
|
||||
|
@ -1,4 +1,4 @@
|
||||
/* SleepyHead Main
|
||||
/* SleepyHead Main
|
||||
*
|
||||
* Copyright (c) 2011-2018 Mark Watkins <mark@jedimark.net>
|
||||
*
|
||||
@ -128,8 +128,9 @@ int main(int argc, char *argv[])
|
||||
|
||||
initializeStrings(); // This must be called AFTER translator is installed, but before mainwindow is setup
|
||||
|
||||
QFontDatabase::addApplicationFont("://fonts/FreeSans.ttf");
|
||||
a.setFont(QFont("FreeSans", 11, QFont::Normal, false));
|
||||
// QFontDatabase::addApplicationFont("://fonts/FreeSans.ttf");
|
||||
// a.setFont(QFont("FreeSans", 11, QFont::Normal, false));
|
||||
|
||||
mainwin = new MainWindow;
|
||||
|
||||
#ifdef BROKEN_OPENGL_BUILD
|
||||
|
@ -1,4 +1,4 @@
|
||||
/* Profile Select Implementation (Login Screen)
|
||||
/* Profile Select Implementation (Login Screen)
|
||||
*
|
||||
* Copyright (c) 2011-2018 Mark Watkins <mark@jedimark.net>
|
||||
*
|
||||
@ -256,7 +256,7 @@ void ProfileSelect::deleteProfile()
|
||||
QMessageBox::Ok);
|
||||
}
|
||||
qDebug() << "Delete" << path;
|
||||
QMessageBox::information(this, STR_MessageBox_Information, QString(tr("Profile '%1' was succesfully deleted").arg(name)),QMessageBox::Ok);
|
||||
QMessageBox::information(this, STR_MessageBox_Information, tr("Profile '%1' was succesfully deleted").arg(name),QMessageBox::Ok);
|
||||
}
|
||||
|
||||
int row = ui->listView->currentIndex().row();
|
||||
|
@ -1,4 +1,4 @@
|
||||
/* Profile Selector Implementation
|
||||
/* Profile Selector Implementation
|
||||
*
|
||||
* Copyright (c) 2018 Mark Watkins <mark@jedimark.net>
|
||||
*
|
||||
@ -423,7 +423,7 @@ void ProfileSelector::on_buttonDestroyProfile_clicked()
|
||||
QMessageBox::Ok);
|
||||
}
|
||||
qDebug() << "Delete" << path;
|
||||
QMessageBox::information(this, STR_MessageBox_Information, QString(tr("Profile '%1' was succesfully deleted").arg(name)),QMessageBox::Ok);
|
||||
QMessageBox::information(this, STR_MessageBox_Information, tr("Profile '%1' was succesfully deleted").arg(name),QMessageBox::Ok);
|
||||
}
|
||||
|
||||
updateProfileList();
|
||||
@ -431,8 +431,9 @@ void ProfileSelector::on_buttonDestroyProfile_clicked()
|
||||
}
|
||||
}
|
||||
|
||||
QString formatSize(qint64 size) {
|
||||
QStringList units = { "Bytes", "KB", "MB", "GB", "TB", "PB" };
|
||||
QString ProfileSelector::formatSize(qint64 size)
|
||||
{
|
||||
QStringList units = { tr("Bytes"), tr("KB"), tr("MB"), tr("GB"), tr("TB"), tr("PB") };
|
||||
int i;
|
||||
double outputSize = size;
|
||||
for (i=0; i<units.size()-1; i++) {
|
||||
@ -443,7 +444,7 @@ QString formatSize(qint64 size) {
|
||||
}
|
||||
|
||||
|
||||
QString getProfileDiskInfo(Profile *profile)
|
||||
QString ProfileSelector::getProfileDiskInfo(Profile *profile)
|
||||
{
|
||||
QString html;
|
||||
if (profile) {
|
||||
@ -452,9 +453,9 @@ QString getProfileDiskInfo(Profile *profile)
|
||||
qint64 sizeBackups = profile->diskSpaceBackups();
|
||||
|
||||
html += "<table>"
|
||||
"<tr><td align=right>"+QObject::tr("Summaries:")+"</td><td>"+formatSize(sizeSummaries)+"</td></tr>"
|
||||
"<tr><td align=right>"+QObject::tr("Events:")+"</td><td>"+formatSize(sizeEvents)+"</td></tr>"
|
||||
"<tr><td align=right>"+QObject::tr("Backups:")+"</td><td>"+formatSize(sizeBackups)+"</td></tr>"
|
||||
"<tr><td align=right>"+tr("Summaries:")+"</td><td>"+formatSize(sizeSummaries)+"</td></tr>"
|
||||
"<tr><td align=right>"+tr("Events:")+"</td><td>"+formatSize(sizeEvents)+"</td></tr>"
|
||||
"<tr><td align=right>"+tr("Backups:")+"</td><td>"+formatSize(sizeBackups)+"</td></tr>"
|
||||
"</table>";
|
||||
}
|
||||
return html;
|
||||
|
@ -1,4 +1,4 @@
|
||||
/* Profile Selector Header
|
||||
/* Profile Selector Header
|
||||
*
|
||||
* Copyright (c) 2018 Mark Watkins <mark@jedimark.net>
|
||||
*
|
||||
@ -58,6 +58,9 @@ private slots:
|
||||
void on_selectionChanged(const QModelIndex ¤t, const QModelIndex &previous);
|
||||
|
||||
private:
|
||||
QString getProfileDiskInfo(Profile *profile);
|
||||
QString formatSize(qint64 size);
|
||||
|
||||
Ui::ProfileSelector *ui;
|
||||
QStandardItemModel *model;
|
||||
MySortFilterProxyModel2 *proxy;
|
||||
|
@ -1,4 +1,4 @@
|
||||
/* SessionBar Graph Implementation
|
||||
/* SessionBar Graph Implementation
|
||||
*
|
||||
* Copyright (c) 2011-2018 Mark Watkins <mark@jedimark.net>
|
||||
*
|
||||
@ -243,8 +243,7 @@ void SessionBar::paintEvent(QPaintEvent *)
|
||||
int m = (len / 60) % 60;
|
||||
//int s=len % 60;
|
||||
|
||||
QString msg = QString("%1h %2m").arg((short)h, 1, 10, QChar('0')).arg((short)m, 1, 10,
|
||||
QChar('0')); //.arg((short)s,2,10,QChar('0'));
|
||||
QString msg = tr("%1h %2m").arg((short)h, 1, 10, QChar('0')).arg((short)m, 1, 10, QChar('0'));
|
||||
//painter.setBrush(QBrush((*i).color);
|
||||
QRect segrect(3 + sx, 3, ex, height() - 6);
|
||||
|
||||
|
@ -14,38 +14,33 @@ DEFINES += QT_DEPRECATED_WARNINGS
|
||||
|
||||
#SleepyHead requires OpenGL 2.0 support to run smoothly
|
||||
#On platforms where it's not available, it can still be built to work
|
||||
#provided the BrokenGL DEFINES flag is passed to qmake (eg, qmake [specs] /path/to/SleepyHeadQT.pro DEFINES+=BrokenGL)
|
||||
contains(DEFINES, BrokenGL) {
|
||||
message("BrokgenGL has been disabled to test the Dynamic GFX Engine selection")
|
||||
#provided the BrokenGL DEFINES flag is passed to qmake (eg, qmake [specs] /path/to/SleepyHeadQT.pro DEFINES+=BrokenGL) (hint, Projects button on the left)
|
||||
contains(DEFINES, NoGL) {
|
||||
message("Building with QWidget gGraphView to support systems without ANY OpenGL")
|
||||
DEFINES += BROKEN_OPENGL_BUILD
|
||||
DEFINES += NO_OPENGL_BUILD
|
||||
} else:contains(DEFINES, BrokenGL) {
|
||||
DEFINES += BROKEN_OPENGL_BUILD
|
||||
message("Building with QWidget gGraphView to support systems with legacy graphics")
|
||||
DEFINES-=BrokenGL
|
||||
} else {
|
||||
QT += opengl
|
||||
message("Building with regular OpenGL gGraphView")
|
||||
}
|
||||
# message("Building with QWidget gGraphView")
|
||||
# DEFINES += BROKEN_OPENGL_BUILD
|
||||
#} else:contains(DEFINES, NoGL) {
|
||||
# message("Building with QWidget gGraphView (No GL at all)")
|
||||
# DEFINES += BROKEN_OPENGL_BUILD
|
||||
# DEFINES += NO_OPENGL_BUILD
|
||||
#} else {
|
||||
# message("Building with QGLWidget gGraphView")
|
||||
#}
|
||||
|
||||
QT += opengl
|
||||
|
||||
DEFINES += LOCK_RESMED_SESSIONS
|
||||
|
||||
CONFIG += c++11
|
||||
CONFIG += rtti
|
||||
|
||||
# Remove this crap because it sucks
|
||||
CONFIG-=debug_and_release
|
||||
CONFIG -= debug_and_release
|
||||
|
||||
contains(DEFINES, STATIC) {
|
||||
static {
|
||||
CONFIG += static
|
||||
QTPLUGIN += qsvg qgif qpng
|
||||
static {
|
||||
CONFIG += static
|
||||
QTPLUGIN += qgif qpng
|
||||
|
||||
message("Static build.")
|
||||
}
|
||||
message("Static build.")
|
||||
}
|
||||
}
|
||||
|
||||
TARGET = SleepyHead
|
||||
@ -69,9 +64,6 @@ win32 {
|
||||
PRE_TARGETDEPS += git_info.h
|
||||
QMAKE_EXTRA_TARGETS += gitinfotarget
|
||||
|
||||
#Comment out for official builds
|
||||
DEFINES += BETA_BUILD
|
||||
|
||||
#Build the help documentation
|
||||
message("Generating help files");
|
||||
qtPrepareTool(QCOLGENERATOR, qcollectiongenerator)
|
||||
@ -80,30 +72,17 @@ command=$$QCOLGENERATOR $$PWD/help/index.qhcp -o $$PWD/help/index.qhc
|
||||
system($$command)|error("Failed to run: $$command")
|
||||
message("Finished generating help files");
|
||||
|
||||
unix:!macx:!haiku {
|
||||
LIBS += -lX11 -lz -lGLU
|
||||
DEFINES += _TTY_POSIX_
|
||||
}
|
||||
|
||||
macx {
|
||||
QMAKE_MACOSX_DEPLOYMENT_TARGET = 10.7
|
||||
|
||||
LIBS += -lz
|
||||
ICON = icons/iconfile.icns
|
||||
}
|
||||
|
||||
haiku {
|
||||
} else:haiku {
|
||||
LIBS += -lz -lGLU
|
||||
DEFINES += _TTY_POSIX_
|
||||
}
|
||||
|
||||
CONFIG(release, debug|release) {
|
||||
contains(DEFINES, UPX_PACK_EXE) {
|
||||
DEFINES-=UPX_PACK_EXE
|
||||
win32:QMAKE_POST_LINK += upx -k --best --overlay=strip --strip-relocs=0 $(DESTDIR_TARGET)
|
||||
}
|
||||
}
|
||||
win32 {
|
||||
} else:unix {
|
||||
LIBS += -lX11 -lz -lGLU
|
||||
DEFINES += _TTY_POSIX_
|
||||
} else:win32 {
|
||||
DEFINES += WINVER=0x0501 # needed for mingw to pull in appropriate dbt business...probably a better way to do this
|
||||
LIBS += -lsetupapi
|
||||
|
||||
@ -112,28 +91,30 @@ win32 {
|
||||
QMAKE_TARGET_COPYRIGHT = Copyright (c)2011-2018 Mark Watkins
|
||||
QMAKE_TARGET_DESCRIPTION = "OpenSource CPAP Research & Review"
|
||||
VERSION = 1.1.0.0
|
||||
|
||||
RC_ICONS = ./icons/bob-v3.0.ico
|
||||
|
||||
|
||||
INCLUDEPATH += $$PWD
|
||||
INCLUDEPATH += $$[QT_INSTALL_PREFIX]/../src/qtbase/src/3rdparty/zlib
|
||||
|
||||
if (*-msvc*):!equals(TEMPLATE_PREFIX, "vc") {
|
||||
LIBS += -ladvapi32
|
||||
DEFINES += "BUILD_WITH_MSVC=1"
|
||||
} else {
|
||||
# MingW needs this
|
||||
LIBS += -lz
|
||||
}
|
||||
|
||||
|
||||
if (*-msvc*) {
|
||||
CONFIG += precompile_header
|
||||
PRECOMPILED_HEADER = pch.h
|
||||
HEADERS += pch.h
|
||||
|
||||
}
|
||||
|
||||
CONFIG(release, debug|release) {
|
||||
contains(DEFINES, OfficialBuild) {
|
||||
QMAKE_POST_LINK += "$$PWD/../../scripts/release_tool.sh --testing --source \"$$PWD/..\" --binary \"$${OUT_PWD}/$${TARGET}.exe\""
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
TRANSLATIONS = $$files($$PWD/../Translations/*.ts)
|
||||
|
@ -1,4 +1,4 @@
|
||||
/* Statistics Report Generator Implementation
|
||||
/* Statistics Report Generator Implementation
|
||||
*
|
||||
* Copyright (c) 2011-2018 Mark Watkins <mark@jedimark.net>
|
||||
*
|
||||
@ -575,7 +575,7 @@ Statistics::Statistics(QObject *parent) :
|
||||
}
|
||||
|
||||
const QString table_width = "width=99%";
|
||||
QString htmlHeader(bool showheader)
|
||||
QString Statistics::htmlHeader(bool showheader)
|
||||
{
|
||||
|
||||
QString address = p_profile->user->address();
|
||||
@ -584,18 +584,18 @@ QString htmlHeader(bool showheader)
|
||||
QString userinfo;
|
||||
|
||||
if (!p_profile->user->firstName().isEmpty()) {
|
||||
userinfo = QString(QObject::tr("Name: %1, %2")).arg(p_profile->user->lastName()).arg(p_profile->user->firstName()) + "<br/>";
|
||||
userinfo = tr("Name: %1, %2").arg(p_profile->user->lastName()).arg(p_profile->user->firstName()) + "<br/>";
|
||||
if (!p_profile->user->DOB().isNull()) {
|
||||
userinfo += QString(QObject::tr("DOB: %1")).arg(p_profile->user->DOB().toString()) + "<br/>";
|
||||
userinfo += tr("DOB: %1").arg(p_profile->user->DOB().toString()) + "<br/>";
|
||||
}
|
||||
if (!p_profile->user->phone().isEmpty()) {
|
||||
userinfo += QString(QObject::tr("Phone: %1")).arg(p_profile->user->phone()) + "<br/>";
|
||||
userinfo += tr("Phone: %1").arg(p_profile->user->phone()) + "<br/>";
|
||||
}
|
||||
if (!p_profile->user->email().isEmpty()) {
|
||||
userinfo += QString(QObject::tr("Email: %1")).arg(p_profile->user->email()) + "<br/><br/>";
|
||||
userinfo += tr("Email: %1").arg(p_profile->user->email()) + "<br/><br/>";
|
||||
}
|
||||
if (!p_profile->user->address().isEmpty()) {
|
||||
userinfo += QObject::tr("Address:")+"<br/>"+address;
|
||||
userinfo += tr("Address:")+"<br/>"+address;
|
||||
}
|
||||
}
|
||||
|
||||
@ -638,22 +638,22 @@ QString htmlHeader(bool showheader)
|
||||
html += "<div align=center>"
|
||||
+resizeHTMLPixmap(bobPixmap,64,64)+"<br/>"
|
||||
"<font size='+3'>" + STR_TR_SleepyHead + "</font><br/>"
|
||||
"<font size='+2'>" + QObject::tr("Usage Statistics") + "</font><br/>"
|
||||
"<font size='+1' title=\""+QObject::tr("This is for legal reasons. Sorry, not sorry. Without manufacturer support and documentation, SleepyHead is unsuitable as a compliance/medical reporting tool.")+"\">" + QObject::tr("(NOT approved for compliance or medical reporting purposes)")+"</font><br/>";
|
||||
"<font size='+2'>" + tr("Usage Statistics") + "</font><br/>"
|
||||
"<font size='+1' title=\""+tr("This is for legal reasons. Sorry, not sorry. Without manufacturer support and documentation, SleepyHead is unsuitable as a compliance/medical reporting tool.")+"\">" + tr("(NOT approved for compliance or medical reporting purposes)")+"</font><br/>";
|
||||
|
||||
if (!userinfo.isEmpty()) html += "<br/>"+userinfo+"<br/>";
|
||||
html += "</div><br/>";
|
||||
}
|
||||
return html;
|
||||
}
|
||||
QString htmlFooter(bool showinfo=true)
|
||||
QString Statistics::htmlFooter(bool showinfo)
|
||||
{
|
||||
QString html;
|
||||
|
||||
if (showinfo) {
|
||||
html += "<hr/><div align=center><font size='-1'><i>";
|
||||
html += QString(QObject::tr("This report was generated by SleepyHead v%1")).arg(ShortVersionString) + "<br/>"
|
||||
+QObject::tr("SleepyHead is free open-source CPAP research software available from http://sleepyhead.jedimark.net");
|
||||
html += tr("This report was generated by SleepyHead v%1").arg(ShortVersionString) + "<br/>"
|
||||
+tr("SleepyHead is free open-source CPAP research software available from http://sleepyhead.jedimark.net");
|
||||
html += "</i></font></div>";
|
||||
}
|
||||
|
||||
@ -1019,7 +1019,7 @@ QString Statistics::GenerateHTML()
|
||||
|
||||
// int decimals = 2;
|
||||
html += "<div align=center>";
|
||||
html += QString("<table class=curved "+table_width+">");
|
||||
html += "<table class=curved "+table_width+">";
|
||||
|
||||
int number_periods = 0;
|
||||
if (p_profile->general->statReportMode() == 1) {
|
||||
@ -1119,16 +1119,16 @@ QString Statistics::GenerateHTML()
|
||||
|
||||
if (value == 0) {
|
||||
html+=QString("<tr><td colspan=%1 align=center>%2</td></tr>\n").arg(periods.size()+1).
|
||||
arg(QString(tr("No %1 data available.")).arg(machine));
|
||||
arg(tr("No %1 data available.").arg(machine));
|
||||
} else if (value == 1) {
|
||||
html+=QString("<tr><td colspan=%1 align=center>%2</td></tr>\n").arg(periods.size()+1).
|
||||
arg(QString(tr("%1 day of %2 Data on %3"))
|
||||
arg(tr("%1 day of %2 Data on %3")
|
||||
.arg(value)
|
||||
.arg(machine)
|
||||
.arg(last.toString()));
|
||||
} else {
|
||||
html+=QString("<tr><td colspan=%1 align=center>%2</td></tr>\n").arg(periods.size()+1).
|
||||
arg(QString(tr("%1 days of %2 Data, between %3 and %4"))
|
||||
arg(tr("%1 days of %2 Data, between %3 and %4")
|
||||
.arg(value)
|
||||
.arg(machine)
|
||||
.arg(first.toString())
|
||||
@ -1210,10 +1210,10 @@ void Statistics::UpdateRecordsBox()
|
||||
|
||||
float comperc = (100.0 / float(totaldays)) * float(compliant);
|
||||
|
||||
html += "<b>"+QObject::tr("CPAP Usage")+"</b><br/>";
|
||||
html += QObject::tr("Days Used: %1").arg(totaldays) + "<br/>";
|
||||
html += QObject::tr("Low Use Days: %1").arg(totaldays - compliant) + "<br/>";
|
||||
html += QObject::tr("Compliance: %1%").arg(comperc, 0, 'f', 1) + "<br/>";
|
||||
html += "<b>"+tr("CPAP Usage")+"</b><br/>";
|
||||
html += tr("Days Used: %1").arg(totaldays) + "<br/>";
|
||||
html += tr("Low Use Days: %1").arg(totaldays - compliant) + "<br/>";
|
||||
html += tr("Compliance: %1%").arg(comperc, 0, 'f', 1) + "<br/>";
|
||||
|
||||
/////////////////////////////////////////////////////////////////////////////////////
|
||||
/// AHI Records
|
||||
@ -1237,30 +1237,30 @@ void Statistics::UpdateRecordsBox()
|
||||
}
|
||||
ahilist.insert(ahi, date);
|
||||
}
|
||||
html += QObject::tr("Days AHI of 5 or greater: %1").arg(baddays) + "<br/><br/>";
|
||||
html += tr("Days AHI of 5 or greater: %1").arg(baddays) + "<br/><br/>";
|
||||
|
||||
|
||||
if (ahilist.size() > (show_records * 2)) {
|
||||
it = ahilist.begin();
|
||||
it_end = ahilist.end();
|
||||
|
||||
html += "<b>"+QObject::tr("Best AHI")+"</b><br/>";
|
||||
html += "<b>"+tr("Best AHI")+"</b><br/>";
|
||||
|
||||
for (int i=0; (i<show_records) && (it != it_end); ++i, ++it) {
|
||||
html += QString("<a href='daily=%1'>").arg(it.value().toString(Qt::ISODate))
|
||||
+QObject::tr("Date: %1 AHI: %2").arg(it.value().toString(Qt::SystemLocaleShortDate)).arg(it.key(), 0, 'f', 2) + "</a><br/>";
|
||||
+tr("Date: %1 AHI: %2").arg(it.value().toString(Qt::SystemLocaleShortDate)).arg(it.key(), 0, 'f', 2) + "</a><br/>";
|
||||
|
||||
}
|
||||
|
||||
html += "<br/>";
|
||||
|
||||
html += "<b>"+QObject::tr("Worst AHI")+"</b><br/>";
|
||||
html += "<b>"+tr("Worst AHI")+"</b><br/>";
|
||||
|
||||
it = ahilist.end() - 1;
|
||||
it_end = ahilist.begin();
|
||||
for (int i=0; (i<show_records) && (it != it_end); ++i, --it) {
|
||||
html += QString("<a href='daily=%1'>").arg(it.value().toString(Qt::ISODate))
|
||||
+QObject::tr("Date: %1 AHI: %2").arg(it.value().toString(Qt::SystemLocaleShortDate)).arg(it.key(), 0, 'f', 2) + "</a><br/>";
|
||||
+tr("Date: %1 AHI: %2").arg(it.value().toString(Qt::SystemLocaleShortDate)).arg(it.key(), 0, 'f', 2) + "</a><br/>";
|
||||
|
||||
}
|
||||
|
||||
@ -1291,29 +1291,29 @@ void Statistics::UpdateRecordsBox()
|
||||
it = ahilist.begin();
|
||||
it_end = ahilist.end();
|
||||
|
||||
html += "<b>"+QObject::tr("Best Flow Limitation")+"</b><br/>";
|
||||
html += "<b>"+tr("Best Flow Limitation")+"</b><br/>";
|
||||
|
||||
for (int i=0; (i<show_records) && (it != it_end); ++i, ++it) {
|
||||
html += QString("<a href='daily=%1'>").arg(it.value().toString(Qt::ISODate))
|
||||
+QObject::tr("Date: %1 FL: %2").arg(it.value().toString(Qt::SystemLocaleShortDate)).arg(it.key(), 0, 'f', 2) + "</a><br/>";
|
||||
+tr("Date: %1 FL: %2").arg(it.value().toString(Qt::SystemLocaleShortDate)).arg(it.key(), 0, 'f', 2) + "</a><br/>";
|
||||
|
||||
}
|
||||
|
||||
html += "<br/>";
|
||||
|
||||
html += "<b>"+QObject::tr("Worst Flow Limtation")+"</b><br/>";
|
||||
html += "<b>"+tr("Worst Flow Limtation")+"</b><br/>";
|
||||
|
||||
it = ahilist.end() - 1;
|
||||
it_end = ahilist.begin();
|
||||
for (int i=0; (i<show_records) && (it != it_end); ++i, --it) {
|
||||
if (it.key() > 0) {
|
||||
html += QString("<a href='daily=%1'>").arg(it.value().toString(Qt::ISODate))
|
||||
+QObject::tr("Date: %1 FL: %2").arg(it.value().toString(Qt::SystemLocaleShortDate)).arg(it.key(), 0, 'f', 2) + "</a><br/>";
|
||||
+tr("Date: %1 FL: %2").arg(it.value().toString(Qt::SystemLocaleShortDate)).arg(it.key(), 0, 'f', 2) + "</a><br/>";
|
||||
cnt++;
|
||||
}
|
||||
}
|
||||
if (cnt == 0) {
|
||||
html+= "<i>"+QObject::tr("No Flow Limitation on record")+"</i><br/>";
|
||||
html+= "<i>"+tr("No Flow Limitation on record")+"</i><br/>";
|
||||
}
|
||||
|
||||
html += "<br/>";
|
||||
@ -1334,7 +1334,7 @@ void Statistics::UpdateRecordsBox()
|
||||
|
||||
cnt = 0;
|
||||
if (ahilist.size() > (show_records * 2)) {
|
||||
html += "<b>"+QObject::tr("Worst Large Leaks")+"</b><br/>";
|
||||
html += "<b>"+tr("Worst Large Leaks")+"</b><br/>";
|
||||
|
||||
it = ahilist.end() - 1;
|
||||
it_end = ahilist.begin();
|
||||
@ -1342,13 +1342,13 @@ void Statistics::UpdateRecordsBox()
|
||||
for (int i=0; (i<show_records) && (it != it_end); ++i, --it) {
|
||||
if (it.key() > 0) {
|
||||
html += QString("<a href='daily=%1'>").arg(it.value().toString(Qt::ISODate))
|
||||
+QObject::tr("Date: %1 Leak: %2%").arg(it.value().toString(Qt::SystemLocaleShortDate)).arg(it.key(), 0, 'f', 2) + "</a><br/>";
|
||||
+tr("Date: %1 Leak: %2%").arg(it.value().toString(Qt::SystemLocaleShortDate)).arg(it.key(), 0, 'f', 2) + "</a><br/>";
|
||||
cnt++;
|
||||
}
|
||||
|
||||
}
|
||||
if (cnt == 0) {
|
||||
html+= "<i>"+QObject::tr("No Large Leaks on record")+"</i><br/>";
|
||||
html+= "<i>"+tr("No Large Leaks on record")+"</i><br/>";
|
||||
}
|
||||
|
||||
html += "<br/>";
|
||||
@ -1371,7 +1371,7 @@ void Statistics::UpdateRecordsBox()
|
||||
}
|
||||
|
||||
if (ahilist.size() > (show_records * 2)) {
|
||||
html += "<b>"+QObject::tr("Worst CSR")+"</b><br/>";
|
||||
html += "<b>"+tr("Worst CSR")+"</b><br/>";
|
||||
|
||||
it = ahilist.end() - 1;
|
||||
it_end = ahilist.begin();
|
||||
@ -1379,12 +1379,12 @@ void Statistics::UpdateRecordsBox()
|
||||
|
||||
if (it.key() > 0) {
|
||||
html += QString("<a href='daily=%1'>").arg(it.value().toString(Qt::ISODate))
|
||||
+QObject::tr("Date: %1 CSR: %2%").arg(it.value().toString(Qt::SystemLocaleShortDate)).arg(it.key(), 0, 'f', 2) + "</a><br/>";
|
||||
+tr("Date: %1 CSR: %2%").arg(it.value().toString(Qt::SystemLocaleShortDate)).arg(it.key(), 0, 'f', 2) + "</a><br/>";
|
||||
cnt++;
|
||||
}
|
||||
}
|
||||
if (cnt == 0) {
|
||||
html+= "<i>"+QObject::tr("No CSR on record")+"</i><br/>";
|
||||
html+= "<i>"+tr("No CSR on record")+"</i><br/>";
|
||||
}
|
||||
|
||||
html += "<br/>";
|
||||
@ -1401,7 +1401,7 @@ void Statistics::UpdateRecordsBox()
|
||||
}
|
||||
|
||||
if (ahilist.size() > (show_records * 2)) {
|
||||
html += "<b>"+QObject::tr("Worst PB")+"</b><br/>";
|
||||
html += "<b>"+tr("Worst PB")+"</b><br/>";
|
||||
|
||||
it = ahilist.end() - 1;
|
||||
it_end = ahilist.begin();
|
||||
@ -1409,12 +1409,12 @@ void Statistics::UpdateRecordsBox()
|
||||
|
||||
if (it.key() > 0) {
|
||||
html += QString("<a href='daily=%1'>").arg(it.value().toString(Qt::ISODate))
|
||||
+QObject::tr("Date: %1 PB: %2%").arg(it.value().toString(Qt::SystemLocaleShortDate)).arg(it.key(), 0, 'f', 2) + "</a><br/>";
|
||||
+tr("Date: %1 PB: %2%").arg(it.value().toString(Qt::SystemLocaleShortDate)).arg(it.key(), 0, 'f', 2) + "</a><br/>";
|
||||
cnt++;
|
||||
}
|
||||
}
|
||||
if (cnt == 0) {
|
||||
html+= "<i>"+QObject::tr("No PB on record")+"</i><br/>";
|
||||
html+= "<i>"+tr("No PB on record")+"</i><br/>";
|
||||
}
|
||||
|
||||
html += "<br/>";
|
||||
@ -1422,9 +1422,9 @@ void Statistics::UpdateRecordsBox()
|
||||
}
|
||||
|
||||
} else {
|
||||
html += "<br/><b>"+QObject::tr("Want more information?")+"</b><br/>";
|
||||
html += "<i>"+QObject::tr("SleepyHead needs all summary data loaded to calculate best/worst data for individual days.")+"</i><br/><br/>";
|
||||
html += "<i>"+QObject::tr("Please enable Pre-Load Summaries checkbox in preferences to make sure this data is available.")+"</i><br/><br/>";
|
||||
html += "<br/><b>"+tr("Want more information?")+"</b><br/>";
|
||||
html += "<i>"+tr("SleepyHead needs all summary data loaded to calculate best/worst data for individual days.")+"</i><br/><br/>";
|
||||
html += "<i>"+tr("Please enable Pre-Load Summaries checkbox in preferences to make sure this data is available.")+"</i><br/><br/>";
|
||||
}
|
||||
|
||||
|
||||
@ -1444,26 +1444,26 @@ void Statistics::UpdateRecordsBox()
|
||||
|
||||
|
||||
if (list.size() >= 2) {
|
||||
html += "<b>"+QObject::tr("Best RX Setting")+"</b><br/>";
|
||||
html += "<b>"+tr("Best RX Setting")+"</b><br/>";
|
||||
const RXItem & rxbest = *list.at(0);
|
||||
html += QString("<a href='overview=%1,%2'>").arg(rxbest.start.toString(Qt::ISODate)).arg(rxbest.end.toString(Qt::ISODate)) +
|
||||
QObject::tr("Date: %1 - %2").arg(rxbest.start.toString(Qt::SystemLocaleShortDate)).arg(rxbest.end.toString(Qt::SystemLocaleShortDate)) + "</a><br/>";
|
||||
tr("Date: %1 - %2").arg(rxbest.start.toString(Qt::SystemLocaleShortDate)).arg(rxbest.end.toString(Qt::SystemLocaleShortDate)) + "</a><br/>";
|
||||
html += QString("%1").arg(rxbest.machine->model()) + "<br/>";
|
||||
html += QString("Serial: %1").arg(rxbest.machine->serial()) + "<br/>";
|
||||
html += QObject::tr("Culminative AHI: %1").arg(double(rxbest.ahi) / rxbest.hours, 0, 'f', 2) + "<br/>";
|
||||
html += QObject::tr("Culminative Hours: %1").arg(rxbest.hours, 0, 'f', 2) + "<br/>";
|
||||
html += tr("Culminative AHI: %1").arg(double(rxbest.ahi) / rxbest.hours, 0, 'f', 2) + "<br/>";
|
||||
html += tr("Culminative Hours: %1").arg(rxbest.hours, 0, 'f', 2) + "<br/>";
|
||||
html += QString("%1").arg(rxbest.pressure) + "<br/>";
|
||||
html += QString("%1").arg(rxbest.relief) + "<br/>";
|
||||
html += "<br/>";
|
||||
|
||||
html += "<b>"+QObject::tr("Worst RX Setting")+"</b><br/>";
|
||||
html += "<b>"+tr("Worst RX Setting")+"</b><br/>";
|
||||
const RXItem & rxworst = *list.at(list.size() -1);
|
||||
html += QString("<a href='overview=%1,%2'>").arg(rxworst.start.toString(Qt::ISODate)).arg(rxworst.end.toString(Qt::ISODate)) +
|
||||
QObject::tr("Date: %1 - %2").arg(rxworst.start.toString(Qt::SystemLocaleShortDate)).arg(rxworst.end.toString(Qt::SystemLocaleShortDate)) + "</a><br/>";
|
||||
tr("Date: %1 - %2").arg(rxworst.start.toString(Qt::SystemLocaleShortDate)).arg(rxworst.end.toString(Qt::SystemLocaleShortDate)) + "</a><br/>";
|
||||
html += QString("%1").arg(rxworst.machine->model()) + "<br/>";
|
||||
html += QString("Serial: %1").arg(rxworst.machine->serial()) + "<br/>";
|
||||
html += QObject::tr("Culminative AHI: %1").arg(double(rxworst.ahi) / rxworst.hours, 0, 'f', 2) + "<br/>";
|
||||
html += QObject::tr("Culminative Hours: %1").arg(rxworst.hours, 0, 'f', 2) + "<br/>";
|
||||
html += tr("Culminative AHI: %1").arg(double(rxworst.ahi) / rxworst.hours, 0, 'f', 2) + "<br/>";
|
||||
html += tr("Culminative Hours: %1").arg(rxworst.hours, 0, 'f', 2) + "<br/>";
|
||||
|
||||
html += QString("%1").arg(rxworst.pressure) + "<br/>";
|
||||
html += QString("%1").arg(rxworst.relief) + "<br/>";
|
||||
|
@ -164,6 +164,9 @@ class Statistics : public QObject
|
||||
|
||||
|
||||
protected:
|
||||
QString htmlHeader(bool showheader);
|
||||
QString htmlFooter(bool showinfo=true);
|
||||
|
||||
// Using a map to maintain order
|
||||
QList<StatisticsRow> rows;
|
||||
QMap<StatCalcType, QString> calcnames;
|
||||
|
Loading…
Reference in New Issue
Block a user