1
0
mirror of https://github.com/etesync/android synced 2025-01-25 15:10:55 +00:00

Add a reentrant lock to our entity data store.

Should fix issues with multiple threads trying to write to the store
at the same time.
This commit is contained in:
Tom Hacohen 2019-10-16 11:26:37 +03:00
parent a74f188b3b
commit 9ed172e23c

View File

@ -1,9 +1,60 @@
package com.etesync.syncadapter.model
import io.requery.Persistable
import io.requery.meta.Attribute
import io.requery.sql.Configuration
import io.requery.sql.EntityDataStore
import java.util.concurrent.locks.ReentrantLock
import kotlin.concurrent.withLock
class MyEntityDataStore(configuration: Configuration): EntityDataStore<Persistable>(configuration) {
val lock = ReentrantLock()
override fun <K : Any?, E : Persistable?> insert(entity: E, keyClass: Class<K>?): K {
lock.withLock {
return super.insert(entity, keyClass)
}
}
override fun <E : Persistable?> update(entity: E): E {
lock.withLock {
return super.update(entity)
}
}
override fun <E : Persistable?> update(entity: E, vararg attributes: Attribute<*, *>?): E {
lock.withLock {
return super.update(entity, *attributes)
}
}
override fun <E : Persistable?> upsert(entity: E): E {
lock.withLock {
return super.upsert(entity)
}
}
override fun <E : Persistable?> refresh(entity: E): E {
lock.withLock {
return super.refresh(entity)
}
}
override fun <E : Persistable?> refresh(entity: E, vararg attributes: Attribute<*, *>?): E {
lock.withLock {
return super.refresh(entity, *attributes)
}
}
override fun <E : Persistable?> refreshAll(entity: E): E {
lock.withLock {
return super.refreshAll(entity)
}
}
override fun <E : Persistable?> delete(entity: E): Void {
lock.withLock {
return super.delete(entity)
}
}
}