diff --git a/Building/Windows/BuildInstall.iss b/Building/Windows/BuildInstall.iss
index f19368f2..f750b401 100644
--- a/Building/Windows/BuildInstall.iss
+++ b/Building/Windows/BuildInstall.iss
@@ -95,6 +95,11 @@ Name: "spanish"; MessagesFile: "compiler:Languages\Spanish.isl"
Name: "turkish"; MessagesFile: "compiler:Languages\Turkish.isl"
Name: "ukrainian"; MessagesFile: "compiler:Languages\Ukrainian.isl"
+[InstallDelete]
+Type: files; Name: "{app}\Html\release_notes*.html"
+Type: files; Name: "{app}\Html\credits*.html"
+Type: files; Name: "{app}\Html\about*.html"
+
[Tasks]
Name: "desktopicon"; Description: "{cm:CreateDesktopIcon}"; GroupDescription: "{cm:AdditionalIcons}"
Name: "quicklaunchicon"; Description: "{cm:CreateQuickLaunchIcon}"; GroupDescription: "{cm:AdditionalIcons}"; Flags: unchecked; OnlyBelowVersion: 0,6.1
diff --git a/Htmldocs/release_notes.html b/Htmldocs/release_notes.html
index 3f80ee21..a55885f4 100644
--- a/Htmldocs/release_notes.html
+++ b/Htmldocs/release_notes.html
@@ -11,6 +11,16 @@
For other languages, go to:
http://www.apneaboard.com/wiki/index.php/OSCAR_Release_Notes
+ Changes and fixes in OSCAR v1.X.Y
+
Portions of OSCAR are © 2019-2020 by
+ The OSCAR Team
+
+ - [fix] Correct calculation of average leak rate on Welcome page.
+ - [fix] Correct installation of non-English Release Notes on Windows.
+ - [fix] User first and last name in Profile window may now have UTF-8 (non-ASCII) characters.
+ - [fix] Fix rare problem of OSCAR crashing with unusual Journal file.
+
+
Changes and fixes in OSCAR v1.2.0
Portions of OSCAR are © 2019-2020 by
The OSCAR Team
diff --git a/oscar/SleepLib/day.cpp b/oscar/SleepLib/day.cpp
index 3e701bea..691a1716 100644
--- a/oscar/SleepLib/day.cpp
+++ b/oscar/SleepLib/day.cpp
@@ -98,6 +98,16 @@ Session *Day::find(SessionID sessid)
return nullptr;
}
+Session *Day::find(SessionID sessid, MachineType mt)
+{
+ for (auto & sess : sessions) {
+ if ((sess->session() == sessid) && (sess->s_machtype == mt)) {
+ return sess;
+ }
+ }
+ return nullptr;
+}
+
void Day::addSession(Session *s)
{
if (s == nullptr) {
diff --git a/oscar/SleepLib/day.h b/oscar/SleepLib/day.h
index 8651442c..2691f652 100644
--- a/oscar/SleepLib/day.h
+++ b/oscar/SleepLib/day.h
@@ -202,6 +202,8 @@ class Day
Session *find(SessionID sessid);
+ Session *find(SessionID sessid, MachineType mt);
+
//! \brief Returns the number of Sessions in this day record
int size() { return sessions.size(); }
diff --git a/oscar/SleepLib/loader_plugins/resmed_loader.cpp b/oscar/SleepLib/loader_plugins/resmed_loader.cpp
index df360550..4a2700f4 100644
--- a/oscar/SleepLib/loader_plugins/resmed_loader.cpp
+++ b/oscar/SleepLib/loader_plugins/resmed_loader.cpp
@@ -2142,7 +2142,7 @@ void ResDayTask::run()
quint32 maskoff = resday->str.maskoff[i];
if ( (maskon > QDateTime::currentDateTime().toTime_t()) ||
(maskoff > QDateTime::currentDateTime().toTime_t()) ) {
- qWarning() << "mask time in future" << resday->date;
+ qWarning() << "mask time in future" << resday->date << "now" << QDateTime::currentDateTime().toTime_t() << "maskon" << maskon << "maskoff" << maskoff;
continue;
}
if (((maskon>0) && (maskoff>0)) && (maskon != maskoff)) { //ignore very short sessions
@@ -2184,7 +2184,7 @@ void ResDayTask::run()
for (int i=0; i < maskOnSize; ++i) {
if ( (resday->str.maskon[i] > QDateTime::currentDateTime().toTime_t()) ||
(resday->str.maskoff[i] > QDateTime::currentDateTime().toTime_t()) ) {
- qWarning() << "mask time in future" << resday->date;
+ qWarning() << "mask time in future" << resday->date << "now" << QDateTime::currentDateTime().toTime_t() << "maskon" << resday->str.maskon[i] << "maskoff" << resday->str.maskoff[i];
continue;
}
if (((resday->str.maskon[i]>0) || (resday->str.maskoff[i]>0))
@@ -2235,7 +2235,7 @@ void ResDayTask::run()
EDFduration dur = getEDFDuration(fullpath);
if ((dur.start > (QDateTime::currentDateTime().toMSecsSinceEpoch()/1000L)) ||
(dur.end > (QDateTime::currentDateTime().toMSecsSinceEpoch()/1000L)) ) {
- qWarning() << "Future Date in" << fullpath;
+ qWarning() << "Future Date in" << fullpath << "now" << QDateTime::currentDateTime().toSecsSinceEpoch() << "maskon" << dur.start << "maskoff" << dur.end;
continue; // skip this file
}
for (int i=overlaps.size()-1; i>=0; --i) {
diff --git a/oscar/SleepLib/preferences.cpp b/oscar/SleepLib/preferences.cpp
index 7efae835..a4e045aa 100644
--- a/oscar/SleepLib/preferences.cpp
+++ b/oscar/SleepLib/preferences.cpp
@@ -335,6 +335,9 @@ bool Preferences::Save(QString filename)
QDomDocument doc(p_name);
+ QDomProcessingInstruction pi = doc.createProcessingInstruction("xml", "version=\"1.0\" encoding=\"UTF-8\"");
+ doc.appendChild(pi);
+
QDomElement droot = doc.createElement(STR_AppName);
doc.appendChild(droot);
@@ -368,6 +371,8 @@ bool Preferences::Save(QString filename)
}
QTextStream ts(&file);
+ ts.setCodec("UTF-8");
+ ts.setGenerateByteOrderMark(true);
ts << doc.toString();
file.close();
diff --git a/oscar/VERSION b/oscar/VERSION
index 19c04ec9..de526223 100644
--- a/oscar/VERSION
+++ b/oscar/VERSION
@@ -1,5 +1,4 @@
// Update the string below to set OSCAR's version and release status.
// See https://semver.org/spec/v2.0.0.html for details on format.
-#define VERSION "1.2.0"
-
+#define VERSION "1.2.1-alpha.0"
diff --git a/oscar/daily.cpp b/oscar/daily.cpp
index 613a6de7..7bff1515 100644
--- a/oscar/daily.cpp
+++ b/oscar/daily.cpp
@@ -560,7 +560,7 @@ void Daily::Link_clicked(const QUrl &url)
if (code=="togglecpapsession") { // Enable/Disable CPAP session
day=p_profile->GetDay(previous_date,MT_CPAP);
if (!day) return;
- Session *sess=day->find(sid);
+ Session *sess=day->find(sid, MT_CPAP);
if (!sess)
return;
// int i=webView->page()->mainFrame()->scrollBarMaximum(Qt::Vertical)-webView->page()->mainFrame()->scrollBarValue(Qt::Vertical);
@@ -571,7 +571,7 @@ void Daily::Link_clicked(const QUrl &url)
// webView->page()->mainFrame()->setScrollBarValue(Qt::Vertical, webView->page()->mainFrame()->scrollBarMaximum(Qt::Vertical)-i);
} else if (code=="toggleoxisession") { // Enable/Disable Oximetry session
day=p_profile->GetDay(previous_date,MT_OXIMETER);
- Session *sess=day->find(sid);
+ Session *sess=day->find(sid, MT_OXIMETER);
if (!sess)
return;
// int i=webView->page()->mainFrame()->scrollBarMaximum(Qt::Vertical)-webView->page()->mainFrame()->scrollBarValue(Qt::Vertical);
diff --git a/oscar/mainwindow.cpp b/oscar/mainwindow.cpp
index d8fba199..95cfdf0e 100644
--- a/oscar/mainwindow.cpp
+++ b/oscar/mainwindow.cpp
@@ -1197,38 +1197,42 @@ void MainWindow::updateFavourites()
if (journal) {
if (journal->size() > 0) {
Session *sess = journal->firstSession(MT_JOURNAL);
- QString tmp;
- bool filtered = !bookmarkFilter.isEmpty();
- bool found = !filtered;
+ if (!sess) {
+ qWarning() << "null session for MT_JOURNAL first session";
+ } else {
+ QString tmp;
+ bool filtered = !bookmarkFilter.isEmpty();
+ bool found = !filtered;
- if (sess->settings.contains(Bookmark_Start)) {
- //QVariantList start=sess->settings[Bookmark_Start].toList();
- //QVariantList end=sess->settings[Bookmark_End].toList();
- QStringList notes = sess->settings[Bookmark_Notes].toStringList();
+ if (sess->settings.contains(Bookmark_Start)) {
+ //QVariantList start=sess->settings[Bookmark_Start].toList();
+ //QVariantList end=sess->settings[Bookmark_End].toList();
+ QStringList notes = sess->settings[Bookmark_Notes].toStringList();
- if (notes.size() > 0) {
- tmp += QString("%2 ")
- .arg(date.toString(Qt::ISODate))
- .arg(date.toString(MedDateFormat));
+ if (notes.size() > 0) {
+ tmp += QString(" |
%2 ")
+ .arg(date.toString(Qt::ISODate))
+ .arg(date.toString(MedDateFormat));
- tmp += "";
+ tmp += "";
- for (int i = 0; i < notes.size(); i++) {
- //QDate d=start[i].toDate();
- QString note = notes[i];
+ for (int i = 0; i < notes.size(); i++) {
+ //QDate d=start[i].toDate();
+ QString note = notes[i];
- if (filtered && note.contains(bookmarkFilter, Qt::CaseInsensitive)) {
- found = true;
+ if (filtered && note.contains(bookmarkFilter, Qt::CaseInsensitive)) {
+ found = true;
+ }
+
+ tmp += "- " + note + "
";
}
- tmp += "- " + note + "
";
+ tmp += " | ";
}
-
- tmp += "";
}
- }
- if (found) { html += tmp; }
+ if (found) { html += tmp; }
+ }
}
}
diff --git a/oscar/welcome.cpp b/oscar/welcome.cpp
index 77f34e01..4afe85bb 100644
--- a/oscar/welcome.cpp
+++ b/oscar/welcome.cpp
@@ -300,8 +300,8 @@ QString Welcome::GenerateCPAPHTML()
//EventDataType lat = day->timeAboveThreshold(CPAP_Leak, p_profile->cpap->leakRedline())/ 60.0;
//EventDataType leaks = 1.0/hours * lat;
- EventDataType leak = day->avg(CPAP_Leak);
- EventDataType leakdays = p_profile->calcAvg(CPAP_Leak, MT_CPAP, starttime, endtime);
+ EventDataType leak = day->wavg(CPAP_Leak);
+ EventDataType leakdays = p_profile->calcWavg(CPAP_Leak, MT_CPAP, starttime, endtime);
if ((leak < leakdays) && ((leakdays - leak) >= 0.1)) {
comp = under;