mirror of
https://gitlab.com/pholy/OSCAR-code.git
synced 2025-04-06 11:10:44 +00:00
Recompressing events doesn't need to recalculate summaries
This commit is contained in:
parent
a369e2dac4
commit
58da6d882a
@ -1,4 +1,4 @@
|
|||||||
/* SleepLib Session Implementation
|
/* SleepLib Session Implementation
|
||||||
* This stuff contains the base calculation smarts
|
* This stuff contains the base calculation smarts
|
||||||
*
|
*
|
||||||
* Copyright (c) 2011-2018 Mark Watkins <mark@jedimark.net>
|
* Copyright (c) 2011-2018 Mark Watkins <mark@jedimark.net>
|
||||||
@ -137,10 +137,10 @@ bool Session::Destroy()
|
|||||||
QString summaryfile = s_machine->getSummariesPath() + base + ".000";
|
QString summaryfile = s_machine->getSummariesPath() + base + ".000";
|
||||||
QString eventfile = s_machine->getEventsPath() + base + ".001";
|
QString eventfile = s_machine->getEventsPath() + base + ".001";
|
||||||
if (!dir.remove(summaryfile)) {
|
if (!dir.remove(summaryfile)) {
|
||||||
qDebug() << "Could not delete" << summaryfile;
|
// qDebug() << "Could not delete" << summaryfile;
|
||||||
}
|
}
|
||||||
if (!dir.remove(eventfile)) {
|
if (!dir.remove(eventfile)) {
|
||||||
qDebug() << "Could not delete" << eventfile;
|
// qDebug() << "Could not delete" << eventfile;
|
||||||
}
|
}
|
||||||
|
|
||||||
return s_machine->unlinkSession(this); //!dir.exists(base + ".000") && !dir.exists(base + ".001");
|
return s_machine->unlinkSession(this); //!dir.exists(base + ".000") && !dir.exists(base + ".001");
|
||||||
@ -714,7 +714,6 @@ bool Session::StoreEvents()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
for (i = eventlist.begin(); i != i_end; i++) {
|
for (i = eventlist.begin(); i != i_end; i++) {
|
||||||
ev_size=i.value().size();
|
ev_size=i.value().size();
|
||||||
|
|
||||||
|
@ -45,9 +45,9 @@ void MyOutputHandler(QtMsgType type, const QMessageLogContext &context, const QS
|
|||||||
if (logger && logger->isRunning()) {
|
if (logger && logger->isRunning()) {
|
||||||
logger->append(msg);
|
logger->append(msg);
|
||||||
}
|
}
|
||||||
//else {
|
else {
|
||||||
fprintf(stderr, "%s\n", msg.toLocal8Bit().data());
|
fprintf(stderr, "%s\n", msg.toLocal8Bit().data());
|
||||||
// }
|
}
|
||||||
|
|
||||||
if (type == QtFatalMsg) {
|
if (type == QtFatalMsg) {
|
||||||
abort();
|
abort();
|
||||||
|
@ -2209,6 +2209,10 @@ void MainWindow::on_filterBookmarksButton_clicked()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void MainWindow::recompressEvents()
|
||||||
|
{
|
||||||
|
QTimer::singleShot(0, this, SLOT(doRecompressEvents()));
|
||||||
|
}
|
||||||
void MainWindow::reprocessEvents(bool restart)
|
void MainWindow::reprocessEvents(bool restart)
|
||||||
{
|
{
|
||||||
m_restartRequired = restart;
|
m_restartRequired = restart;
|
||||||
@ -2245,12 +2249,11 @@ void MainWindow::MachineUnsupported(Machine * m)
|
|||||||
QMessageBox::information(this, STR_MessageBox_Error, QObject::tr("Sorry, your %1 %2 machine is not currently supported.").arg(m->brand()).arg(m->model()), QMessageBox::Ok);
|
QMessageBox::information(this, STR_MessageBox_Error, QObject::tr("Sorry, your %1 %2 machine is not currently supported.").arg(m->brand()).arg(m->model()), QMessageBox::Ok);
|
||||||
}
|
}
|
||||||
|
|
||||||
void MainWindow::doReprocessEvents()
|
void MainWindow::doRecompressEvents()
|
||||||
{
|
{
|
||||||
if (p_profile->countDays(MT_CPAP, p_profile->FirstDay(), p_profile->LastDay()) == 0) {
|
if (p_profile->countDays(MT_CPAP, p_profile->FirstDay(), p_profile->LastDay()) == 0) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
m_inRecalculation = true;
|
m_inRecalculation = true;
|
||||||
QDate first = p_profile->FirstDay();
|
QDate first = p_profile->FirstDay();
|
||||||
QDate date = p_profile->LastDay();
|
QDate date = p_profile->LastDay();
|
||||||
@ -2265,8 +2268,72 @@ void MainWindow::doReprocessEvents()
|
|||||||
int daycount = first.daysTo(date);
|
int daycount = first.daysTo(date);
|
||||||
int idx = 0;
|
int idx = 0;
|
||||||
|
|
||||||
|
qstatus->setText(tr("Re/Decompressing Session Event Data"));
|
||||||
|
|
||||||
|
if (qprogress) {
|
||||||
|
qprogress->setValue(0);
|
||||||
|
qprogress->setVisible(true);
|
||||||
|
qprogress->setMaximum(daycount);
|
||||||
|
}
|
||||||
|
|
||||||
|
bool isopen;
|
||||||
|
|
||||||
|
do {
|
||||||
|
day = p_profile->GetDay(date, MT_CPAP);
|
||||||
|
|
||||||
|
if (day) {
|
||||||
|
for (int i = 0; i < day->size(); i++) {
|
||||||
|
sess = (*day)[i];
|
||||||
|
isopen = sess->eventsLoaded();
|
||||||
|
|
||||||
|
// Load the events if they aren't loaded already
|
||||||
|
sess->OpenEvents();
|
||||||
|
|
||||||
|
sess->SetChanged(true);
|
||||||
|
|
||||||
|
sess->machine()->SaveSession(sess);
|
||||||
|
|
||||||
|
if (!isopen) {
|
||||||
|
sess->TrashEvents();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
date = date.addDays(-1);
|
||||||
|
qprogress->setValue(idx);
|
||||||
|
QApplication::processEvents();
|
||||||
|
idx++;
|
||||||
|
} while (date >= first);
|
||||||
|
|
||||||
|
qstatus->setText(tr(""));
|
||||||
|
qprogress->setVisible(false);
|
||||||
|
m_inRecalculation = false;
|
||||||
|
|
||||||
|
Notify(tr("Session re/decompression are now complete."), tr("Task Completed"));
|
||||||
|
}
|
||||||
|
void MainWindow::doReprocessEvents()
|
||||||
|
{
|
||||||
|
if (p_profile->countDays(MT_CPAP, p_profile->FirstDay(), p_profile->LastDay()) == 0) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
m_inRecalculation = true;
|
||||||
|
QDate first = p_profile->FirstDay();
|
||||||
|
QDate date = p_profile->LastDay();
|
||||||
|
Session *sess;
|
||||||
|
Day *day;
|
||||||
|
//FlowParser flowparser;
|
||||||
|
|
||||||
|
mainwin->Notify(tr("Performance will be degraded during these recalculations."),
|
||||||
|
tr("Recompressing Session Data"));
|
||||||
|
|
||||||
|
// For each day in history
|
||||||
|
int daycount = first.daysTo(date);
|
||||||
|
int idx = 0;
|
||||||
|
|
||||||
QList<Machine *> machines = p_profile->GetMachines(MT_CPAP);
|
QList<Machine *> machines = p_profile->GetMachines(MT_CPAP);
|
||||||
|
|
||||||
|
|
||||||
// Disabling multithreaded save as it appears it's causing problems
|
// Disabling multithreaded save as it appears it's causing problems
|
||||||
bool cache_sessions = false; //p_profile->session->cacheSessions();
|
bool cache_sessions = false; //p_profile->session->cacheSessions();
|
||||||
|
|
||||||
|
@ -134,6 +134,7 @@ class MainWindow : public QMainWindow
|
|||||||
|
|
||||||
//! \brief Sets up recalculation of all event summaries and flags
|
//! \brief Sets up recalculation of all event summaries and flags
|
||||||
void reprocessEvents(bool restart = false);
|
void reprocessEvents(bool restart = false);
|
||||||
|
void recompressEvents();
|
||||||
|
|
||||||
|
|
||||||
//! \brief Internal function to set Records Box html from statistics module
|
//! \brief Internal function to set Records Box html from statistics module
|
||||||
@ -149,6 +150,7 @@ class MainWindow : public QMainWindow
|
|||||||
public slots:
|
public slots:
|
||||||
//! \brief Recalculate all event summaries and flags
|
//! \brief Recalculate all event summaries and flags
|
||||||
void doReprocessEvents();
|
void doReprocessEvents();
|
||||||
|
void doRecompressEvents();
|
||||||
|
|
||||||
void MachineUnsupported(Machine * m);
|
void MachineUnsupported(Machine * m);
|
||||||
|
|
||||||
|
@ -659,6 +659,7 @@ PreferencesDialog::~PreferencesDialog()
|
|||||||
|
|
||||||
bool PreferencesDialog::Save()
|
bool PreferencesDialog::Save()
|
||||||
{
|
{
|
||||||
|
bool recompress_events = false;
|
||||||
bool recalc_events = false;
|
bool recalc_events = false;
|
||||||
bool needs_restart = false;
|
bool needs_restart = false;
|
||||||
|
|
||||||
@ -719,9 +720,18 @@ bool PreferencesDialog::Save()
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (profile->session->compressSessionData() != ui->compressSessionData->isChecked()) {
|
if (profile->session->compressSessionData() != ui->compressSessionData->isChecked()) {
|
||||||
recalc_events = true;
|
recompress_events = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (recompress_events) {
|
||||||
|
if (profile->countDays(MT_CPAP, profile->FirstDay(), profile->LastDay()) > 0) {
|
||||||
|
if (QMessageBox::question(this, tr("Data Processing Required"),
|
||||||
|
tr("A data re/decompression proceedure is required to apply these changes. This operation may take a couple of minutes to complete.\n\nAre you sure you want to make these changes?"),
|
||||||
|
QMessageBox::Yes, QMessageBox::No) == QMessageBox::No) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
} else { recompress_events = false; }
|
||||||
|
}
|
||||||
if (recalc_events) {
|
if (recalc_events) {
|
||||||
if (profile->countDays(MT_CPAP, profile->FirstDay(), profile->LastDay()) > 0) {
|
if (profile->countDays(MT_CPAP, profile->FirstDay(), profile->LastDay()) > 0) {
|
||||||
if (QMessageBox::question(this, tr("Data Reindex Required"),
|
if (QMessageBox::question(this, tr("Data Reindex Required"),
|
||||||
@ -895,7 +905,9 @@ bool PreferencesDialog::Save()
|
|||||||
PREF.Save();
|
PREF.Save();
|
||||||
profile->Save();
|
profile->Save();
|
||||||
|
|
||||||
if (recalc_events) {
|
if (recompress_events) {
|
||||||
|
mainwin->recompressEvents();
|
||||||
|
} else if (recalc_events) {
|
||||||
// send a signal instead?
|
// send a signal instead?
|
||||||
mainwin->reprocessEvents(needs_restart);
|
mainwin->reprocessEvents(needs_restart);
|
||||||
} else if (needs_restart) {
|
} else if (needs_restart) {
|
||||||
|
Loading…
Reference in New Issue
Block a user