mirror of
https://github.com/tachiyomiorg/tachiyomi.git
synced 2025-01-09 00:40:44 +01:00
Manual mappings. Code generation on java classes (better compilation times)
This commit is contained in:
parent
7ba898f701
commit
7039216eae
@ -84,10 +84,6 @@ android {
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
kapt {
|
|
||||||
generateStubs = true
|
|
||||||
}
|
|
||||||
|
|
||||||
dependencies {
|
dependencies {
|
||||||
final SUPPORT_LIBRARY_VERSION = '23.4.0'
|
final SUPPORT_LIBRARY_VERSION = '23.4.0'
|
||||||
final DAGGER_VERSION = '2.4'
|
final DAGGER_VERSION = '2.4'
|
||||||
@ -148,7 +144,6 @@ dependencies {
|
|||||||
// Database
|
// Database
|
||||||
compile "com.pushtorefresh.storio:sqlite:$STORIO_VERSION"
|
compile "com.pushtorefresh.storio:sqlite:$STORIO_VERSION"
|
||||||
compile "com.pushtorefresh.storio:sqlite-annotations:$STORIO_VERSION"
|
compile "com.pushtorefresh.storio:sqlite-annotations:$STORIO_VERSION"
|
||||||
kapt "com.pushtorefresh.storio:sqlite-annotations-processor:$STORIO_VERSION"
|
|
||||||
|
|
||||||
// Model View Presenter
|
// Model View Presenter
|
||||||
compile "info.android15.nucleus:nucleus:$NUCLEUS_VERSION"
|
compile "info.android15.nucleus:nucleus:$NUCLEUS_VERSION"
|
||||||
|
@ -3,10 +3,9 @@ package eu.kanade.tachiyomi
|
|||||||
import android.app.Application
|
import android.app.Application
|
||||||
import android.content.Context
|
import android.content.Context
|
||||||
import eu.kanade.tachiyomi.data.preference.PreferencesHelper
|
import eu.kanade.tachiyomi.data.preference.PreferencesHelper
|
||||||
|
import eu.kanade.tachiyomi.injection.AppComponentFactory
|
||||||
import eu.kanade.tachiyomi.injection.ComponentReflectionInjector
|
import eu.kanade.tachiyomi.injection.ComponentReflectionInjector
|
||||||
import eu.kanade.tachiyomi.injection.component.AppComponent
|
import eu.kanade.tachiyomi.injection.component.AppComponent
|
||||||
import eu.kanade.tachiyomi.injection.component.DaggerAppComponent
|
|
||||||
import eu.kanade.tachiyomi.injection.module.AppModule
|
|
||||||
import org.acra.ACRA
|
import org.acra.ACRA
|
||||||
import org.acra.annotation.ReportsCrashes
|
import org.acra.annotation.ReportsCrashes
|
||||||
import timber.log.Timber
|
import timber.log.Timber
|
||||||
@ -32,7 +31,7 @@ open class App : Application() {
|
|||||||
super.onCreate()
|
super.onCreate()
|
||||||
if (BuildConfig.DEBUG) Timber.plant(Timber.DebugTree())
|
if (BuildConfig.DEBUG) Timber.plant(Timber.DebugTree())
|
||||||
|
|
||||||
component = prepareAppComponent().build()
|
component = createAppComponent()
|
||||||
|
|
||||||
componentReflection = ComponentReflectionInjector(AppComponent::class.java, component)
|
componentReflection = ComponentReflectionInjector(AppComponent::class.java, component)
|
||||||
|
|
||||||
@ -44,9 +43,8 @@ open class App : Application() {
|
|||||||
appTheme = PreferencesHelper.getTheme(this)
|
appTheme = PreferencesHelper.getTheme(this)
|
||||||
}
|
}
|
||||||
|
|
||||||
protected open fun prepareAppComponent(): DaggerAppComponent.Builder {
|
protected open fun createAppComponent(): AppComponent {
|
||||||
return DaggerAppComponent.builder()
|
return AppComponentFactory.create(this)
|
||||||
.appModule(AppModule(this))
|
|
||||||
}
|
}
|
||||||
|
|
||||||
protected open fun setupAcra() {
|
protected open fun setupAcra() {
|
||||||
|
@ -2,6 +2,7 @@ package eu.kanade.tachiyomi.data.database
|
|||||||
|
|
||||||
import android.content.Context
|
import android.content.Context
|
||||||
import com.pushtorefresh.storio.sqlite.impl.DefaultStorIOSQLite
|
import com.pushtorefresh.storio.sqlite.impl.DefaultStorIOSQLite
|
||||||
|
import eu.kanade.tachiyomi.data.database.mappers.*
|
||||||
import eu.kanade.tachiyomi.data.database.models.*
|
import eu.kanade.tachiyomi.data.database.models.*
|
||||||
import eu.kanade.tachiyomi.data.database.queries.*
|
import eu.kanade.tachiyomi.data.database.queries.*
|
||||||
|
|
||||||
@ -13,12 +14,12 @@ open class DatabaseHelper(context: Context)
|
|||||||
|
|
||||||
override val db = DefaultStorIOSQLite.builder()
|
override val db = DefaultStorIOSQLite.builder()
|
||||||
.sqliteOpenHelper(DbOpenHelper(context))
|
.sqliteOpenHelper(DbOpenHelper(context))
|
||||||
.addTypeMapping(Manga::class.java, MangaSQLiteTypeMapping())
|
.addTypeMapping(Manga::class.java, MangaTypeMapping())
|
||||||
.addTypeMapping(Chapter::class.java, ChapterSQLiteTypeMapping())
|
.addTypeMapping(Chapter::class.java, ChapterTypeMapping())
|
||||||
.addTypeMapping(MangaSync::class.java, MangaSyncSQLiteTypeMapping())
|
.addTypeMapping(MangaSync::class.java, MangaSyncTypeMapping())
|
||||||
.addTypeMapping(Category::class.java, CategorySQLiteTypeMapping())
|
.addTypeMapping(Category::class.java, CategoryTypeMapping())
|
||||||
.addTypeMapping(MangaCategory::class.java, MangaCategorySQLiteTypeMapping())
|
.addTypeMapping(MangaCategory::class.java, MangaCategoryTypeMapping())
|
||||||
.addTypeMapping(History::class.java, HistorySQLiteTypeMapping())
|
.addTypeMapping(History::class.java, HistoryTypeMapping())
|
||||||
.build()
|
.build()
|
||||||
|
|
||||||
inline fun inTransaction(block: () -> Unit) = db.inTransaction(block)
|
inline fun inTransaction(block: () -> Unit) = db.inTransaction(block)
|
||||||
|
@ -0,0 +1,62 @@
|
|||||||
|
package eu.kanade.tachiyomi.data.database.mappers
|
||||||
|
|
||||||
|
import android.content.ContentValues
|
||||||
|
import android.database.Cursor
|
||||||
|
import com.pushtorefresh.storio.sqlite.SQLiteTypeMapping
|
||||||
|
import com.pushtorefresh.storio.sqlite.operations.delete.DefaultDeleteResolver
|
||||||
|
import com.pushtorefresh.storio.sqlite.operations.get.DefaultGetResolver
|
||||||
|
import com.pushtorefresh.storio.sqlite.operations.put.DefaultPutResolver
|
||||||
|
import com.pushtorefresh.storio.sqlite.queries.DeleteQuery
|
||||||
|
import com.pushtorefresh.storio.sqlite.queries.InsertQuery
|
||||||
|
import com.pushtorefresh.storio.sqlite.queries.UpdateQuery
|
||||||
|
import eu.kanade.tachiyomi.data.database.models.Category
|
||||||
|
import eu.kanade.tachiyomi.data.database.tables.CategoryTable.COL_FLAGS
|
||||||
|
import eu.kanade.tachiyomi.data.database.tables.CategoryTable.COL_ID
|
||||||
|
import eu.kanade.tachiyomi.data.database.tables.CategoryTable.COL_NAME
|
||||||
|
import eu.kanade.tachiyomi.data.database.tables.CategoryTable.COL_ORDER
|
||||||
|
import eu.kanade.tachiyomi.data.database.tables.CategoryTable.TABLE
|
||||||
|
|
||||||
|
class CategoryTypeMapping : SQLiteTypeMapping<Category>(
|
||||||
|
CategoryPutResolver(),
|
||||||
|
CategoryGetResolver(),
|
||||||
|
CategoryDeleteResolver()
|
||||||
|
)
|
||||||
|
|
||||||
|
class CategoryPutResolver : DefaultPutResolver<Category>() {
|
||||||
|
|
||||||
|
override fun mapToInsertQuery(obj: Category) = InsertQuery.builder()
|
||||||
|
.table(TABLE)
|
||||||
|
.build()
|
||||||
|
|
||||||
|
override fun mapToUpdateQuery(obj: Category) = UpdateQuery.builder()
|
||||||
|
.table(TABLE)
|
||||||
|
.where("$COL_ID = ?")
|
||||||
|
.whereArgs(obj.id)
|
||||||
|
.build()
|
||||||
|
|
||||||
|
override fun mapToContentValues(obj: Category) = ContentValues(4).apply {
|
||||||
|
put(COL_ID, obj.id)
|
||||||
|
put(COL_NAME, obj.name)
|
||||||
|
put(COL_ORDER, obj.order)
|
||||||
|
put(COL_FLAGS, obj.flags)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class CategoryGetResolver : DefaultGetResolver<Category>() {
|
||||||
|
|
||||||
|
override fun mapFromCursor(cursor: Cursor) = Category().apply {
|
||||||
|
id = cursor.getInt(cursor.getColumnIndex(COL_ID))
|
||||||
|
name = cursor.getString(cursor.getColumnIndex(COL_NAME))
|
||||||
|
order = cursor.getInt(cursor.getColumnIndex(COL_ORDER))
|
||||||
|
flags = cursor.getInt(cursor.getColumnIndex(COL_FLAGS))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class CategoryDeleteResolver : DefaultDeleteResolver<Category>() {
|
||||||
|
|
||||||
|
override fun mapToDeleteQuery(obj: Category) = DeleteQuery.builder()
|
||||||
|
.table(TABLE)
|
||||||
|
.where("$COL_ID = ?")
|
||||||
|
.whereArgs(obj.id)
|
||||||
|
.build()
|
||||||
|
}
|
@ -0,0 +1,81 @@
|
|||||||
|
package eu.kanade.tachiyomi.data.database.mappers
|
||||||
|
|
||||||
|
import android.content.ContentValues
|
||||||
|
import android.database.Cursor
|
||||||
|
import com.pushtorefresh.storio.sqlite.SQLiteTypeMapping
|
||||||
|
import com.pushtorefresh.storio.sqlite.operations.delete.DefaultDeleteResolver
|
||||||
|
import com.pushtorefresh.storio.sqlite.operations.get.DefaultGetResolver
|
||||||
|
import com.pushtorefresh.storio.sqlite.operations.put.DefaultPutResolver
|
||||||
|
import com.pushtorefresh.storio.sqlite.queries.DeleteQuery
|
||||||
|
import com.pushtorefresh.storio.sqlite.queries.InsertQuery
|
||||||
|
import com.pushtorefresh.storio.sqlite.queries.UpdateQuery
|
||||||
|
import eu.kanade.tachiyomi.data.database.models.Chapter
|
||||||
|
import eu.kanade.tachiyomi.data.database.tables.ChapterTable.COL_CHAPTER_NUMBER
|
||||||
|
import eu.kanade.tachiyomi.data.database.tables.ChapterTable.COL_DATE_FETCH
|
||||||
|
import eu.kanade.tachiyomi.data.database.tables.ChapterTable.COL_DATE_UPLOAD
|
||||||
|
import eu.kanade.tachiyomi.data.database.tables.ChapterTable.COL_ID
|
||||||
|
import eu.kanade.tachiyomi.data.database.tables.ChapterTable.COL_LAST_PAGE_READ
|
||||||
|
import eu.kanade.tachiyomi.data.database.tables.ChapterTable.COL_MANGA_ID
|
||||||
|
import eu.kanade.tachiyomi.data.database.tables.ChapterTable.COL_NAME
|
||||||
|
import eu.kanade.tachiyomi.data.database.tables.ChapterTable.COL_READ
|
||||||
|
import eu.kanade.tachiyomi.data.database.tables.ChapterTable.COL_SOURCE_ORDER
|
||||||
|
import eu.kanade.tachiyomi.data.database.tables.ChapterTable.COL_URL
|
||||||
|
import eu.kanade.tachiyomi.data.database.tables.ChapterTable.TABLE
|
||||||
|
|
||||||
|
class ChapterTypeMapping : SQLiteTypeMapping<Chapter>(
|
||||||
|
ChapterPutResolver(),
|
||||||
|
ChapterGetResolver(),
|
||||||
|
ChapterDeleteResolver()
|
||||||
|
)
|
||||||
|
|
||||||
|
class ChapterPutResolver : DefaultPutResolver<Chapter>() {
|
||||||
|
|
||||||
|
override fun mapToInsertQuery(obj: Chapter) = InsertQuery.builder()
|
||||||
|
.table(TABLE)
|
||||||
|
.build()
|
||||||
|
|
||||||
|
override fun mapToUpdateQuery(obj: Chapter) = UpdateQuery.builder()
|
||||||
|
.table(TABLE)
|
||||||
|
.where("$COL_ID = ?")
|
||||||
|
.whereArgs(obj.id)
|
||||||
|
.build()
|
||||||
|
|
||||||
|
override fun mapToContentValues(obj: Chapter) = ContentValues(10).apply {
|
||||||
|
put(COL_ID, obj.id)
|
||||||
|
put(COL_MANGA_ID, obj.manga_id)
|
||||||
|
put(COL_URL, obj.url)
|
||||||
|
put(COL_NAME, obj.name)
|
||||||
|
put(COL_READ, obj.read)
|
||||||
|
put(COL_DATE_FETCH, obj.date_fetch)
|
||||||
|
put(COL_DATE_UPLOAD, obj.date_upload)
|
||||||
|
put(COL_LAST_PAGE_READ, obj.last_page_read)
|
||||||
|
put(COL_CHAPTER_NUMBER, obj.chapter_number)
|
||||||
|
put(COL_SOURCE_ORDER, obj.source_order)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class ChapterGetResolver : DefaultGetResolver<Chapter>() {
|
||||||
|
|
||||||
|
override fun mapFromCursor(cursor: Cursor) = Chapter().apply {
|
||||||
|
id = cursor.getLong(cursor.getColumnIndex(COL_ID))
|
||||||
|
manga_id = cursor.getLong(cursor.getColumnIndex(COL_MANGA_ID))
|
||||||
|
url = cursor.getString(cursor.getColumnIndex(COL_URL))
|
||||||
|
name = cursor.getString(cursor.getColumnIndex(COL_NAME))
|
||||||
|
read = cursor.getInt(cursor.getColumnIndex(COL_READ)) == 1
|
||||||
|
date_fetch = cursor.getLong(cursor.getColumnIndex(COL_DATE_FETCH))
|
||||||
|
date_upload = cursor.getLong(cursor.getColumnIndex(COL_DATE_UPLOAD))
|
||||||
|
last_page_read = cursor.getInt(cursor.getColumnIndex(COL_LAST_PAGE_READ))
|
||||||
|
chapter_number = cursor.getFloat(cursor.getColumnIndex(COL_CHAPTER_NUMBER))
|
||||||
|
source_order = cursor.getInt(cursor.getColumnIndex(COL_SOURCE_ORDER))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class ChapterDeleteResolver : DefaultDeleteResolver<Chapter>() {
|
||||||
|
|
||||||
|
override fun mapToDeleteQuery(obj: Chapter) = DeleteQuery.builder()
|
||||||
|
.table(TABLE)
|
||||||
|
.where("$COL_ID = ?")
|
||||||
|
.whereArgs(obj.id)
|
||||||
|
.build()
|
||||||
|
}
|
||||||
|
|
@ -0,0 +1,62 @@
|
|||||||
|
package eu.kanade.tachiyomi.data.database.mappers
|
||||||
|
|
||||||
|
import android.content.ContentValues
|
||||||
|
import android.database.Cursor
|
||||||
|
import com.pushtorefresh.storio.sqlite.SQLiteTypeMapping
|
||||||
|
import com.pushtorefresh.storio.sqlite.operations.delete.DefaultDeleteResolver
|
||||||
|
import com.pushtorefresh.storio.sqlite.operations.get.DefaultGetResolver
|
||||||
|
import com.pushtorefresh.storio.sqlite.operations.put.DefaultPutResolver
|
||||||
|
import com.pushtorefresh.storio.sqlite.queries.DeleteQuery
|
||||||
|
import com.pushtorefresh.storio.sqlite.queries.InsertQuery
|
||||||
|
import com.pushtorefresh.storio.sqlite.queries.UpdateQuery
|
||||||
|
import eu.kanade.tachiyomi.data.database.models.History
|
||||||
|
import eu.kanade.tachiyomi.data.database.tables.HistoryTable.COL_CHAPTER_ID
|
||||||
|
import eu.kanade.tachiyomi.data.database.tables.HistoryTable.COL_ID
|
||||||
|
import eu.kanade.tachiyomi.data.database.tables.HistoryTable.COL_LAST_READ
|
||||||
|
import eu.kanade.tachiyomi.data.database.tables.HistoryTable.COL_TIME_READ
|
||||||
|
import eu.kanade.tachiyomi.data.database.tables.HistoryTable.TABLE
|
||||||
|
|
||||||
|
class HistoryTypeMapping : SQLiteTypeMapping<History>(
|
||||||
|
HistoryPutResolver(),
|
||||||
|
HistoryGetResolver(),
|
||||||
|
HistoryDeleteResolver()
|
||||||
|
)
|
||||||
|
|
||||||
|
class HistoryPutResolver : DefaultPutResolver<History>() {
|
||||||
|
|
||||||
|
override fun mapToInsertQuery(obj: History) = InsertQuery.builder()
|
||||||
|
.table(TABLE)
|
||||||
|
.build()
|
||||||
|
|
||||||
|
override fun mapToUpdateQuery(obj: History) = UpdateQuery.builder()
|
||||||
|
.table(TABLE)
|
||||||
|
.where("$COL_ID = ?")
|
||||||
|
.whereArgs(obj.id)
|
||||||
|
.build()
|
||||||
|
|
||||||
|
override fun mapToContentValues(obj: History) = ContentValues(4).apply {
|
||||||
|
put(COL_ID, obj.id)
|
||||||
|
put(COL_CHAPTER_ID, obj.chapter_id)
|
||||||
|
put(COL_LAST_READ, obj.last_read)
|
||||||
|
put(COL_TIME_READ, obj.time_read)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class HistoryGetResolver : DefaultGetResolver<History>() {
|
||||||
|
|
||||||
|
override fun mapFromCursor(cursor: Cursor) = History().apply {
|
||||||
|
id = cursor.getLong(cursor.getColumnIndex(COL_ID))
|
||||||
|
chapter_id = cursor.getLong(cursor.getColumnIndex(COL_CHAPTER_ID))
|
||||||
|
last_read = cursor.getLong(cursor.getColumnIndex(COL_LAST_READ))
|
||||||
|
time_read = cursor.getLong(cursor.getColumnIndex(COL_TIME_READ))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class HistoryDeleteResolver : DefaultDeleteResolver<History>() {
|
||||||
|
|
||||||
|
override fun mapToDeleteQuery(obj: History) = DeleteQuery.builder()
|
||||||
|
.table(TABLE)
|
||||||
|
.where("$COL_ID = ?")
|
||||||
|
.whereArgs(obj.id)
|
||||||
|
.build()
|
||||||
|
}
|
@ -0,0 +1,59 @@
|
|||||||
|
package eu.kanade.tachiyomi.data.database.mappers
|
||||||
|
|
||||||
|
import android.content.ContentValues
|
||||||
|
import android.database.Cursor
|
||||||
|
import com.pushtorefresh.storio.sqlite.SQLiteTypeMapping
|
||||||
|
import com.pushtorefresh.storio.sqlite.operations.delete.DefaultDeleteResolver
|
||||||
|
import com.pushtorefresh.storio.sqlite.operations.get.DefaultGetResolver
|
||||||
|
import com.pushtorefresh.storio.sqlite.operations.put.DefaultPutResolver
|
||||||
|
import com.pushtorefresh.storio.sqlite.queries.DeleteQuery
|
||||||
|
import com.pushtorefresh.storio.sqlite.queries.InsertQuery
|
||||||
|
import com.pushtorefresh.storio.sqlite.queries.UpdateQuery
|
||||||
|
import eu.kanade.tachiyomi.data.database.models.MangaCategory
|
||||||
|
import eu.kanade.tachiyomi.data.database.tables.MangaCategoryTable.COL_CATEGORY_ID
|
||||||
|
import eu.kanade.tachiyomi.data.database.tables.MangaCategoryTable.COL_ID
|
||||||
|
import eu.kanade.tachiyomi.data.database.tables.MangaCategoryTable.COL_MANGA_ID
|
||||||
|
import eu.kanade.tachiyomi.data.database.tables.MangaCategoryTable.TABLE
|
||||||
|
|
||||||
|
class MangaCategoryTypeMapping : SQLiteTypeMapping<MangaCategory>(
|
||||||
|
MangaCategoryPutResolver(),
|
||||||
|
MangaCategoryGetResolver(),
|
||||||
|
MangaCategoryDeleteResolver()
|
||||||
|
)
|
||||||
|
|
||||||
|
class MangaCategoryPutResolver : DefaultPutResolver<MangaCategory>() {
|
||||||
|
|
||||||
|
override fun mapToInsertQuery(obj: MangaCategory) = InsertQuery.builder()
|
||||||
|
.table(TABLE)
|
||||||
|
.build()
|
||||||
|
|
||||||
|
override fun mapToUpdateQuery(obj: MangaCategory) = UpdateQuery.builder()
|
||||||
|
.table(TABLE)
|
||||||
|
.where("$COL_ID = ?")
|
||||||
|
.whereArgs(obj.id)
|
||||||
|
.build()
|
||||||
|
|
||||||
|
override fun mapToContentValues(obj: MangaCategory) = ContentValues(3).apply {
|
||||||
|
put(COL_ID, obj.id)
|
||||||
|
put(COL_MANGA_ID, obj.manga_id)
|
||||||
|
put(COL_CATEGORY_ID, obj.category_id)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class MangaCategoryGetResolver : DefaultGetResolver<MangaCategory>() {
|
||||||
|
|
||||||
|
override fun mapFromCursor(cursor: Cursor) = MangaCategory().apply {
|
||||||
|
id = cursor.getLong(cursor.getColumnIndex(COL_ID))
|
||||||
|
manga_id = cursor.getLong(cursor.getColumnIndex(COL_MANGA_ID))
|
||||||
|
category_id = cursor.getInt(cursor.getColumnIndex(COL_CATEGORY_ID))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class MangaCategoryDeleteResolver : DefaultDeleteResolver<MangaCategory>() {
|
||||||
|
|
||||||
|
override fun mapToDeleteQuery(obj: MangaCategory) = DeleteQuery.builder()
|
||||||
|
.table(TABLE)
|
||||||
|
.where("$COL_ID = ?")
|
||||||
|
.whereArgs(obj.id)
|
||||||
|
.build()
|
||||||
|
}
|
@ -0,0 +1,77 @@
|
|||||||
|
package eu.kanade.tachiyomi.data.database.mappers
|
||||||
|
|
||||||
|
import android.content.ContentValues
|
||||||
|
import android.database.Cursor
|
||||||
|
import com.pushtorefresh.storio.sqlite.SQLiteTypeMapping
|
||||||
|
import com.pushtorefresh.storio.sqlite.operations.delete.DefaultDeleteResolver
|
||||||
|
import com.pushtorefresh.storio.sqlite.operations.get.DefaultGetResolver
|
||||||
|
import com.pushtorefresh.storio.sqlite.operations.put.DefaultPutResolver
|
||||||
|
import com.pushtorefresh.storio.sqlite.queries.DeleteQuery
|
||||||
|
import com.pushtorefresh.storio.sqlite.queries.InsertQuery
|
||||||
|
import com.pushtorefresh.storio.sqlite.queries.UpdateQuery
|
||||||
|
import eu.kanade.tachiyomi.data.database.models.MangaSync
|
||||||
|
import eu.kanade.tachiyomi.data.database.tables.MangaSyncTable.COL_ID
|
||||||
|
import eu.kanade.tachiyomi.data.database.tables.MangaSyncTable.COL_LAST_CHAPTER_READ
|
||||||
|
import eu.kanade.tachiyomi.data.database.tables.MangaSyncTable.COL_MANGA_ID
|
||||||
|
import eu.kanade.tachiyomi.data.database.tables.MangaSyncTable.COL_REMOTE_ID
|
||||||
|
import eu.kanade.tachiyomi.data.database.tables.MangaSyncTable.COL_SCORE
|
||||||
|
import eu.kanade.tachiyomi.data.database.tables.MangaSyncTable.COL_STATUS
|
||||||
|
import eu.kanade.tachiyomi.data.database.tables.MangaSyncTable.COL_SYNC_ID
|
||||||
|
import eu.kanade.tachiyomi.data.database.tables.MangaSyncTable.COL_TITLE
|
||||||
|
import eu.kanade.tachiyomi.data.database.tables.MangaSyncTable.COL_TOTAL_CHAPTERS
|
||||||
|
import eu.kanade.tachiyomi.data.database.tables.MangaSyncTable.TABLE
|
||||||
|
|
||||||
|
class MangaSyncTypeMapping : SQLiteTypeMapping<MangaSync>(
|
||||||
|
MangaSyncPutResolver(),
|
||||||
|
MangaSyncGetResolver(),
|
||||||
|
MangaSyncDeleteResolver()
|
||||||
|
)
|
||||||
|
|
||||||
|
class MangaSyncPutResolver : DefaultPutResolver<MangaSync>() {
|
||||||
|
|
||||||
|
override fun mapToInsertQuery(obj: MangaSync) = InsertQuery.builder()
|
||||||
|
.table(TABLE)
|
||||||
|
.build()
|
||||||
|
|
||||||
|
override fun mapToUpdateQuery(obj: MangaSync) = UpdateQuery.builder()
|
||||||
|
.table(TABLE)
|
||||||
|
.where("$COL_ID = ?")
|
||||||
|
.whereArgs(obj.id)
|
||||||
|
.build()
|
||||||
|
|
||||||
|
override fun mapToContentValues(obj: MangaSync) = ContentValues(9).apply {
|
||||||
|
put(COL_ID, obj.id)
|
||||||
|
put(COL_MANGA_ID, obj.manga_id)
|
||||||
|
put(COL_SYNC_ID, obj.sync_id)
|
||||||
|
put(COL_REMOTE_ID, obj.remote_id)
|
||||||
|
put(COL_TITLE, obj.title)
|
||||||
|
put(COL_LAST_CHAPTER_READ, obj.last_chapter_read)
|
||||||
|
put(COL_TOTAL_CHAPTERS, obj.total_chapters)
|
||||||
|
put(COL_STATUS, obj.status)
|
||||||
|
put(COL_SCORE, obj.score)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class MangaSyncGetResolver : DefaultGetResolver<MangaSync>() {
|
||||||
|
|
||||||
|
override fun mapFromCursor(cursor: Cursor) = MangaSync().apply {
|
||||||
|
id = cursor.getLong(cursor.getColumnIndex(COL_ID))
|
||||||
|
manga_id = cursor.getLong(cursor.getColumnIndex(COL_MANGA_ID))
|
||||||
|
sync_id = cursor.getInt(cursor.getColumnIndex(COL_SYNC_ID))
|
||||||
|
remote_id = cursor.getInt(cursor.getColumnIndex(COL_REMOTE_ID))
|
||||||
|
title = cursor.getString(cursor.getColumnIndex(COL_TITLE))
|
||||||
|
last_chapter_read = cursor.getInt(cursor.getColumnIndex(COL_LAST_CHAPTER_READ))
|
||||||
|
total_chapters = cursor.getInt(cursor.getColumnIndex(COL_TOTAL_CHAPTERS))
|
||||||
|
status = cursor.getInt(cursor.getColumnIndex(COL_STATUS))
|
||||||
|
score = cursor.getFloat(cursor.getColumnIndex(COL_SCORE))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class MangaSyncDeleteResolver : DefaultDeleteResolver<MangaSync>() {
|
||||||
|
|
||||||
|
override fun mapToDeleteQuery(obj: MangaSync) = DeleteQuery.builder()
|
||||||
|
.table(TABLE)
|
||||||
|
.where("$COL_ID = ?")
|
||||||
|
.whereArgs(obj.id)
|
||||||
|
.build()
|
||||||
|
}
|
@ -0,0 +1,95 @@
|
|||||||
|
package eu.kanade.tachiyomi.data.database.mappers
|
||||||
|
|
||||||
|
import android.content.ContentValues
|
||||||
|
import android.database.Cursor
|
||||||
|
import com.pushtorefresh.storio.sqlite.SQLiteTypeMapping
|
||||||
|
import com.pushtorefresh.storio.sqlite.operations.delete.DefaultDeleteResolver
|
||||||
|
import com.pushtorefresh.storio.sqlite.operations.get.DefaultGetResolver
|
||||||
|
import com.pushtorefresh.storio.sqlite.operations.put.DefaultPutResolver
|
||||||
|
import com.pushtorefresh.storio.sqlite.queries.DeleteQuery
|
||||||
|
import com.pushtorefresh.storio.sqlite.queries.InsertQuery
|
||||||
|
import com.pushtorefresh.storio.sqlite.queries.UpdateQuery
|
||||||
|
import eu.kanade.tachiyomi.data.database.models.Manga
|
||||||
|
import eu.kanade.tachiyomi.data.database.tables.MangaTable.COL_ARTIST
|
||||||
|
import eu.kanade.tachiyomi.data.database.tables.MangaTable.COL_AUTHOR
|
||||||
|
import eu.kanade.tachiyomi.data.database.tables.MangaTable.COL_CHAPTER_FLAGS
|
||||||
|
import eu.kanade.tachiyomi.data.database.tables.MangaTable.COL_DESCRIPTION
|
||||||
|
import eu.kanade.tachiyomi.data.database.tables.MangaTable.COL_FAVORITE
|
||||||
|
import eu.kanade.tachiyomi.data.database.tables.MangaTable.COL_GENRE
|
||||||
|
import eu.kanade.tachiyomi.data.database.tables.MangaTable.COL_ID
|
||||||
|
import eu.kanade.tachiyomi.data.database.tables.MangaTable.COL_INITIALIZED
|
||||||
|
import eu.kanade.tachiyomi.data.database.tables.MangaTable.COL_LAST_UPDATE
|
||||||
|
import eu.kanade.tachiyomi.data.database.tables.MangaTable.COL_SOURCE
|
||||||
|
import eu.kanade.tachiyomi.data.database.tables.MangaTable.COL_STATUS
|
||||||
|
import eu.kanade.tachiyomi.data.database.tables.MangaTable.COL_THUMBNAIL_URL
|
||||||
|
import eu.kanade.tachiyomi.data.database.tables.MangaTable.COL_TITLE
|
||||||
|
import eu.kanade.tachiyomi.data.database.tables.MangaTable.COL_URL
|
||||||
|
import eu.kanade.tachiyomi.data.database.tables.MangaTable.COL_VIEWER
|
||||||
|
import eu.kanade.tachiyomi.data.database.tables.MangaTable.TABLE
|
||||||
|
|
||||||
|
class MangaTypeMapping : SQLiteTypeMapping<Manga>(
|
||||||
|
MangaPutResolver(),
|
||||||
|
MangaGetResolver(),
|
||||||
|
MangaDeleteResolver()
|
||||||
|
)
|
||||||
|
|
||||||
|
class MangaPutResolver : DefaultPutResolver<Manga>() {
|
||||||
|
|
||||||
|
override fun mapToInsertQuery(obj: Manga) = InsertQuery.builder()
|
||||||
|
.table(TABLE)
|
||||||
|
.build()
|
||||||
|
|
||||||
|
override fun mapToUpdateQuery(obj: Manga) = UpdateQuery.builder()
|
||||||
|
.table(TABLE)
|
||||||
|
.where("$COL_ID = ?")
|
||||||
|
.whereArgs(obj.id)
|
||||||
|
.build()
|
||||||
|
|
||||||
|
override fun mapToContentValues(obj: Manga) = ContentValues(15).apply {
|
||||||
|
put(COL_ID, obj.id)
|
||||||
|
put(COL_SOURCE, obj.source)
|
||||||
|
put(COL_URL, obj.url)
|
||||||
|
put(COL_ARTIST, obj.artist)
|
||||||
|
put(COL_AUTHOR, obj.author)
|
||||||
|
put(COL_DESCRIPTION, obj.description)
|
||||||
|
put(COL_GENRE, obj.genre)
|
||||||
|
put(COL_TITLE, obj.title)
|
||||||
|
put(COL_STATUS, obj.status)
|
||||||
|
put(COL_THUMBNAIL_URL, obj.thumbnail_url)
|
||||||
|
put(COL_FAVORITE, obj.favorite)
|
||||||
|
put(COL_LAST_UPDATE, obj.last_update)
|
||||||
|
put(COL_INITIALIZED, obj.initialized)
|
||||||
|
put(COL_VIEWER, obj.viewer)
|
||||||
|
put(COL_CHAPTER_FLAGS, obj.chapter_flags)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
open class MangaGetResolver : DefaultGetResolver<Manga>() {
|
||||||
|
|
||||||
|
override fun mapFromCursor(cursor: Cursor) = Manga().apply {
|
||||||
|
id = cursor.getLong(cursor.getColumnIndex(COL_ID))
|
||||||
|
source = cursor.getInt(cursor.getColumnIndex(COL_SOURCE))
|
||||||
|
url = cursor.getString(cursor.getColumnIndex(COL_URL))
|
||||||
|
artist = cursor.getString(cursor.getColumnIndex(COL_ARTIST))
|
||||||
|
author = cursor.getString(cursor.getColumnIndex(COL_AUTHOR))
|
||||||
|
description = cursor.getString(cursor.getColumnIndex(COL_DESCRIPTION))
|
||||||
|
genre = cursor.getString(cursor.getColumnIndex(COL_GENRE))
|
||||||
|
title = cursor.getString(cursor.getColumnIndex(COL_TITLE))
|
||||||
|
status = cursor.getInt(cursor.getColumnIndex(COL_STATUS))
|
||||||
|
thumbnail_url = cursor.getString(cursor.getColumnIndex(COL_THUMBNAIL_URL))
|
||||||
|
favorite = cursor.getInt(cursor.getColumnIndex(COL_FAVORITE)) == 1
|
||||||
|
last_update = cursor.getLong(cursor.getColumnIndex(COL_LAST_UPDATE))
|
||||||
|
initialized = cursor.getInt(cursor.getColumnIndex(COL_INITIALIZED)) == 1
|
||||||
|
viewer = cursor.getInt(cursor.getColumnIndex(COL_VIEWER))
|
||||||
|
chapter_flags = cursor.getInt(cursor.getColumnIndex(COL_CHAPTER_FLAGS))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class MangaDeleteResolver : DefaultDeleteResolver<Manga>() {
|
||||||
|
|
||||||
|
override fun mapToDeleteQuery(obj: Manga) = DeleteQuery.builder()
|
||||||
|
.table(TABLE)
|
||||||
|
.where("$COL_ID = ?")
|
||||||
|
.whereArgs(obj.id)
|
||||||
|
.build()
|
||||||
|
}
|
@ -1,12 +1,11 @@
|
|||||||
package eu.kanade.tachiyomi.data.database.resolvers
|
package eu.kanade.tachiyomi.data.database.resolvers
|
||||||
|
|
||||||
import android.database.Cursor
|
import android.database.Cursor
|
||||||
|
import eu.kanade.tachiyomi.data.database.mappers.MangaGetResolver
|
||||||
import eu.kanade.tachiyomi.data.database.models.Manga
|
import eu.kanade.tachiyomi.data.database.models.Manga
|
||||||
import eu.kanade.tachiyomi.data.database.models.MangaStorIOSQLiteGetResolver
|
|
||||||
import eu.kanade.tachiyomi.data.database.tables.MangaTable
|
import eu.kanade.tachiyomi.data.database.tables.MangaTable
|
||||||
|
|
||||||
class LibraryMangaGetResolver : MangaStorIOSQLiteGetResolver() {
|
class LibraryMangaGetResolver : MangaGetResolver() {
|
||||||
|
|
||||||
companion object {
|
companion object {
|
||||||
val INSTANCE = LibraryMangaGetResolver()
|
val INSTANCE = LibraryMangaGetResolver()
|
||||||
|
@ -2,9 +2,9 @@ package eu.kanade.tachiyomi.data.database.resolvers
|
|||||||
|
|
||||||
import android.database.Cursor
|
import android.database.Cursor
|
||||||
import com.pushtorefresh.storio.sqlite.operations.get.DefaultGetResolver
|
import com.pushtorefresh.storio.sqlite.operations.get.DefaultGetResolver
|
||||||
import eu.kanade.tachiyomi.data.database.models.ChapterStorIOSQLiteGetResolver
|
import eu.kanade.tachiyomi.data.database.mappers.ChapterGetResolver
|
||||||
|
import eu.kanade.tachiyomi.data.database.mappers.MangaGetResolver
|
||||||
import eu.kanade.tachiyomi.data.database.models.MangaChapter
|
import eu.kanade.tachiyomi.data.database.models.MangaChapter
|
||||||
import eu.kanade.tachiyomi.data.database.models.MangaStorIOSQLiteGetResolver
|
|
||||||
|
|
||||||
class MangaChapterGetResolver : DefaultGetResolver<MangaChapter>() {
|
class MangaChapterGetResolver : DefaultGetResolver<MangaChapter>() {
|
||||||
|
|
||||||
@ -12,9 +12,9 @@ class MangaChapterGetResolver : DefaultGetResolver<MangaChapter>() {
|
|||||||
val INSTANCE = MangaChapterGetResolver()
|
val INSTANCE = MangaChapterGetResolver()
|
||||||
}
|
}
|
||||||
|
|
||||||
private val mangaGetResolver = MangaStorIOSQLiteGetResolver()
|
private val mangaGetResolver = MangaGetResolver()
|
||||||
|
|
||||||
private val chapterGetResolver = ChapterStorIOSQLiteGetResolver()
|
private val chapterGetResolver = ChapterGetResolver()
|
||||||
|
|
||||||
override fun mapFromCursor(cursor: Cursor): MangaChapter {
|
override fun mapFromCursor(cursor: Cursor): MangaChapter {
|
||||||
val manga = mangaGetResolver.mapFromCursor(cursor)
|
val manga = mangaGetResolver.mapFromCursor(cursor)
|
||||||
|
@ -2,7 +2,11 @@ package eu.kanade.tachiyomi.data.database.resolvers
|
|||||||
|
|
||||||
import android.database.Cursor
|
import android.database.Cursor
|
||||||
import com.pushtorefresh.storio.sqlite.operations.get.DefaultGetResolver
|
import com.pushtorefresh.storio.sqlite.operations.get.DefaultGetResolver
|
||||||
import eu.kanade.tachiyomi.data.database.models.*
|
import eu.kanade.tachiyomi.data.database.mappers.ChapterGetResolver
|
||||||
|
import eu.kanade.tachiyomi.data.database.mappers.HistoryGetResolver
|
||||||
|
import eu.kanade.tachiyomi.data.database.mappers.MangaGetResolver
|
||||||
|
import eu.kanade.tachiyomi.data.database.models.MangaChapter
|
||||||
|
import eu.kanade.tachiyomi.data.database.models.MangaChapterHistory
|
||||||
|
|
||||||
class MangaChapterHistoryGetResolver : DefaultGetResolver<MangaChapterHistory>() {
|
class MangaChapterHistoryGetResolver : DefaultGetResolver<MangaChapterHistory>() {
|
||||||
companion object {
|
companion object {
|
||||||
@ -12,17 +16,17 @@ class MangaChapterHistoryGetResolver : DefaultGetResolver<MangaChapterHistory>()
|
|||||||
/**
|
/**
|
||||||
* Manga get resolver
|
* Manga get resolver
|
||||||
*/
|
*/
|
||||||
private val mangaGetResolver = MangaStorIOSQLiteGetResolver()
|
private val mangaGetResolver = MangaGetResolver()
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Chapter get resolver
|
* Chapter get resolver
|
||||||
*/
|
*/
|
||||||
private val chapterResolver = ChapterStorIOSQLiteGetResolver()
|
private val chapterResolver = ChapterGetResolver()
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* History get resolver
|
* History get resolver
|
||||||
*/
|
*/
|
||||||
private val historyGetResolver = HistoryStorIOSQLiteGetResolver()
|
private val historyGetResolver = HistoryGetResolver()
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Map correct objects from cursor result
|
* Map correct objects from cursor result
|
||||||
|
@ -0,0 +1,16 @@
|
|||||||
|
package eu.kanade.tachiyomi.injection;
|
||||||
|
|
||||||
|
import eu.kanade.tachiyomi.App;
|
||||||
|
import eu.kanade.tachiyomi.injection.component.AppComponent;
|
||||||
|
import eu.kanade.tachiyomi.injection.component.DaggerAppComponent;
|
||||||
|
import eu.kanade.tachiyomi.injection.module.AppModule;
|
||||||
|
|
||||||
|
|
||||||
|
public class AppComponentFactory {
|
||||||
|
|
||||||
|
public static AppComponent create(App app) {
|
||||||
|
return DaggerAppComponent.builder().appModule(new AppModule(app)).build();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
@ -1,15 +1,17 @@
|
|||||||
package eu.kanade.tachiyomi
|
package eu.kanade.tachiyomi
|
||||||
|
|
||||||
|
import eu.kanade.tachiyomi.injection.component.AppComponent
|
||||||
import eu.kanade.tachiyomi.injection.component.DaggerAppComponent
|
import eu.kanade.tachiyomi.injection.component.DaggerAppComponent
|
||||||
import eu.kanade.tachiyomi.injection.module.AppModule
|
import eu.kanade.tachiyomi.injection.module.AppModule
|
||||||
import eu.kanade.tachiyomi.injection.module.TestDataModule
|
import eu.kanade.tachiyomi.injection.module.TestDataModule
|
||||||
|
|
||||||
open class TestApp : App() {
|
open class TestApp : App() {
|
||||||
|
|
||||||
override fun prepareAppComponent(): DaggerAppComponent.Builder {
|
override fun createAppComponent(): AppComponent {
|
||||||
return DaggerAppComponent.builder()
|
return DaggerAppComponent.builder()
|
||||||
.appModule(AppModule(this))
|
.appModule(AppModule(this))
|
||||||
.dataModule(TestDataModule())
|
.dataModule(TestDataModule())
|
||||||
|
.build()
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun setupAcra() {
|
override fun setupAcra() {
|
||||||
|
Loading…
Reference in New Issue
Block a user