mirror of
				https://github.com/InsanusMokrassar/MicroUtils.git
				synced 2025-10-26 01:30:48 +00:00 
			
		
		
		
	Compare commits
	
		
			15 Commits
		
	
	
		
			0.26.2
			...
			renovate/k
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 7db412301d | ||
| 9dad353957 | |||
| 89e16b7bdb | |||
| c2965da341 | |||
| ffb072dc5f | |||
| a247dbcb02 | |||
| 1dd71175f4 | |||
| bbe62c0e7b | |||
| 9822ff321b | |||
| b485d485ef | |||
| 0b3d445109 | |||
| d7e48940bc | |||
| 1049eb0fe7 | |||
| c871ef5635 | |||
| 7edfcb20c4 | 
							
								
								
									
										29
									
								
								CHANGELOG.md
									
									
									
									
									
								
							
							
						
						
									
										29
									
								
								CHANGELOG.md
									
									
									
									
									
								
							| @@ -1,5 +1,34 @@ | ||||
| # Changelog | ||||
|  | ||||
| ## 0.26.6 | ||||
|  | ||||
| * `Versions`: | ||||
|     * `Ktor`: `3.3.0` -> `3.3.1` | ||||
|     * `Okio`: `3.16.0` -> `3.16.2` | ||||
|  | ||||
| ## 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` | ||||
|     * `KotlinX Browser`: `0.3` -> `0.5.0` | ||||
|     * `Koin`: `4.1.0` -> `4.1.1` | ||||
|  | ||||
| ## 0.26.4 | ||||
|  | ||||
| * `Common`: | ||||
|   * Add expect/actual `MPPFilePathSeparator` | ||||
|   * Fix `FileName` realization to take care about system file path separator | ||||
|  | ||||
| ## 0.26.3 | ||||
|  | ||||
| * `Versions`: | ||||
|   * `Kotlin`: `2.2.0` -> `2.2.10` | ||||
|   * `KSP`: `2.2.0-2.0.2` -> `2.2.10-2.0.2` | ||||
|   * `Android CoreKTX`: `1.16.0` -> `1.17.0` | ||||
|   * `Android Fragment`: `1.8.8` -> `1.8.9` | ||||
|  | ||||
| ## 0.26.2 | ||||
|  | ||||
| * `Versions`: | ||||
|   | ||||
| @@ -7,7 +7,7 @@ import kotlin.jvm.JvmInline | ||||
| @JvmInline | ||||
| value class FileName(val string: String) { | ||||
|     val name: String | ||||
|         get() = withoutSlashAtTheEnd.takeLastWhile { it != '/' } | ||||
|         get() = withoutSlashAtTheEnd.takeLastWhile { it != MPPFilePathSeparator } | ||||
|     val extension: String | ||||
|         get() = name.takeLastWhile { it != '.' } | ||||
|     val nameWithoutExtension: String | ||||
| @@ -18,7 +18,7 @@ value class FileName(val string: String) { | ||||
|             } ?: filename | ||||
|         } | ||||
|     val withoutSlashAtTheEnd: String | ||||
|         get() = string.dropLastWhile { it == '/' } | ||||
|         get() = string.dropLastWhile { it == MPPFilePathSeparator } | ||||
|     override fun toString(): String = string | ||||
| } | ||||
|  | ||||
| @@ -26,6 +26,7 @@ value class FileName(val string: String) { | ||||
| expect class MPPFile | ||||
|  | ||||
| expect val MPPFile.filename: FileName | ||||
| expect val MPPFilePathSeparator: Char | ||||
| expect val MPPFile.filesize: Long | ||||
| expect val MPPFile.bytesAllocatorSync: ByteArrayAllocator | ||||
| expect val MPPFile.bytesAllocator: SuspendByteArrayAllocator | ||||
|   | ||||
| @@ -35,6 +35,10 @@ private suspend fun MPPFile.dirtyReadBytes(): ByteArray = readBytesPromise().awa | ||||
|  */ | ||||
| actual val MPPFile.filename: FileName | ||||
|     get() = FileName(name) | ||||
|  | ||||
| actual val MPPFilePathSeparator: Char | ||||
|     get() = '/' | ||||
|  | ||||
| /** | ||||
|  * @suppress | ||||
|  */ | ||||
|   | ||||
| @@ -14,6 +14,10 @@ actual typealias MPPFile = File | ||||
|  */ | ||||
| actual val MPPFile.filename: FileName | ||||
|     get() = FileName(name) | ||||
|  | ||||
| actual val MPPFilePathSeparator: Char | ||||
|     get() = File.separatorChar | ||||
|  | ||||
| /** | ||||
|  * @suppress | ||||
|  */ | ||||
|   | ||||
| @@ -11,6 +11,10 @@ actual typealias MPPFile = Path | ||||
|  */ | ||||
| actual val MPPFile.filename: FileName | ||||
|     get() = FileName(toString()) | ||||
|  | ||||
|  | ||||
| actual val MPPFilePathSeparator: Char = Path.DIRECTORY_SEPARATOR.first() | ||||
|  | ||||
| /** | ||||
|  * @suppress | ||||
|  */ | ||||
|   | ||||
| @@ -37,6 +37,10 @@ private suspend fun MPPFile.dirtyReadBytes(): ByteArray = readBytesPromise().awa | ||||
|  */ | ||||
| actual val MPPFile.filename: FileName | ||||
|     get() = FileName(name) | ||||
|  | ||||
| actual val MPPFilePathSeparator: Char | ||||
|     get() = '/' | ||||
|  | ||||
| /** | ||||
|  * @suppress | ||||
|  */ | ||||
|   | ||||
| @@ -18,5 +18,5 @@ crypto_js_version=4.1.1 | ||||
| # Project data | ||||
|  | ||||
| group=dev.inmo | ||||
| version=0.26.2 | ||||
| android_code_version=301 | ||||
| version=0.26.6 | ||||
| android_code_version=305 | ||||
|   | ||||
| @@ -1,43 +1,44 @@ | ||||
| [versions] | ||||
|  | ||||
| kt = "2.2.0" | ||||
| 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" | ||||
| jb-dokka = "2.1.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" | ||||
|  | ||||
| ktor = "3.2.3" | ||||
| ktor = "3.3.1" | ||||
|  | ||||
| gh-release = "2.5.2" | ||||
|  | ||||
| koin = "4.1.0" | ||||
| koin = "4.1.1" | ||||
|  | ||||
| okio = "3.16.0" | ||||
| okio = "3.16.2" | ||||
|  | ||||
| ksp = "2.2.0-2.0.2" | ||||
| ksp = "2.3.0" | ||||
| kotlin-poet = "2.2.0" | ||||
|  | ||||
| versions = "0.52.0" | ||||
| nmcp = "1.0.2" | ||||
| nmcp = "1.1.0" | ||||
|  | ||||
| android-gradle = "8.9.+" | ||||
| android-gradle = "8.10.+" | ||||
| dexcount = "4.0.0" | ||||
|  | ||||
| android-coreKtx = "1.16.0" | ||||
| android-coreKtx = "1.17.0" | ||||
| android-recyclerView = "1.4.0" | ||||
| android-appCompat = "1.7.1" | ||||
| android-fragment = "1.8.8" | ||||
| android-fragment = "1.8.9" | ||||
| android-espresso = "3.7.0" | ||||
| android-test = "1.3.0" | ||||
|  | ||||
|   | ||||
							
								
								
									
										2
									
								
								gradle/wrapper/gradle-wrapper.properties
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								gradle/wrapper/gradle-wrapper.properties
									
									
									
									
										vendored
									
									
								
							| @@ -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 | ||||
|   | ||||
| @@ -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 <R> 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<String>) { | ||||
|             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> T.initTable() where T: ExposedRepo, T: Table = initTable(database) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user