From e2b957e50e484d9633cb0e37e18d2ac1c5a57fe9 Mon Sep 17 00:00:00 2001 From: dankito Date: Tue, 28 Apr 2020 18:16:16 +0200 Subject: [PATCH] Hopefully now really fixed app crashes when restoring Android app due to previous DocumentsWriter / IndexWriter instance is still not destroyed and still holds write lock --- .../persistence/LuceneBankingPersistence.kt | 31 +++++++------------ 1 file changed, 12 insertions(+), 19 deletions(-) diff --git a/persistence/LuceneBankingPersistence/src/main/kotlin/net/dankito/banking/persistence/LuceneBankingPersistence.kt b/persistence/LuceneBankingPersistence/src/main/kotlin/net/dankito/banking/persistence/LuceneBankingPersistence.kt index e513f312..f88f2b7c 100644 --- a/persistence/LuceneBankingPersistence/src/main/kotlin/net/dankito/banking/persistence/LuceneBankingPersistence.kt +++ b/persistence/LuceneBankingPersistence/src/main/kotlin/net/dankito/banking/persistence/LuceneBankingPersistence.kt @@ -20,7 +20,6 @@ import net.dankito.utils.serialization.ISerializer import net.dankito.utils.serialization.JacksonJsonSerializer import org.apache.lucene.index.IndexableField import java.io.File -import java.util.concurrent.atomic.AtomicInteger open class LuceneBankingPersistence( @@ -29,13 +28,18 @@ open class LuceneBankingPersistence( serializer: ISerializer = JacksonJsonSerializer() ) : BankingPersistenceJson(File(databaseFolder, "accounts.json"), serializer), IBankingPersistence { + companion object { + + // i really hate this solution, but could find no other way to avoid app crashes when + // Android app gets restored as previous IndexWriter is not not destroyed yet and holds + // write lock and a new IndexWriter instance in DocumentsWriter gets instantiated + protected var documentsWriter: DocumentsWriter? = null + + } + protected val fields = FieldBuilder() - protected var documentsWriter: DocumentsWriter? = null - - protected val countWriterUsages = AtomicInteger(0) - override fun saveOrUpdateAccountTransactions(bankAccount: BankAccount, transactions: List) { val writer = getWriter() @@ -48,8 +52,6 @@ open class LuceneBankingPersistence( } writer.flushChangesToDisk() - - releaseWriter() } protected open fun createFieldsForAccountTransaction(bankAccount: BankAccount, transaction: AccountTransaction): List { @@ -73,22 +75,13 @@ open class LuceneBankingPersistence( @Synchronized protected open fun getWriter(): DocumentsWriter { - countWriterUsages.incrementAndGet() - documentsWriter?.let { return it } - documentsWriter = DocumentsWriter(LuceneConfig.getAccountTransactionsIndexFolder(indexFolder)) + val writer = DocumentsWriter(LuceneConfig.getAccountTransactionsIndexFolder(indexFolder)) - return documentsWriter!! - } + documentsWriter = writer - @Synchronized - protected open fun releaseWriter() { - val countUsages = countWriterUsages.decrementAndGet() - - if (countUsages == 0) { - documentsWriter?.close() - } + return writer } } \ No newline at end of file