From bbe62c0e7b81a61d6a916f4acd2ba1b98d463c54 Mon Sep 17 00:00:00 2001 From: InsanusMokrassar Date: Tue, 30 Sep 2025 23:06:42 +0600 Subject: [PATCH 1/3] start 0.26.5 --- CHANGELOG.md | 2 ++ gradle.properties | 4 ++-- 2 files changed, 4 insertions(+), 2 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 44d9c728530..ca08adfa2ae 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,5 +1,7 @@ # Changelog +## 0.26.5 + ## 0.26.4 * `Common`: diff --git a/gradle.properties b/gradle.properties index 000afc9ac55..a387e024420 100644 --- a/gradle.properties +++ b/gradle.properties @@ -18,5 +18,5 @@ crypto_js_version=4.1.1 # Project data group=dev.inmo -version=0.26.4 -android_code_version=303 +version=0.26.5 +android_code_version=304 From 1dd71175f433e8272472b32b26a9af887867a8ff Mon Sep 17 00:00:00 2001 From: InsanusMokrassar Date: Tue, 30 Sep 2025 23:29:04 +0600 Subject: [PATCH 2/3] update dependencies --- CHANGELOG.md | 8 ++++++++ gradle/libs.versions.toml | 14 +++++++------- gradle/wrapper/gradle-wrapper.properties | 2 +- 3 files changed, 16 insertions(+), 8 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index ca08adfa2ae..34a4367d350 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -2,6 +2,14 @@ ## 0.26.5 +* `Versions`: + * `Kotlin`: `2.2.10` -> `2.2.20` + * `KSLog`: `1.5.0` -> `1.5.1` + * `Ktor`: `3.2.3` -> `3.3.0` + * `SQLite`: `3.50.1.0` -> `3.50.3.0` + * `KotlinX Browser`: `0.3` -> `0.5.0` + * `Koin`: `4.1.0` -> `4.1.1` + ## 0.26.4 * `Common`: diff --git a/gradle/libs.versions.toml b/gradle/libs.versions.toml index 031bb920e2e..4a4271c6e3a 100644 --- a/gradle/libs.versions.toml +++ b/gradle/libs.versions.toml @@ -1,31 +1,31 @@ [versions] -kt = "2.2.10" +kt = "2.2.20" kt-serialization = "1.9.0" kt-coroutines = "1.10.2" -kotlinx-browser = "0.3" +kotlinx-browser = "0.5.0" -kslog = "1.5.0" +kslog = "1.5.1" jb-compose = "1.8.2" jb-exposed = "0.61.0" jb-dokka = "2.0.0" -sqlite = "3.50.1.0" +sqlite = "3.50.3.0" korlibs = "5.4.0" uuid = "0.8.4" -ktor = "3.2.3" +ktor = "3.3.0" gh-release = "2.5.2" -koin = "4.1.0" +koin = "4.1.1" okio = "3.16.0" -ksp = "2.2.10-2.0.2" +ksp = "2.2.20-2.0.3" kotlin-poet = "2.2.0" versions = "0.52.0" diff --git a/gradle/wrapper/gradle-wrapper.properties b/gradle/wrapper/gradle-wrapper.properties index 2733ed5dc3c..3ae1e2f124c 100644 --- a/gradle/wrapper/gradle-wrapper.properties +++ b/gradle/wrapper/gradle-wrapper.properties @@ -1,5 +1,5 @@ distributionBase=GRADLE_USER_HOME distributionPath=wrapper/dists -distributionUrl=https\://services.gradle.org/distributions/gradle-8.13-bin.zip +distributionUrl=https\://services.gradle.org/distributions/gradle-8.14.3-bin.zip zipStoreBase=GRADLE_USER_HOME zipStorePath=wrapper/dists From a247dbcb0293c1f9b27c585454a8f310adefb75a Mon Sep 17 00:00:00 2001 From: InsanusMokrassar Date: Sat, 4 Oct 2025 14:20:18 +0600 Subject: [PATCH 3/3] rollback sqlite update --- CHANGELOG.md | 1 - gradle/libs.versions.toml | 3 +- .../exposed/ExposedTableInitialization.kt | 73 ++++++++++++++++++- 3 files changed, 74 insertions(+), 3 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 34a4367d350..b0b76332859 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -6,7 +6,6 @@ * `Kotlin`: `2.2.10` -> `2.2.20` * `KSLog`: `1.5.0` -> `1.5.1` * `Ktor`: `3.2.3` -> `3.3.0` - * `SQLite`: `3.50.1.0` -> `3.50.3.0` * `KotlinX Browser`: `0.3` -> `0.5.0` * `Koin`: `4.1.0` -> `4.1.1` diff --git a/gradle/libs.versions.toml b/gradle/libs.versions.toml index 4a4271c6e3a..1e203933469 100644 --- a/gradle/libs.versions.toml +++ b/gradle/libs.versions.toml @@ -12,7 +12,8 @@ jb-compose = "1.8.2" jb-exposed = "0.61.0" jb-dokka = "2.0.0" -sqlite = "3.50.3.0" +# 3.50.3.0 contains bug https://github.com/InsanusMokrassar/MicroUtils/actions/runs/18138301958/job/51629588088 +sqlite = "3.50.1.0" korlibs = "5.4.0" uuid = "0.8.4" diff --git a/repos/exposed/src/jvmMain/kotlin/dev/inmo/micro_utils/repos/exposed/ExposedTableInitialization.kt b/repos/exposed/src/jvmMain/kotlin/dev/inmo/micro_utils/repos/exposed/ExposedTableInitialization.kt index 8b0587c96b2..5d7802338bf 100644 --- a/repos/exposed/src/jvmMain/kotlin/dev/inmo/micro_utils/repos/exposed/ExposedTableInitialization.kt +++ b/repos/exposed/src/jvmMain/kotlin/dev/inmo/micro_utils/repos/exposed/ExposedTableInitialization.kt @@ -1,10 +1,81 @@ package dev.inmo.micro_utils.repos.exposed import org.jetbrains.exposed.sql.* +import org.jetbrains.exposed.sql.SchemaUtils.addMissingColumnsStatements +import org.jetbrains.exposed.sql.SchemaUtils.checkMappingConsistence +import org.jetbrains.exposed.sql.SchemaUtils.createStatements +import org.jetbrains.exposed.sql.transactions.TransactionManager import org.jetbrains.exposed.sql.transactions.transaction +/** + * Code in this function mostly duplicates Exposed [SchemaUtils.createMissingTablesAndColumns]. It made due to deprecation + * status of the last one and potential lost of it in future updates. + * + * Code doing: + * + * * Creating missed tables + * * Altering missed tables (where possible) + * * Calculate problems with [checkMappingConsistence] and add them in execution too + * + * All changes made in [transaction] with [database] as its `db` argument + */ +fun initTablesInTransaction(vararg tables: Table, database: Database, inBatch: Boolean = false, withLogs: Boolean = true) { + transaction(database) { + fun logTimeSpent(message: String, withLogs: Boolean, block: () -> R): R { + return if (withLogs) { + val start = System.currentTimeMillis() + val answer = block() + exposedLogger.info(message + " took " + (System.currentTimeMillis() - start) + "ms") + answer + } else { + block() + } + } + fun Transaction.execStatements(inBatch: Boolean, statements: List) { + if (inBatch) { + execInBatch(statements) + } else { + for (statement in statements) { + exec(statement) + } + } + } + with(TransactionManager.current()) { + db.dialect.resetCaches() + val createStatements = logTimeSpent("Preparing create tables statements", withLogs) { + createStatements(*tables) + } + logTimeSpent("Executing create tables statements", withLogs) { + execStatements(inBatch, createStatements) + commit() + } + + val alterStatements = logTimeSpent("Preparing alter table statements", withLogs) { + addMissingColumnsStatements(tables = tables, withLogs) + } + logTimeSpent("Executing alter table statements", withLogs) { + execStatements(inBatch, alterStatements) + commit() + } + val executedStatements = createStatements + alterStatements + logTimeSpent("Checking mapping consistence", withLogs) { + val modifyTablesStatements = checkMappingConsistence( + tables = tables, + withLogs + ).filter { it !in executedStatements } + execStatements(inBatch, modifyTablesStatements) + commit() + } + db.dialect.resetCaches() + } + } +} + +fun Table.initTable(database: Database, inBatch: Boolean, withLogs: Boolean) { + initTablesInTransaction(this, database = database, inBatch = inBatch, withLogs = withLogs) +} fun Table.initTable(database: Database) { - transaction(database) { SchemaUtils.createMissingTablesAndColumns(this@initTable) } + initTable(database = database, inBatch = false, withLogs = true) } fun T.initTable() where T: ExposedRepo, T: Table = initTable(database)