make processChangedGlucoseValuesCompat tailrec

This commit is contained in:
Andrei Vereha 2021-10-16 21:14:01 +02:00
parent 6ed9024769
commit b330e7af00
2 changed files with 9 additions and 8 deletions

View file

@ -419,7 +419,7 @@ class DataSyncSelectorImplementation @Inject constructor(
//private var lastGvId = -1L //private var lastGvId = -1L
//private var lastGvTime = -1L //private var lastGvTime = -1L
override fun processChangedGlucoseValuesCompat(): Boolean { override tailrec fun processChangedGlucoseValuesCompat() {
val lastDbIdWrapped = appRepository.getLastGlucoseValueIdWrapped().blockingGet() val lastDbIdWrapped = appRepository.getLastGlucoseValueIdWrapped().blockingGet()
val lastDbId = if (lastDbIdWrapped is ValueWrapper.Existing) lastDbIdWrapped.value else 0L val lastDbId = if (lastDbIdWrapped is ValueWrapper.Existing) lastDbIdWrapped.value else 0L
var startId = sp.getLong(R.string.key_ns_glucose_value_last_synced_id, 0) var startId = sp.getLong(R.string.key_ns_glucose_value_last_synced_id, 0)
@ -431,6 +431,7 @@ class DataSyncSelectorImplementation @Inject constructor(
//lastGvId = startId //lastGvId = startId
//lastGvTime = dateUtil.now() //lastGvTime = dateUtil.now()
queueCounter.gvsRemaining = lastDbId - startId queueCounter.gvsRemaining = lastDbId - startId
var tailCall = false
appRepository.getNextSyncElementGlucoseValue(startId).blockingGet()?.let { gv -> appRepository.getNextSyncElementGlucoseValue(startId).blockingGet()?.let { gv ->
aapsLogger.info(LTag.DATABASE, "Loading GlucoseValue data ID: ${gv.first.id} HistoryID: ${gv.second.id} ") aapsLogger.info(LTag.DATABASE, "Loading GlucoseValue data ID: ${gv.first.id} HistoryID: ${gv.second.id} ")
if (activePlugin.activeBgSource.shouldUploadToNs(gv.first)) { if (activePlugin.activeBgSource.shouldUploadToNs(gv.first)) {
@ -439,15 +440,14 @@ class DataSyncSelectorImplementation @Inject constructor(
gv.first.onlyNsIdAdded(gv.second) -> { gv.first.onlyNsIdAdded(gv.second) -> {
confirmLastGlucoseValueIdIfGreater(gv.second.id) confirmLastGlucoseValueIdIfGreater(gv.second.id)
//lastGvId = -1 //lastGvId = -1
processChangedGlucoseValuesCompat()
aapsLogger.info(LTag.DATABASE, "Ignoring GlucoseValue. Only NS id changed ID: ${gv.first.id} HistoryID: ${gv.second.id} ") aapsLogger.info(LTag.DATABASE, "Ignoring GlucoseValue. Only NS id changed ID: ${gv.first.id} HistoryID: ${gv.second.id} ")
return false tailCall = true
} }
// without nsId = create new // without nsId = create new
gv.first.interfaceIDs.nightscoutId == null -> gv.first.interfaceIDs.nightscoutId == null ->
nsClientPlugin.nsClientService?.dbAdd("entries", gv.first.toJson(true, dateUtil), DataSyncSelector.PairGlucoseValue(gv.first, gv.second.id), "$startId/$lastDbId") nsClientPlugin.nsClientService?.dbAdd("entries", gv.first.toJson(true, dateUtil), DataSyncSelector.PairGlucoseValue(gv.first, gv.second.id), "$startId/$lastDbId")
// with nsId = update // with nsId = update
gv.first.interfaceIDs.nightscoutId != null -> else -> // gv.first.interfaceIDs.nightscoutId != null
nsClientPlugin.nsClientService?.dbUpdate( nsClientPlugin.nsClientService?.dbUpdate(
"entries", "entries",
gv.first.interfaceIDs.nightscoutId, gv.first.interfaceIDs.nightscoutId,
@ -456,14 +456,15 @@ class DataSyncSelectorImplementation @Inject constructor(
"$startId/$lastDbId" "$startId/$lastDbId"
) )
} }
return true
} else { } else {
confirmLastGlucoseValueIdIfGreater(gv.second.id) confirmLastGlucoseValueIdIfGreater(gv.second.id)
//lastGvId = -1 //lastGvId = -1
processChangedGlucoseValuesCompat() tailCall = true
} }
} }
return false if (tailCall) {
processChangedGlucoseValuesCompat()
}
} }
override fun confirmLastTherapyEventIdIfGreater(lastSynced: Long) { override fun confirmLastTherapyEventIdIfGreater(lastSynced: Long) {

View file

@ -49,7 +49,7 @@ interface DataSyncSelector {
fun confirmLastGlucoseValueIdIfGreater(lastSynced: Long) fun confirmLastGlucoseValueIdIfGreater(lastSynced: Long)
fun changedGlucoseValues() : List<GlucoseValue> fun changedGlucoseValues() : List<GlucoseValue>
// Until NS v3 // Until NS v3
fun processChangedGlucoseValuesCompat(): Boolean fun processChangedGlucoseValuesCompat()
fun confirmLastTherapyEventIdIfGreater(lastSynced: Long) fun confirmLastTherapyEventIdIfGreater(lastSynced: Long)
fun changedTherapyEvents() : List<TherapyEvent> fun changedTherapyEvents() : List<TherapyEvent>