From 95eede542291f50fb3334b95be548d01c0aff2bf Mon Sep 17 00:00:00 2001 From: JaniruTEC <52893617+JaniruTEC@users.noreply.github.com> Date: Sun, 17 Mar 2024 19:04:15 +0100 Subject: [PATCH] Redefined logic of "MappingSupportSQLiteQuery" *This commit is related to issue #529 [1]* [1] https://github.com/cryptomator/android/issues/529 --- .../db/sqlmapping/MappingSupportSQLiteDatabase.kt | 14 +++++++++++--- 1 file changed, 11 insertions(+), 3 deletions(-) diff --git a/data/src/main/java/org/cryptomator/data/db/sqlmapping/MappingSupportSQLiteDatabase.kt b/data/src/main/java/org/cryptomator/data/db/sqlmapping/MappingSupportSQLiteDatabase.kt index 88b8b1401..8f1dedc8e 100644 --- a/data/src/main/java/org/cryptomator/data/db/sqlmapping/MappingSupportSQLiteDatabase.kt +++ b/data/src/main/java/org/cryptomator/data/db/sqlmapping/MappingSupportSQLiteDatabase.kt @@ -8,7 +8,7 @@ import androidx.sqlite.db.SupportSQLiteDatabase import androidx.sqlite.db.SupportSQLiteOpenHelper import androidx.sqlite.db.SupportSQLiteQuery import androidx.sqlite.db.SupportSQLiteStatement -import java.util.Collections +import timber.log.Timber internal class MappingSupportSQLiteDatabase( private val delegate: SupportSQLiteDatabase, @@ -153,10 +153,18 @@ internal class MappingSupportSQLiteDatabase( private val delegateQuery: SupportSQLiteQuery ) : SupportSQLiteQuery by delegateQuery { - private val mappedQueries: MutableMap = Collections.synchronizedMap(mutableMapOf()) + private val lock = Any() + private var called = false + private val _sql = map(delegateQuery.sql) override val sql: String - get() = mappedQueries.computeIfAbsent(delegateQuery.sql) { map(it) } + get() = synchronized(lock) { + if (called) { + Timber.tag("MappingSupportSQLiteQuery").e("SQL queried twice") + } + called = true + return _sql + } } }