forked from JS8Call-improved/JS8Call-improved
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathDriftingDateTime.cpp
More file actions
51 lines (40 loc) · 1.51 KB
/
DriftingDateTime.cpp
File metadata and controls
51 lines (40 loc) · 1.51 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
#include <QMutexLocker>
#include <QLoggingCategory>
#include <QThread>
#include "DriftingDateTime.h"
#include "qDateTimeExperiment.h"
Q_DECLARE_LOGGING_CATEGORY(driftingdatetime_js8)
static QPointer<QDateTimeRoundingExperiment> experiment;
DriftingDateTimeSingleton & DriftingDateTimeSingleton::getSingleton() {
if (singleton.isNull()) {
singleton = QPointer{new DriftingDateTimeSingleton{}};
if (experiment.isNull()) {
experiment = QPointer{new QDateTimeRoundingExperiment};
}
}
return *(singleton.data());
}
DriftingDateTimeSingleton::DriftingDateTimeSingleton(): driftMS(0) {}
qint64 DriftingDateTimeSingleton::drift() const {
QMutexLocker locker(&mutex);
return driftMS;
}
void DriftingDateTimeSingleton::setDriftInner(qint64 ms) {
QMutexLocker locker(&mutex);
driftMS = ms;
}
void DriftingDateTimeSingleton::setDrift(qint64 ms) {
qint64 old_drift = drift();
setDriftInner(ms);
if(ms != old_drift) {
qCDebug(driftingdatetime_js8) << "Changed drift from" << old_drift << "to" << ms << "ms";
emit driftChanged(ms);
} else {
qCDebug(driftingdatetime_js8) << "Incoming signal without change of drift, still" << old_drift << "ms";
}
}
void DriftingDateTimeSingleton::onPlumbingCompleted() const {
emit driftChanged(drift());
}
QPointer<DriftingDateTimeSingleton> DriftingDateTimeSingleton::singleton = QPointer<DriftingDateTimeSingleton>{};
Q_LOGGING_CATEGORY(driftingdatetime_js8, "driftingdatetime.js8", QtWarningMsg)