mirror of
				https://github.com/InsanusMokrassar/MicroUtils.git
				synced 2025-10-25 09:10:30 +00:00 
			
		
		
		
	Compare commits
	
		
			82 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 4a454f3d67 | |||
| 151aa1863d | |||
| 3bf6896296 | |||
| 0d01561476 | |||
| f6ded92251 | |||
| d01b735cc6 | |||
| 6c12001080 | |||
| 1afbf03606 | |||
| f6ef5c61c5 | |||
| c18fee8107 | |||
| d9df7a4384 | |||
| 87c2230e8e | |||
| da7eb6de0a | |||
| ed3815118f | |||
| be726f42bd | |||
| a91006132f | |||
| 9a9f741a0b | |||
| 5028f130e9 | |||
| 77fa019651 | |||
| 9715da9384 | |||
| f6d5035c1a | |||
| 43e782ab6f | |||
| f3f9920bfb | |||
| 2bfd615812 | |||
| ebfacb3659 | |||
| c71d557eec | |||
| e0398cef21 | |||
| f91599e9c6 | |||
| f8f9f93c97 | |||
| a8a5340d8b | |||
| 871b27f37d | |||
| 6f174cae1d | |||
| 22d7ac3e22 | |||
| 9b30c3a155 | |||
| 915bac64b1 | |||
| 9d2b50e55d | |||
| bde100f63d | |||
| 05b035a13d | |||
| eefb56bed7 | |||
| fcc0dc4189 | |||
| 47ff20317f | |||
| 1558b9103d | |||
| 7a78742162 | |||
| c01e240f66 | |||
| fef4fcbac6 | |||
| 5ab18bce4b | |||
| 24aec7271a | |||
| 9b19a2cb95 | |||
| efdd7b8a57 | |||
| 6df4cc9c3b | |||
| b9d93db0f5 | |||
| d7ee45ca64 | |||
| d7c31b1b22 | |||
| 7d6794a358 | |||
| 473eb87346 | |||
| 8b18b07790 | |||
| ab3c80a5ec | |||
| 075b93ecd6 | |||
| f6d0f72e49 | |||
| fcda3af862 | |||
| d5c7a589b1 | |||
| 86e099ed25 | |||
| ebd7befe73 | |||
| b8c7e581a1 | |||
| 8281259179 | |||
| d3e06b07df | |||
| 4967018418 | |||
| 537a3c38fa | |||
| 0124957833 | |||
| f0420e2d61 | |||
| 7090566041 | |||
| f0d5035cd0 | |||
| 0fb9b8dc30 | |||
| eef6e81134 | |||
| 1593159a3f | |||
| 3da9eb9dbe | |||
| f17613f3fb | |||
| 14337ccb46 | |||
| 1a3913b09c | |||
| 039aed2747 | |||
| 173991e3cb | |||
| 8b3f8cab01 | 
							
								
								
									
										2
									
								
								.github/workflows/build.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/build.yml
									
									
									
									
										vendored
									
									
								
							| @@ -8,7 +8,7 @@ jobs: | ||||
|       - uses: actions/checkout@v2 | ||||
|       - uses: actions/setup-java@v1 | ||||
|         with: | ||||
|           java-version: 11 | ||||
|           java-version: 17 | ||||
|       - name: Rewrite version | ||||
|         run: | | ||||
|           branch="`echo "${{ github.ref }}" | grep -o "[^/]*$"`" | ||||
|   | ||||
							
								
								
									
										2
									
								
								.github/workflows/dokka_push.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/dokka_push.yml
									
									
									
									
										vendored
									
									
								
							| @@ -10,7 +10,7 @@ jobs: | ||||
|       - uses: actions/checkout@v2 | ||||
|       - uses: actions/setup-java@v1 | ||||
|         with: | ||||
|           java-version: 11 | ||||
|           java-version: 17 | ||||
|       - name: Build | ||||
|         run: ./gradlew build && ./gradlew dokkaHtml | ||||
|       - name: Publish KDocs | ||||
|   | ||||
							
								
								
									
										111
									
								
								CHANGELOG.md
									
									
									
									
									
								
							
							
						
						
									
										111
									
								
								CHANGELOG.md
									
									
									
									
									
								
							| @@ -1,5 +1,116 @@ | ||||
| # Changelog | ||||
|  | ||||
| ## 0.20.21 | ||||
|  | ||||
| * `Resources`: | ||||
|     * Inited | ||||
|  | ||||
| ## 0.20.20 | ||||
|  | ||||
| * `Repos`: | ||||
|     * `Exposed`: | ||||
|         * Add opportunity for setup flows in `AbstractExposedCRUDRepo` | ||||
|  | ||||
| ## 0.20.19 | ||||
|  | ||||
| * `Versions`: | ||||
|     * `Ktor`: `2.3.6` -> `2.3.7` | ||||
|  | ||||
| ## 0.20.18 | ||||
|  | ||||
| * `Coroutines`: | ||||
|     * `SpecialMutableStateFlow` now extends `MutableStateFlow` | ||||
|     * `Compose`: | ||||
|         * Deprecate `FlowState` due to its complexity in fixes | ||||
|  | ||||
| ## 0.20.17 | ||||
|  | ||||
| * `Versions`: | ||||
|     * `Serialization`: `1.6.1` -> `1.6.2` | ||||
|  | ||||
| ## 0.20.16 | ||||
|  | ||||
| * `Versions`: | ||||
|     * `Exposed`: `0.44.1` -> `0.45.0` | ||||
| * `Coroutines`: | ||||
|     * Add `SpecialMutableStateFlow` | ||||
|     * `Compose`: | ||||
|         * Add `FlowState` | ||||
|  | ||||
| ## 0.20.15 | ||||
|  | ||||
| * `Versions`: | ||||
|     * `Kotlin`: `1.9.20` -> `1.9.21` | ||||
|     * `KSLog`: `1.3.0` -> `1.3.1` | ||||
|     * `Compose`: `1.5.10` -> `1.5.11` | ||||
|  | ||||
| ## 0.20.14 | ||||
|  | ||||
| * `Versions`: | ||||
|     * `Serialization`: `1.6.0` -> `1.6.1` | ||||
|     * `KSLog`: `1.2.4` -> `1.3.0` | ||||
|  | ||||
| ## 0.20.13 | ||||
|  | ||||
| * `Versions`: | ||||
|     * `Ktor`: `2.3.5` -> `2.3.6` | ||||
|     * `UUID`: `0.8.1` -> `0.8.2` | ||||
|  | ||||
| ## 0.20.12 | ||||
|  | ||||
| **It is experimental migration onto new gradle version. Be careful in use of this version** | ||||
|  | ||||
| **This update have JDK 17 in `compatibility` and `target` versions** | ||||
|  | ||||
| ## 0.20.11 | ||||
|  | ||||
| * `Versions`: | ||||
|     * `Kotlin`: `1.9.20-RC2` -> `1.9.20` | ||||
|     * `Exposed`: `0.44.0` -> `0.44.1` | ||||
|     * `Compose`: `1.5.10-rc02` -> `1.5.10` | ||||
| * `Coroutines`: | ||||
|     * `SmartRWLocker` now will wait first unlock of write mutex for acquiring read | ||||
|  | ||||
| ## 0.20.10 | ||||
|  | ||||
| * `Versions`: | ||||
|     * `Kotlin`: `1.9.20-RC` -> `1.9.20-RC1` | ||||
|     * `KSLog`: `1.2.1` -> `1.2.2` | ||||
|     * `Compose`: `1.5.10-rc01` -> `1.5.10-rc02` | ||||
|     * `RecyclerView`: `1.3.1` -> `1.3.2` | ||||
|  | ||||
| ## 0.20.9 | ||||
|  | ||||
| * Most of common modules now supports `linuxArm64` target | ||||
|  | ||||
| ## 0.20.8 | ||||
|  | ||||
| **THIS VERSION CONTAINS UPDATES OF DEPENDENCIES UP TO RC VERSIONS. USE WITH CAUTION** | ||||
|  | ||||
| * `Versions`: | ||||
|     * `Kotlin`: `1.9.20-Beta2` -> `1.9.20-RC` | ||||
|     * `Compose`: `1.5.10-beta02` -> `1.5.10-rc01` | ||||
|  | ||||
| ## 0.20.7 | ||||
|  | ||||
| **THIS VERSION CONTAINS UPDATES OF DEPENDENCIES UP TO BETA VERSIONS. USE WITH CAUTION** | ||||
|  | ||||
| * `Versions`: | ||||
|     * `Kotlin`: `1.9.10` -> `1.9.20-Beta2` | ||||
|     * `Compose`: `1.5.1` -> `1.5.10-beta02` | ||||
|     * `Exposed`: `0.43.0` -> `0.44.0` | ||||
|     * `Ktor`: `2.3.4` -> `2.3.5` | ||||
|     * `Koin`: `3.4.3` -> `3.5.0` | ||||
|     * `Okio`: `3.5.0` -> `3.6.0` | ||||
|     * `Android Core`: `1.10.1` -> `1.12.0` | ||||
|     * `Android Compose Material`: `1.1.1` -> `1.1.2` | ||||
|  | ||||
| ## 0.20.6 | ||||
|  | ||||
| * `Repos`: | ||||
|     * `Exposed` | ||||
|         * Fixes in exposed key-values repos | ||||
|  | ||||
| ## 0.20.5 | ||||
|  | ||||
| * `Coroutines`: | ||||
|   | ||||
| @@ -27,7 +27,7 @@ allprojects { | ||||
|         mavenCentral() | ||||
|         google() | ||||
|         maven { url "https://maven.pkg.jetbrains.space/public/p/compose/dev" } | ||||
|         maven { url "https://git.inmo.dev/api/packages/InsanusMokrassar/maven" } | ||||
|         maven { url "https://nexus.inmo.dev/repository/maven-releases/" } | ||||
|     } | ||||
|  | ||||
|     // temporal crutch until legacy tests will be stabled or legacy target will be removed | ||||
|   | ||||
| @@ -4,7 +4,7 @@ plugins { | ||||
|     id "com.android.library" | ||||
| } | ||||
|  | ||||
| apply from: "$mppProjectWithSerializationPresetPath" | ||||
| apply from: "$mppJvmJsAndroidLinuxMingwLinuxArm64ProjectPresetPath" | ||||
|  | ||||
| kotlin { | ||||
|     sourceSets { | ||||
| @@ -31,5 +31,10 @@ kotlin { | ||||
|                 api libs.okio | ||||
|             } | ||||
|         } | ||||
|         linuxArm64Main { | ||||
|             dependencies { | ||||
|                 api libs.okio | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| } | ||||
|   | ||||
							
								
								
									
										36
									
								
								common/src/linuxArm64Main/kotlin/ActualMPPFile.kt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										36
									
								
								common/src/linuxArm64Main/kotlin/ActualMPPFile.kt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,36 @@ | ||||
| package dev.inmo.micro_utils.common | ||||
|  | ||||
| import okio.FileSystem | ||||
| import okio.Path | ||||
| import okio.use | ||||
|  | ||||
| actual typealias MPPFile = Path | ||||
|  | ||||
| /** | ||||
|  * @suppress | ||||
|  */ | ||||
| actual val MPPFile.filename: FileName | ||||
|     get() = FileName(toString()) | ||||
| /** | ||||
|  * @suppress | ||||
|  */ | ||||
| actual val MPPFile.filesize: Long | ||||
|     get() = FileSystem.SYSTEM.openReadOnly(this).use { | ||||
|         it.size() | ||||
|     } | ||||
| /** | ||||
|  * @suppress | ||||
|  */ | ||||
| actual val MPPFile.bytesAllocatorSync: ByteArrayAllocator | ||||
|     get() = { | ||||
|         FileSystem.SYSTEM.read(this) { | ||||
|             readByteArray() | ||||
|         } | ||||
|     } | ||||
| /** | ||||
|  * @suppress | ||||
|  */ | ||||
| actual val MPPFile.bytesAllocator: SuspendByteArrayAllocator | ||||
|     get() = { | ||||
|         bytesAllocatorSync() | ||||
|     } | ||||
							
								
								
									
										25
									
								
								common/src/linuxArm64Main/kotlin/fixed.kt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										25
									
								
								common/src/linuxArm64Main/kotlin/fixed.kt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,25 @@ | ||||
| package dev.inmo.micro_utils.common | ||||
|  | ||||
| import kotlinx.cinterop.* | ||||
| import platform.posix.snprintf | ||||
| import platform.posix.sprintf | ||||
|  | ||||
| @OptIn(ExperimentalForeignApi::class) | ||||
| actual fun Float.fixed(signs: Int): Float { | ||||
|     return memScoped { | ||||
|         val buff = allocArray<ByteVar>(Float.SIZE_BYTES * 2) | ||||
|  | ||||
|         sprintf(buff, "%.${signs}f", this@fixed) | ||||
|         buff.toKString().toFloat() | ||||
|     } | ||||
| } | ||||
|  | ||||
| @OptIn(ExperimentalForeignApi::class) | ||||
| actual fun Double.fixed(signs: Int): Double { | ||||
|     return memScoped { | ||||
|         val buff = allocArray<ByteVar>(Double.SIZE_BYTES * 2) | ||||
|  | ||||
|         sprintf(buff, "%.${signs}f", this@fixed) | ||||
|         buff.toKString().toDouble() | ||||
|     } | ||||
| } | ||||
| @@ -4,7 +4,7 @@ plugins { | ||||
|     id "com.android.library" | ||||
| } | ||||
|  | ||||
| apply from: "$mppProjectWithSerializationPresetPath" | ||||
| apply from: "$mppJvmJsAndroidLinuxMingwLinuxArm64ProjectPresetPath" | ||||
|  | ||||
| kotlin { | ||||
|     sourceSets { | ||||
|   | ||||
| @@ -0,0 +1,46 @@ | ||||
| package dev.inmo.micro_utils.coroutines.compose | ||||
|  | ||||
| import androidx.compose.runtime.MutableState | ||||
| import dev.inmo.micro_utils.coroutines.SpecialMutableStateFlow | ||||
| import kotlinx.coroutines.CoroutineScope | ||||
| import kotlinx.coroutines.Dispatchers | ||||
|  | ||||
| /** | ||||
|  * This type works like [MutableState], [kotlinx.coroutines.flow.StateFlow] and [kotlinx.coroutines.flow.MutableSharedFlow]. | ||||
|  * Based on [SpecialMutableStateFlow] | ||||
|  */ | ||||
| @Deprecated("Will be removed soon") | ||||
| class FlowState<T>( | ||||
|     initial: T, | ||||
|     internalScope: CoroutineScope = CoroutineScope(Dispatchers.Default) | ||||
| ) : MutableState<T>, | ||||
|     SpecialMutableStateFlow<T>(initial, internalScope) { | ||||
|     private var internalValue: T = initial | ||||
|     override var value: T | ||||
|         get() = internalValue | ||||
|         set(value) { | ||||
|             internalValue = value | ||||
|             tryEmit(value) | ||||
|         } | ||||
|  | ||||
|     override fun onChangeWithoutSync(value: T) { | ||||
|         internalValue = value | ||||
|         super.onChangeWithoutSync(value) | ||||
|     } | ||||
|  | ||||
|     override fun component1(): T = value | ||||
|  | ||||
|     override fun component2(): (T) -> Unit = { tryEmit(it) } | ||||
|  | ||||
|     override fun tryEmit(value: T): Boolean { | ||||
|         internalValue = value | ||||
|         return super.tryEmit(value) | ||||
|     } | ||||
|  | ||||
|     override suspend fun emit(value: T) { | ||||
|         internalValue = value | ||||
|         super.emit(value) | ||||
|     } | ||||
| } | ||||
|  | ||||
| //fun <T> MutableState<T>.asFlowState(scope: CoroutineScope = CoroutineScope(Dispatchers.Main)) = FlowState(this, scope) | ||||
| @@ -23,6 +23,7 @@ class SmartRWLocker(private val readPermits: Int = Int.MAX_VALUE, writeIsLocked: | ||||
|      * Do lock in [readSemaphore] inside of [writeMutex] locking | ||||
|      */ | ||||
|     suspend fun acquireRead() { | ||||
|         _writeMutex.waitUnlock() | ||||
|         _readSemaphore.acquire() | ||||
|     } | ||||
|  | ||||
|   | ||||
| @@ -0,0 +1,86 @@ | ||||
| package dev.inmo.micro_utils.coroutines | ||||
|  | ||||
| import kotlinx.coroutines.CoroutineScope | ||||
| import kotlinx.coroutines.Dispatchers | ||||
| import kotlinx.coroutines.ExperimentalCoroutinesApi | ||||
| import kotlinx.coroutines.InternalCoroutinesApi | ||||
| import kotlinx.coroutines.channels.BufferOverflow | ||||
| import kotlinx.coroutines.flow.FlowCollector | ||||
| import kotlinx.coroutines.flow.MutableSharedFlow | ||||
| import kotlinx.coroutines.flow.MutableStateFlow | ||||
| import kotlinx.coroutines.flow.StateFlow | ||||
| import kotlinx.coroutines.internal.SynchronizedObject | ||||
| import kotlinx.coroutines.internal.synchronized | ||||
|  | ||||
| /** | ||||
|  * Works like [StateFlow], but guarantee that latest value update will always be delivered to | ||||
|  * each active subscriber | ||||
|  */ | ||||
| open class SpecialMutableStateFlow<T>( | ||||
|     initialValue: T, | ||||
|     internalScope: CoroutineScope = CoroutineScope(Dispatchers.Default) | ||||
| ) : MutableStateFlow<T>, FlowCollector<T>, MutableSharedFlow<T> { | ||||
|     @OptIn(InternalCoroutinesApi::class) | ||||
|     private val syncObject = SynchronizedObject() | ||||
|     protected val internalSharedFlow: MutableSharedFlow<T> = MutableSharedFlow( | ||||
|         replay = 0, | ||||
|         extraBufferCapacity = 2, | ||||
|         onBufferOverflow = BufferOverflow.DROP_OLDEST | ||||
|     ) | ||||
|     protected val publicSharedFlow: MutableSharedFlow<T> = MutableSharedFlow( | ||||
|         replay = 1, | ||||
|         extraBufferCapacity = 1, | ||||
|         onBufferOverflow = BufferOverflow.DROP_OLDEST | ||||
|     ) | ||||
|  | ||||
|     protected var _value: T = initialValue | ||||
|     override var value: T | ||||
|         get() = _value | ||||
|         set(value) { | ||||
|             doOnChangeAction(value) | ||||
|         } | ||||
|     protected val job = internalSharedFlow.subscribe(internalScope) { | ||||
|         doOnChangeAction(it) | ||||
|     } | ||||
|  | ||||
|     override val replayCache: List<T> | ||||
|         get() = publicSharedFlow.replayCache | ||||
|     override val subscriptionCount: StateFlow<Int> | ||||
|         get() = publicSharedFlow.subscriptionCount | ||||
|  | ||||
|     @OptIn(InternalCoroutinesApi::class) | ||||
|     override fun compareAndSet(expect: T, update: T): Boolean { | ||||
|         return synchronized(syncObject) { | ||||
|             if (expect == _value && update != _value) { | ||||
|                 doOnChangeAction(update) | ||||
|             } | ||||
|             expect == _value | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     protected open fun onChangeWithoutSync(value: T) { | ||||
|         _value = value | ||||
|         publicSharedFlow.tryEmit(value) | ||||
|     } | ||||
|     @OptIn(InternalCoroutinesApi::class) | ||||
|     protected open fun doOnChangeAction(value: T) { | ||||
|         synchronized(syncObject) { | ||||
|             if (_value != value) { | ||||
|                 onChangeWithoutSync(value) | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     @ExperimentalCoroutinesApi | ||||
|     override fun resetReplayCache() = publicSharedFlow.resetReplayCache() | ||||
|  | ||||
|     override fun tryEmit(value: T): Boolean { | ||||
|         return internalSharedFlow.tryEmit(value) | ||||
|     } | ||||
|  | ||||
|     override suspend fun emit(value: T) { | ||||
|         internalSharedFlow.emit(value) | ||||
|     } | ||||
|  | ||||
|     override suspend fun collect(collector: FlowCollector<T>) = publicSharedFlow.collect(collector) | ||||
| } | ||||
| @@ -4,7 +4,7 @@ plugins { | ||||
|     id "com.android.library" | ||||
| } | ||||
|  | ||||
| apply from: "$mppProjectWithSerializationPresetPath" | ||||
| apply from: "$mppJvmJsAndroidLinuxMingwLinuxArm64ProjectPresetPath" | ||||
|  | ||||
| kotlin { | ||||
|     sourceSets { | ||||
|   | ||||
| @@ -27,7 +27,7 @@ android { | ||||
|     } | ||||
|  | ||||
|     compileOptions { | ||||
|         sourceCompatibility JavaVersion.VERSION_1_8 | ||||
|         targetCompatibility JavaVersion.VERSION_1_8 | ||||
|         sourceCompatibility JavaVersion.VERSION_17 | ||||
|         targetCompatibility JavaVersion.VERSION_17 | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -19,11 +19,19 @@ allprojects { | ||||
|         } | ||||
|  | ||||
|         releaseMode = (project.hasProperty('RELEASE_MODE') && project.property('RELEASE_MODE') == "true") || System.getenv('RELEASE_MODE') == "true" | ||||
| //        String compilerPluginVersionFromProperties = (String) project.properties["compose.kotlinCompilerPluginVersion"] | ||||
| //        String compilerPluginVersionFromLibrariesVersions = libs.versions.compose.kotlin.get() | ||||
| //        composePluginKotlinVersion = compilerPluginVersionFromProperties | ||||
| //        if (compilerPluginVersionFromProperties == null) { | ||||
| //            composePluginKotlinVersion = compilerPluginVersionFromLibrariesVersions | ||||
| //        } | ||||
|  | ||||
|         mppProjectWithSerializationPresetPath = "${rootProject.projectDir.absolutePath}/mppProjectWithSerialization.gradle" | ||||
|         mppProjectWithSerializationPresetPath = "${rootProject.projectDir.absolutePath}/mppJvmJsAndroidProject.gradle" | ||||
|         mppProjectWithSerializationAndComposePresetPath = "${rootProject.projectDir.absolutePath}/mppProjectWithSerializationAndCompose.gradle" | ||||
|         mppJavaProjectPresetPath = "${rootProject.projectDir.absolutePath}/mppJavaProject.gradle" | ||||
|         mppJvmJsLinuxMingwProjectPresetPath = "${rootProject.projectDir.absolutePath}/mppJvmJsLinuxMingwProject.gradle" | ||||
|         mppJvmJsLinuxMingwLinuxArm64ProjectPresetPath = "${rootProject.projectDir.absolutePath}/mppJvmJsLinuxMingwLinuxArm64Project.gradle" | ||||
|         mppJvmJsAndroidLinuxMingwLinuxArm64ProjectPresetPath = "${rootProject.projectDir.absolutePath}/mppJvmJsAndroidLinuxMingwLinuxArm64Project.gradle" | ||||
|         mppAndroidProjectPresetPath = "${rootProject.projectDir.absolutePath}/mppAndroidProject.gradle" | ||||
|  | ||||
|         defaultAndroidSettingsPresetPath = "${rootProject.projectDir.absolutePath}/defaultAndroidSettings.gradle" | ||||
|   | ||||
| @@ -4,7 +4,7 @@ plugins { | ||||
|     id "com.android.library" | ||||
| } | ||||
|  | ||||
| apply from: "$mppProjectWithSerializationPresetPath" | ||||
| apply from: "$mppJvmJsAndroidLinuxMingwLinuxArm64ProjectPresetPath" | ||||
|  | ||||
| kotlin { | ||||
|     sourceSets { | ||||
|   | ||||
| @@ -4,7 +4,7 @@ plugins { | ||||
|     id "com.android.library" | ||||
| } | ||||
|  | ||||
| apply from: "$mppProjectWithSerializationPresetPath" | ||||
| apply from: "$mppJvmJsAndroidLinuxMingwLinuxArm64ProjectPresetPath" | ||||
|  | ||||
| kotlin { | ||||
|     sourceSets { | ||||
|   | ||||
| @@ -6,7 +6,7 @@ kotlin.incremental.js=true | ||||
| #kotlin.experimental.tryK2=true | ||||
| android.useAndroidX=true | ||||
| android.enableJetifier=true | ||||
| org.gradle.jvmargs=-Xmx2g | ||||
| org.gradle.jvmargs=-Xmx2g -XX:MaxMetaspaceSize=2g | ||||
|  | ||||
| # JS NPM | ||||
|  | ||||
| @@ -15,5 +15,5 @@ crypto_js_version=4.1.1 | ||||
| # Project data | ||||
|  | ||||
| group=dev.inmo | ||||
| version=0.20.5 | ||||
| android_code_version=211 | ||||
| version=0.20.21 | ||||
| android_code_version=227 | ||||
|   | ||||
| @@ -1,41 +1,41 @@ | ||||
| [versions] | ||||
|  | ||||
| kt = "1.9.10" | ||||
| kt-serialization = "1.6.0" | ||||
| kt = "1.9.21" | ||||
| kt-serialization = "1.6.2" | ||||
| kt-coroutines = "1.7.3" | ||||
|  | ||||
| kslog = "1.2.1" | ||||
| kslog = "1.3.1" | ||||
|  | ||||
| jb-compose = "1.5.1" | ||||
| jb-exposed = "0.43.0" | ||||
| jb-dokka = "1.9.0" | ||||
| jb-compose = "1.5.11" | ||||
| jb-exposed = "0.45.0" | ||||
| jb-dokka = "1.9.10" | ||||
|  | ||||
| korlibs = "4.0.10" | ||||
| uuid = "0.8.1" | ||||
| uuid = "0.8.2" | ||||
|  | ||||
| ktor = "2.3.4" | ||||
| ktor = "2.3.7" | ||||
|  | ||||
| gh-release = "2.4.1" | ||||
|  | ||||
| koin = "3.4.3" | ||||
| koin = "3.5.0" | ||||
|  | ||||
| okio = "3.5.0" | ||||
| okio = "3.6.0" | ||||
|  | ||||
| ksp = "1.9.10-1.0.13" | ||||
| kotlin-poet = "1.14.2" | ||||
| ksp = "1.9.21-1.0.15" | ||||
| kotlin-poet = "1.15.3" | ||||
|  | ||||
| versions = "0.47.0" | ||||
| versions = "0.50.0" | ||||
|  | ||||
| android-gradle = "7.4.2" | ||||
| android-gradle = "8.2.0" | ||||
| dexcount = "4.0.0" | ||||
|  | ||||
| android-coreKtx = "1.10.1" | ||||
| android-recyclerView = "1.3.1" | ||||
| android-coreKtx = "1.12.0" | ||||
| android-recyclerView = "1.3.2" | ||||
| android-appCompat = "1.6.1" | ||||
| android-fragment = "1.6.1" | ||||
| android-fragment = "1.6.2" | ||||
| android-espresso = "3.5.1" | ||||
| android-test = "1.1.5" | ||||
| android-compose-material3 = "1.1.1" | ||||
| android-compose-material3 = "1.1.2" | ||||
|  | ||||
| android-props-minSdk = "21" | ||||
| android-props-compileSdk = "34" | ||||
|   | ||||
							
								
								
									
										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-7.6.2-bin.zip | ||||
| distributionUrl=https\://services.gradle.org/distributions/gradle-8.5-bin.zip | ||||
| zipStoreBase=GRADLE_USER_HOME | ||||
| zipStorePath=wrapper/dists | ||||
|   | ||||
| @@ -2,11 +2,11 @@ apply plugin: 'maven-publish' | ||||
|  | ||||
| task javadocJar(type: Jar) { | ||||
|     from javadoc | ||||
|     classifier = 'javadoc' | ||||
|     archiveClassifier = 'javadoc' | ||||
| } | ||||
| task sourcesJar(type: Jar) { | ||||
|     from sourceSets.main.allSource | ||||
|     classifier = 'sources' | ||||
|     archiveClassifier = 'sources' | ||||
| } | ||||
|  | ||||
| publishing { | ||||
| @@ -68,18 +68,14 @@ publishing { | ||||
|                  | ||||
|                     } | ||||
|                 } | ||||
|                 if (project.hasProperty('GITEA_TOKEN') || System.getenv('GITEA_TOKEN') != null) { | ||||
|                 if ((project.hasProperty('INMONEXUS_USER') || System.getenv('INMONEXUS_USER') != null) && (project.hasProperty('INMONEXUS_PASSWORD') || System.getenv('INMONEXUS_PASSWORD') != null)) { | ||||
|                     maven { | ||||
|                         name = "Gitea" | ||||
|                         url = uri("https://git.inmo.dev/api/packages/InsanusMokrassar/maven") | ||||
|                         name = "InmoNexus" | ||||
|                         url = uri("https://nexus.inmo.dev/repository/maven-releases/") | ||||
|                  | ||||
|                         credentials(HttpHeaderCredentials) { | ||||
|                             name = "Authorization" | ||||
|                             value = project.hasProperty('GITEA_TOKEN') ? project.property('GITEA_TOKEN') : System.getenv('GITEA_TOKEN') | ||||
|                         } | ||||
|                  | ||||
|                         authentication { | ||||
|                             header(HttpHeaderAuthentication) | ||||
|                         credentials { | ||||
|                             username = project.hasProperty('INMONEXUS_USER') ? project.property('INMONEXUS_USER') : System.getenv('INMONEXUS_USER') | ||||
|                             password = project.hasProperty('INMONEXUS_PASSWORD') ? project.property('INMONEXUS_PASSWORD') : System.getenv('INMONEXUS_PASSWORD') | ||||
|                         } | ||||
|                  | ||||
|                     } | ||||
| @@ -115,4 +111,27 @@ if (project.hasProperty("signing.gnupg.keyName")) { | ||||
|             dependsOn(it) | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     // Workaround to make android sign operations depend on signing tasks | ||||
|     project.getTasks().withType(AbstractPublishToMaven.class).configureEach { | ||||
|         def signingTasks = project.getTasks().withType(Sign.class) | ||||
|         mustRunAfter(signingTasks) | ||||
|     } | ||||
|     // Workaround to make test tasks use sign | ||||
|     project.getTasks().withType(Sign.class).configureEach { signTask -> | ||||
|         def withoutSign = (signTask.name.startsWith("sign") ? signTask.name.minus("sign") : signTask.name) | ||||
|         def pubName = withoutSign.endsWith("Publication") ? withoutSign.substring(0, withoutSign.length() - "Publication".length()) : withoutSign | ||||
|         // These tasks only exist for native targets, hence findByName() to avoid trying to find them for other targets | ||||
|  | ||||
|         // Task ':linkDebugTest<platform>' uses this output of task ':sign<platform>Publication' without declaring an explicit or implicit dependency | ||||
|         def debugTestTask = tasks.findByName("linkDebugTest$pubName") | ||||
|         if (debugTestTask != null) { | ||||
|             signTask.mustRunAfter(debugTestTask) | ||||
|         } | ||||
|         // Task ':compileTestKotlin<platform>' uses this output of task ':sign<platform>Publication' without declaring an explicit or implicit dependency | ||||
|         def testTask = tasks.findByName("compileTestKotlin$pubName") | ||||
|         if (testTask != null) { | ||||
|             signTask.mustRunAfter(testTask) | ||||
|         } | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -1 +1 @@ | ||||
| {"licenses":[{"id":"Apache-2.0","title":"Apache Software License 2.0","url":"https://github.com/InsanusMokrassar/MicroUtils/blob/master/LICENSE"}],"mavenConfig":{"name":"${project.name}","description":"It is set of projects with micro tools for avoiding of routines coding","url":"https://github.com/InsanusMokrassar/MicroUtils/","vcsUrl":"https://github.com/InsanusMokrassar/MicroUtils.git","developers":[{"id":"InsanusMokrassar","name":"Aleksei Ovsiannikov","eMail":"ovsyannikov.alexey95@gmail.com"},{"id":"000Sanya","name":"Syrov Aleksandr","eMail":"000sanya.000sanya@gmail.com"}],"repositories":[{"name":"GithubPackages","url":"https://maven.pkg.github.com/InsanusMokrassar/MicroUtils"},{"name":"Gitea","url":"https://git.inmo.dev/api/packages/InsanusMokrassar/maven","credsType":{"type":"dev.inmo.kmppscriptbuilder.core.models.MavenPublishingRepository.CredentialsType.HttpHeaderCredentials","headerName":"Authorization","headerValueProperty":"GITEA_TOKEN"}},{"name":"sonatype","url":"https://oss.sonatype.org/service/local/staging/deploy/maven2/"}],"gpgSigning":{"type":"dev.inmo.kmppscriptbuilder.core.models.GpgSigning.Optional"}},"type":"JVM"} | ||||
| {"licenses":[{"id":"Apache-2.0","title":"Apache Software License 2.0","url":"https://github.com/InsanusMokrassar/MicroUtils/blob/master/LICENSE"}],"mavenConfig":{"name":"${project.name}","description":"It is set of projects with micro tools for avoiding of routines coding","url":"https://github.com/InsanusMokrassar/MicroUtils/","vcsUrl":"https://github.com/InsanusMokrassar/MicroUtils.git","developers":[{"id":"InsanusMokrassar","name":"Aleksei Ovsiannikov","eMail":"ovsyannikov.alexey95@gmail.com"},{"id":"000Sanya","name":"Syrov Aleksandr","eMail":"000sanya.000sanya@gmail.com"}],"repositories":[{"name":"GithubPackages","url":"https://maven.pkg.github.com/InsanusMokrassar/MicroUtils"},{"name":"InmoNexus","url":"https://nexus.inmo.dev/repository/maven-releases/"},{"name":"sonatype","url":"https://oss.sonatype.org/service/local/staging/deploy/maven2/"}],"gpgSigning":{"type":"dev.inmo.kmppscriptbuilder.core.models.GpgSigning.Optional"}},"type":"JVM"} | ||||
| @@ -15,6 +15,6 @@ dependencies { | ||||
| } | ||||
|  | ||||
| java { | ||||
|     sourceCompatibility = JavaVersion.VERSION_1_8 | ||||
|     targetCompatibility = JavaVersion.VERSION_1_8 | ||||
|     sourceCompatibility = JavaVersion.VERSION_17 | ||||
|     targetCompatibility = JavaVersion.VERSION_17 | ||||
| } | ||||
|   | ||||
| @@ -4,7 +4,7 @@ plugins { | ||||
|     id "com.android.library" | ||||
| } | ||||
|  | ||||
| apply from: "$mppProjectWithSerializationPresetPath" | ||||
| apply from: "$mppJvmJsAndroidLinuxMingwLinuxArm64ProjectPresetPath" | ||||
|  | ||||
| kotlin { | ||||
|     sourceSets { | ||||
| @@ -30,5 +30,11 @@ kotlin { | ||||
|                 api internalProject("micro_utils.mime_types") | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         linuxArm64Main { | ||||
|             dependencies { | ||||
|                 api internalProject("micro_utils.mime_types") | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -0,0 +1,40 @@ | ||||
| package dev.inmo.micro_utils.ktor.client | ||||
|  | ||||
| import dev.inmo.micro_utils.common.MPPFile | ||||
| import dev.inmo.micro_utils.common.filename | ||||
| import dev.inmo.micro_utils.ktor.common.TemporalFileId | ||||
| import dev.inmo.micro_utils.mime_types.getMimeTypeOrAny | ||||
| import io.ktor.client.HttpClient | ||||
| import io.ktor.client.plugins.onUpload | ||||
| import io.ktor.client.request.forms.formData | ||||
| import io.ktor.client.request.forms.submitFormWithBinaryData | ||||
| import io.ktor.client.statement.bodyAsText | ||||
| import io.ktor.http.Headers | ||||
| import io.ktor.http.HttpHeaders | ||||
|  | ||||
| internal val MPPFile.mimeType: String | ||||
|     get() = getMimeTypeOrAny(filename.extension).raw | ||||
|  | ||||
| actual suspend fun HttpClient.tempUpload( | ||||
|     fullTempUploadDraftPath: String, | ||||
|     file: MPPFile, | ||||
|     onUpload: OnUploadCallback | ||||
| ): TemporalFileId { | ||||
|     val inputProvider = file.inputProvider() | ||||
|     val fileId = submitFormWithBinaryData( | ||||
|         fullTempUploadDraftPath, | ||||
|         formData = formData { | ||||
|             append( | ||||
|                 "data", | ||||
|                 inputProvider, | ||||
|                 Headers.build { | ||||
|                     append(HttpHeaders.ContentType, file.mimeType) | ||||
|                     append(HttpHeaders.ContentDisposition, "filename=\"${file.filename.string}\"") | ||||
|                 } | ||||
|             ) | ||||
|         } | ||||
|     ) { | ||||
|         onUpload(onUpload) | ||||
|     }.bodyAsText() | ||||
|     return TemporalFileId(fileId) | ||||
| } | ||||
							
								
								
									
										107
									
								
								ktor/client/src/linuxArm64Main/kotlin/ActualUniUpload.kt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										107
									
								
								ktor/client/src/linuxArm64Main/kotlin/ActualUniUpload.kt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,107 @@ | ||||
| package dev.inmo.micro_utils.ktor.client | ||||
|  | ||||
| import dev.inmo.micro_utils.common.MPPFile | ||||
| import dev.inmo.micro_utils.common.Progress | ||||
| import io.ktor.client.HttpClient | ||||
| import io.ktor.client.engine.mergeHeaders | ||||
| import io.ktor.client.plugins.onUpload | ||||
| import io.ktor.client.request.HttpRequestBuilder | ||||
| import io.ktor.client.request.forms.InputProvider | ||||
| import io.ktor.client.request.forms.formData | ||||
| import io.ktor.client.request.forms.submitForm | ||||
| import io.ktor.client.request.forms.submitFormWithBinaryData | ||||
| import io.ktor.client.request.headers | ||||
| import io.ktor.client.statement.bodyAsText | ||||
| import io.ktor.http.Headers | ||||
| import io.ktor.http.HttpHeaders | ||||
| import io.ktor.http.HttpStatusCode | ||||
| import io.ktor.http.Parameters | ||||
| import io.ktor.http.content.PartData | ||||
| import kotlinx.serialization.DeserializationStrategy | ||||
| import kotlinx.serialization.InternalSerializationApi | ||||
| import kotlinx.serialization.SerializationStrategy | ||||
| import kotlinx.serialization.StringFormat | ||||
| import kotlinx.serialization.encodeToString | ||||
| import kotlinx.serialization.serializer | ||||
|  | ||||
| /** | ||||
|  * Will execute submitting of multipart data request | ||||
|  * | ||||
|  * @param data [Map] where keys will be used as names for multipart parts and values as values. If you will pass | ||||
|  * [dev.inmo.micro_utils.common.MPPFile] (File from JS or JVM platform). Also you may pass [UniUploadFileInfo] as value | ||||
|  * in case you wish to pass other source of multipart binary data than regular file | ||||
|  * @suppress | ||||
|  */ | ||||
| @OptIn(InternalSerializationApi::class) | ||||
| actual suspend fun <T> HttpClient.uniUpload( | ||||
|     url: String, | ||||
|     data: Map<String, Any>, | ||||
|     resultDeserializer: DeserializationStrategy<T>, | ||||
|     headers: Headers, | ||||
|     stringFormat: StringFormat, | ||||
|     onUpload: OnUploadCallback | ||||
| ): T? { | ||||
|     val withBinary = data.values.any { it is MPPFile || it is UniUploadFileInfo } | ||||
|  | ||||
|     val formData = formData { | ||||
|         for (k in data.keys) { | ||||
|             val v = data[k] ?: continue | ||||
|             when (v) { | ||||
|                 is MPPFile -> append( | ||||
|                     k, | ||||
|                     v.inputProvider(), | ||||
|                     Headers.build { | ||||
|                         append(HttpHeaders.ContentType, v.mimeType) | ||||
|                         append(HttpHeaders.ContentDisposition, "filename=\"${v.name}\"") | ||||
|                     } | ||||
|                 ) | ||||
|                 is UniUploadFileInfo -> append( | ||||
|                     k, | ||||
|                     InputProvider(block = v.inputAllocator), | ||||
|                     Headers.build { | ||||
|                         append(HttpHeaders.ContentType, v.mimeType) | ||||
|                         append(HttpHeaders.ContentDisposition, "filename=\"${v.fileName.name}\"") | ||||
|                     } | ||||
|                 ) | ||||
|                 else -> append( | ||||
|                     k, | ||||
|                     stringFormat.encodeToString(v::class.serializer() as SerializationStrategy<in Any>, v) | ||||
|                 ) | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     val requestBuilder: HttpRequestBuilder.() -> Unit = { | ||||
|         headers { | ||||
|             appendAll(headers) | ||||
|         } | ||||
|         onUpload { bytesSentTotal, contentLength -> | ||||
|             onUpload(bytesSentTotal, contentLength) | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     val response = if (withBinary) { | ||||
|         submitFormWithBinaryData( | ||||
|             url, | ||||
|             formData, | ||||
|             block = requestBuilder | ||||
|         ) | ||||
|     } else { | ||||
|         submitForm( | ||||
|             url, | ||||
|             Parameters.build { | ||||
|                 for (it in formData) { | ||||
|                     val formItem = (it as PartData.FormItem) | ||||
|                     append(it.name!!, it.value) | ||||
|                 } | ||||
|             }, | ||||
|             block = requestBuilder | ||||
|         ) | ||||
|     } | ||||
|  | ||||
|     return if (response.status == HttpStatusCode.OK) { | ||||
|         stringFormat.decodeFromString(resultDeserializer, response.bodyAsText()) | ||||
|     } else { | ||||
|         null | ||||
|     } | ||||
| } | ||||
| @@ -4,7 +4,7 @@ plugins { | ||||
|     id "com.android.library" | ||||
| } | ||||
|  | ||||
| apply from: "$mppProjectWithSerializationPresetPath" | ||||
| apply from: "$mppJvmJsAndroidLinuxMingwLinuxArm64ProjectPresetPath" | ||||
|  | ||||
| kotlin { | ||||
|     sourceSets { | ||||
|   | ||||
							
								
								
									
										11
									
								
								ktor/common/src/linuxArm64Main/kotlin/ActualMPPFileInput.kt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								ktor/common/src/linuxArm64Main/kotlin/ActualMPPFileInput.kt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,11 @@ | ||||
| package dev.inmo.micro_utils.ktor.common | ||||
|  | ||||
| import dev.inmo.micro_utils.common.MPPFile | ||||
| import dev.inmo.micro_utils.common.bytesAllocatorSync | ||||
| import io.ktor.utils.io.core.ByteReadPacket | ||||
| import io.ktor.utils.io.core.Input | ||||
|  | ||||
| actual fun MPPFile.input(): Input { | ||||
|     return ByteReadPacket(bytesAllocatorSync()) | ||||
| } | ||||
|  | ||||
| @@ -4,7 +4,7 @@ plugins { | ||||
|     id "com.android.library" | ||||
| } | ||||
|  | ||||
| apply from: "$mppProjectWithSerializationPresetPath" | ||||
| apply from: "$mppJvmJsAndroidLinuxMingwLinuxArm64ProjectPresetPath" | ||||
|  | ||||
| kotlin { | ||||
|     sourceSets { | ||||
|   | ||||
| @@ -26,6 +26,6 @@ dependencies { | ||||
| mainClassName="MainKt" | ||||
|  | ||||
| java { | ||||
|     sourceCompatibility = JavaVersion.VERSION_1_8 | ||||
|     targetCompatibility = JavaVersion.VERSION_1_8 | ||||
|     sourceCompatibility = JavaVersion.VERSION_17 | ||||
|     targetCompatibility = JavaVersion.VERSION_17 | ||||
| } | ||||
|   | ||||
| @@ -4,4 +4,4 @@ plugins { | ||||
|     id "com.android.library" | ||||
| } | ||||
|  | ||||
| apply from: "$mppProjectWithSerializationPresetPath" | ||||
| apply from: "$mppJvmJsAndroidLinuxMingwLinuxArm64ProjectPresetPath" | ||||
|   | ||||
| @@ -1,12 +1,15 @@ | ||||
| package dev.inmo.micro_utils.matrix | ||||
|  | ||||
| class MatrixBuilder<T> { | ||||
| open class MatrixBuilder<T> { | ||||
|     private val mutMatrix: MutableList<List<T>> = ArrayList() | ||||
|     val matrix: Matrix<T> | ||||
|         get() = mutMatrix | ||||
|  | ||||
|     fun row(t: List<T>) = mutMatrix.add(t) | ||||
|     fun add(t: List<T>) = mutMatrix.add(t) | ||||
|     operator fun List<T>.unaryPlus() = row(this) | ||||
|     operator fun plus(t: List<T>) = add(t) | ||||
|     operator fun T.unaryPlus() = add(listOf(this)) | ||||
| } | ||||
|  | ||||
| fun <T> MatrixBuilder<T>.row(block: RowBuilder<T>.() -> Unit) = +RowBuilder<T>().also(block).row | ||||
|   | ||||
| @@ -1,12 +1,13 @@ | ||||
| package dev.inmo.micro_utils.matrix | ||||
|  | ||||
| class RowBuilder<T> { | ||||
| open class RowBuilder<T> { | ||||
|     private val mutRow: MutableList<T> = ArrayList() | ||||
|     val row: Row<T> | ||||
|         get() = mutRow | ||||
|  | ||||
|     fun column(t: T) = mutRow.add(t) | ||||
|     fun add(t: T) = mutRow.add(t) | ||||
|     operator fun T.unaryPlus() = column(this) | ||||
|     fun column(t: T) = mutRow.add(t) | ||||
| } | ||||
|  | ||||
| fun <T> row(block: RowBuilder<T>.() -> Unit): List<T> = RowBuilder<T>().also(block).row | ||||
|   | ||||
| @@ -4,4 +4,4 @@ plugins { | ||||
|     id "com.android.library" | ||||
| } | ||||
|  | ||||
| apply from: "$mppProjectWithSerializationPresetPath" | ||||
| apply from: "$mppJvmJsAndroidLinuxMingwLinuxArm64ProjectPresetPath" | ||||
|   | ||||
| @@ -4,8 +4,13 @@ project.group = "$group" | ||||
| apply from: "$publishGradlePath" | ||||
|  | ||||
| kotlin { | ||||
|     android { | ||||
|     androidTarget { | ||||
|         publishAllLibraryVariants() | ||||
|         compilations.all { | ||||
|             kotlinOptions { | ||||
|                 jvmTarget = "17" | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     sourceSets { | ||||
| @@ -27,6 +32,6 @@ kotlin { | ||||
| apply from: "$defaultAndroidSettingsPresetPath" | ||||
|  | ||||
| java { | ||||
|     sourceCompatibility = JavaVersion.VERSION_1_8 | ||||
|     targetCompatibility = JavaVersion.VERSION_1_8 | ||||
|     sourceCompatibility = JavaVersion.VERSION_17 | ||||
|     targetCompatibility = JavaVersion.VERSION_17 | ||||
| } | ||||
|   | ||||
| @@ -7,7 +7,7 @@ kotlin { | ||||
|     jvm { | ||||
|         compilations.main { | ||||
|             kotlinOptions { | ||||
|                 jvmTarget = "1.8" | ||||
|                 jvmTarget = "17" | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| @@ -35,6 +35,6 @@ kotlin { | ||||
| } | ||||
|  | ||||
| java { | ||||
|     sourceCompatibility = JavaVersion.VERSION_1_8 | ||||
|     targetCompatibility = JavaVersion.VERSION_1_8 | ||||
|     sourceCompatibility = JavaVersion.VERSION_17 | ||||
|     targetCompatibility = JavaVersion.VERSION_17 | ||||
| } | ||||
|   | ||||
							
								
								
									
										71
									
								
								mppJvmJsAndroidLinuxMingwLinuxArm64Project.gradle
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										71
									
								
								mppJvmJsAndroidLinuxMingwLinuxArm64Project.gradle
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,71 @@ | ||||
| project.version = "$version" | ||||
| project.group = "$group" | ||||
|  | ||||
| apply from: "$publishGradlePath" | ||||
|  | ||||
| kotlin { | ||||
|     jvm { | ||||
|         compilations.main { | ||||
|             kotlinOptions { | ||||
|                 jvmTarget = "17" | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|     js (IR) { | ||||
|         browser() | ||||
|         nodejs() | ||||
|     } | ||||
|     androidTarget { | ||||
|         publishAllLibraryVariants() | ||||
|         compilations.all { | ||||
|             kotlinOptions { | ||||
|                 jvmTarget = "17" | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|     linuxX64() | ||||
|     mingwX64() | ||||
|     linuxArm64() | ||||
|  | ||||
|     sourceSets { | ||||
|         commonMain { | ||||
|             dependencies { | ||||
|                 implementation kotlin('stdlib') | ||||
|                 api libs.kt.serialization | ||||
|             } | ||||
|         } | ||||
|         commonTest { | ||||
|             dependencies { | ||||
|                 implementation kotlin('test-common') | ||||
|                 implementation kotlin('test-annotations-common') | ||||
|                 implementation libs.kt.coroutines.test | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         androidUnitTest { | ||||
|             dependencies { | ||||
|                 implementation kotlin('test-junit') | ||||
|                 implementation libs.android.test.junit | ||||
|                 implementation libs.android.espresso | ||||
|             } | ||||
|         } | ||||
|         jvmTest { | ||||
|             dependencies { | ||||
|                 implementation kotlin('test-junit') | ||||
|             } | ||||
|         } | ||||
|         jsTest { | ||||
|             dependencies { | ||||
|                 implementation kotlin('test-js') | ||||
|                 implementation kotlin('test-junit') | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| apply from: "$defaultAndroidSettingsPresetPath" | ||||
|  | ||||
| java { | ||||
|     sourceCompatibility = JavaVersion.VERSION_17 | ||||
|     targetCompatibility = JavaVersion.VERSION_17 | ||||
| } | ||||
| @@ -7,7 +7,7 @@ kotlin { | ||||
|     jvm { | ||||
|         compilations.main { | ||||
|             kotlinOptions { | ||||
|                 jvmTarget = "1.8" | ||||
|                 jvmTarget = "17" | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| @@ -15,8 +15,13 @@ kotlin { | ||||
|         browser() | ||||
|         nodejs() | ||||
|     } | ||||
|     android { | ||||
|     androidTarget { | ||||
|         publishAllLibraryVariants() | ||||
|         compilations.all { | ||||
|             kotlinOptions { | ||||
|                 jvmTarget = "17" | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|     linuxX64() | ||||
|     mingwX64() | ||||
| @@ -71,6 +76,6 @@ kotlin { | ||||
| apply from: "$defaultAndroidSettingsPresetPath" | ||||
| 
 | ||||
| java { | ||||
|     sourceCompatibility = JavaVersion.VERSION_1_8 | ||||
|     targetCompatibility = JavaVersion.VERSION_1_8 | ||||
|     sourceCompatibility = JavaVersion.VERSION_17 | ||||
|     targetCompatibility = JavaVersion.VERSION_17 | ||||
| } | ||||
							
								
								
									
										54
									
								
								mppJvmJsLinuxMingwLinuxArm64Project.gradle
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										54
									
								
								mppJvmJsLinuxMingwLinuxArm64Project.gradle
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,54 @@ | ||||
| project.version = "$version" | ||||
| project.group = "$group" | ||||
|  | ||||
| apply from: "$publishGradlePath" | ||||
|  | ||||
| kotlin { | ||||
|     jvm { | ||||
|         compilations.main { | ||||
|             kotlinOptions { | ||||
|                 jvmTarget = "17" | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|     js (IR) { | ||||
|         browser() | ||||
|         nodejs() | ||||
|     } | ||||
|     linuxX64() | ||||
|     mingwX64() | ||||
|     linuxArm64() | ||||
|  | ||||
|     sourceSets { | ||||
|         commonMain { | ||||
|             dependencies { | ||||
|                 implementation kotlin('stdlib') | ||||
|                 api libs.kt.serialization | ||||
|             } | ||||
|         } | ||||
|         commonTest { | ||||
|             dependencies { | ||||
|                 implementation kotlin('test-common') | ||||
|                 implementation kotlin('test-annotations-common') | ||||
|                 implementation libs.kt.coroutines.test | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         jvmTest { | ||||
|             dependencies { | ||||
|                 implementation kotlin('test-junit') | ||||
|             } | ||||
|         } | ||||
|         jsTest { | ||||
|             dependencies { | ||||
|                 implementation kotlin('test-js') | ||||
|                 implementation kotlin('test-junit') | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| java { | ||||
|     sourceCompatibility = JavaVersion.VERSION_17 | ||||
|     targetCompatibility = JavaVersion.VERSION_17 | ||||
| } | ||||
| @@ -7,7 +7,7 @@ kotlin { | ||||
|     jvm { | ||||
|         compilations.main { | ||||
|             kotlinOptions { | ||||
|                 jvmTarget = "1.8" | ||||
|                 jvmTarget = "17" | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| @@ -22,6 +22,7 @@ kotlin { | ||||
|         commonMain { | ||||
|             dependencies { | ||||
|                 implementation kotlin('stdlib') | ||||
|                 api libs.kt.serialization | ||||
|             } | ||||
|         } | ||||
|         commonTest { | ||||
| @@ -43,10 +44,22 @@ kotlin { | ||||
|                 implementation kotlin('test-junit') | ||||
|             } | ||||
|         } | ||||
|         mingwX64Test { | ||||
|             dependencies { | ||||
|                 implementation kotlin('test-junit') | ||||
|             } | ||||
|         } | ||||
|         linuxX64Test { | ||||
|             dependencies { | ||||
|                 implementation kotlin('test-junit') | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         androidMain.dependsOn jvmMain | ||||
|     } | ||||
| } | ||||
|  | ||||
| java { | ||||
|     sourceCompatibility = JavaVersion.VERSION_1_8 | ||||
|     targetCompatibility = JavaVersion.VERSION_1_8 | ||||
|     sourceCompatibility = JavaVersion.VERSION_17 | ||||
|     targetCompatibility = JavaVersion.VERSION_17 | ||||
| } | ||||
|   | ||||
| @@ -7,7 +7,7 @@ kotlin { | ||||
|     jvm { | ||||
|         compilations.main { | ||||
|             kotlinOptions { | ||||
|                 jvmTarget = "1.8" | ||||
|                 jvmTarget = "17" | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| @@ -15,8 +15,13 @@ kotlin { | ||||
|         browser() | ||||
|         nodejs() | ||||
|     } | ||||
|     android { | ||||
|     androidTarget { | ||||
|         publishAllLibraryVariants() | ||||
|         compilations.all { | ||||
|             kotlinOptions { | ||||
|                 jvmTarget = "17" | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     sourceSets { | ||||
| @@ -70,6 +75,13 @@ kotlin { | ||||
| apply from: "$defaultAndroidSettingsPresetPath" | ||||
|  | ||||
| java { | ||||
|     sourceCompatibility = JavaVersion.VERSION_1_8 | ||||
|     targetCompatibility = JavaVersion.VERSION_1_8 | ||||
|     sourceCompatibility = JavaVersion.VERSION_17 | ||||
|     targetCompatibility = JavaVersion.VERSION_17 | ||||
| } | ||||
|  | ||||
|  | ||||
| //compose { | ||||
| //    if (composePluginKotlinVersion != null && !composePluginKotlinVersion.isEmpty()) { | ||||
| //        kotlinCompilerPlugin.set(composePluginKotlinVersion) | ||||
| //    } | ||||
| //} | ||||
|   | ||||
| @@ -4,7 +4,7 @@ plugins { | ||||
|     id "com.android.library" | ||||
| } | ||||
|  | ||||
| apply from: "$mppProjectWithSerializationPresetPath" | ||||
| apply from: "$mppJvmJsAndroidLinuxMingwLinuxArm64ProjectPresetPath" | ||||
|  | ||||
| kotlin { | ||||
|     sourceSets { | ||||
|   | ||||
| @@ -4,7 +4,7 @@ plugins { | ||||
|     id "com.android.library" | ||||
| } | ||||
|  | ||||
| apply from: "$mppProjectWithSerializationPresetPath" | ||||
| apply from: "$mppJvmJsAndroidLinuxMingwLinuxArm64ProjectPresetPath" | ||||
|  | ||||
| kotlin { | ||||
|     sourceSets { | ||||
|   | ||||
| @@ -1,7 +1,7 @@ | ||||
| apply plugin: 'maven-publish' | ||||
|  | ||||
| task javadocsJar(type: Jar) { | ||||
|     classifier = 'javadoc' | ||||
|     archiveClassifier = 'javadoc' | ||||
| } | ||||
|  | ||||
| publishing { | ||||
| @@ -19,29 +19,29 @@ publishing { | ||||
|             } | ||||
|  | ||||
|             developers { | ||||
|  | ||||
|                  | ||||
|                     developer { | ||||
|                         id = "InsanusMokrassar" | ||||
|                         name = "Aleksei Ovsiannikov" | ||||
|                         email = "ovsyannikov.alexey95@gmail.com" | ||||
|                     } | ||||
|  | ||||
|                  | ||||
|  | ||||
|                     developer { | ||||
|                         id = "000Sanya" | ||||
|                         name = "Syrov Aleksandr" | ||||
|                         email = "000sanya.000sanya@gmail.com" | ||||
|                     } | ||||
|  | ||||
|                  | ||||
|             } | ||||
|  | ||||
|             licenses { | ||||
|  | ||||
|                  | ||||
|                     license { | ||||
|                         name = "Apache Software License 2.0" | ||||
|                         url = "https://github.com/InsanusMokrassar/MicroUtils/blob/master/LICENSE" | ||||
|                     } | ||||
|  | ||||
|                  | ||||
|             } | ||||
|         } | ||||
|         repositories { | ||||
| @@ -49,57 +49,77 @@ publishing { | ||||
|                 maven { | ||||
|                     name = "GithubPackages" | ||||
|                     url = uri("https://maven.pkg.github.com/InsanusMokrassar/MicroUtils") | ||||
|  | ||||
|              | ||||
|                     credentials { | ||||
|                         username = project.hasProperty('GITHUBPACKAGES_USER') ? project.property('GITHUBPACKAGES_USER') : System.getenv('GITHUBPACKAGES_USER') | ||||
|                         password = project.hasProperty('GITHUBPACKAGES_PASSWORD') ? project.property('GITHUBPACKAGES_PASSWORD') : System.getenv('GITHUBPACKAGES_PASSWORD') | ||||
|                     } | ||||
|  | ||||
|              | ||||
|                 } | ||||
|             } | ||||
|             if (project.hasProperty('GITEA_TOKEN') || System.getenv('GITEA_TOKEN') != null) { | ||||
|             if ((project.hasProperty('INMONEXUS_USER') || System.getenv('INMONEXUS_USER') != null) && (project.hasProperty('INMONEXUS_PASSWORD') || System.getenv('INMONEXUS_PASSWORD') != null)) { | ||||
|                 maven { | ||||
|                     name = "Gitea" | ||||
|                     url = uri("https://git.inmo.dev/api/packages/InsanusMokrassar/maven") | ||||
|  | ||||
|                     credentials(HttpHeaderCredentials) { | ||||
|                         name = "Authorization" | ||||
|                         value = project.hasProperty('GITEA_TOKEN') ? project.property('GITEA_TOKEN') : System.getenv('GITEA_TOKEN') | ||||
|                     } | ||||
|  | ||||
|                     authentication { | ||||
|                         header(HttpHeaderAuthentication) | ||||
|                     name = "InmoNexus" | ||||
|                     url = uri("https://nexus.inmo.dev/repository/maven-releases/") | ||||
|              | ||||
|                     credentials { | ||||
|                         username = project.hasProperty('INMONEXUS_USER') ? project.property('INMONEXUS_USER') : System.getenv('INMONEXUS_USER') | ||||
|                         password = project.hasProperty('INMONEXUS_PASSWORD') ? project.property('INMONEXUS_PASSWORD') : System.getenv('INMONEXUS_PASSWORD') | ||||
|                     } | ||||
|              | ||||
|                 } | ||||
|             } | ||||
|             if ((project.hasProperty('SONATYPE_USER') || System.getenv('SONATYPE_USER') != null) && (project.hasProperty('SONATYPE_PASSWORD') || System.getenv('SONATYPE_PASSWORD') != null)) { | ||||
|                 maven { | ||||
|                     name = "sonatype" | ||||
|                     url = uri("https://oss.sonatype.org/service/local/staging/deploy/maven2/") | ||||
|  | ||||
|              | ||||
|                     credentials { | ||||
|                         username = project.hasProperty('SONATYPE_USER') ? project.property('SONATYPE_USER') : System.getenv('SONATYPE_USER') | ||||
|                         password = project.hasProperty('SONATYPE_PASSWORD') ? project.property('SONATYPE_PASSWORD') : System.getenv('SONATYPE_PASSWORD') | ||||
|                     } | ||||
|  | ||||
|              | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
|      | ||||
| if (project.hasProperty("signing.gnupg.keyName")) { | ||||
|     apply plugin: 'signing' | ||||
|  | ||||
|      | ||||
|     signing { | ||||
|         useGpgCmd() | ||||
|  | ||||
|      | ||||
|         sign publishing.publications | ||||
|     } | ||||
|  | ||||
|      | ||||
|     task signAll { | ||||
|         tasks.withType(Sign).forEach { | ||||
|             dependsOn(it) | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     // Workaround to make android sign operations depend on signing tasks | ||||
|     project.getTasks().withType(AbstractPublishToMaven.class).configureEach { | ||||
|         def signingTasks = project.getTasks().withType(Sign.class) | ||||
|         mustRunAfter(signingTasks) | ||||
|     } | ||||
|     // Workaround to make test tasks use sign | ||||
|     project.getTasks().withType(Sign.class).configureEach { signTask -> | ||||
|         def withoutSign = (signTask.name.startsWith("sign") ? signTask.name.minus("sign") : signTask.name) | ||||
|         def pubName = withoutSign.endsWith("Publication") ? withoutSign.substring(0, withoutSign.length() - "Publication".length()) : withoutSign | ||||
|         // These tasks only exist for native targets, hence findByName() to avoid trying to find them for other targets | ||||
|  | ||||
|         // Task ':linkDebugTest<platform>' uses this output of task ':sign<platform>Publication' without declaring an explicit or implicit dependency | ||||
|         def debugTestTask = tasks.findByName("linkDebugTest$pubName") | ||||
|         if (debugTestTask != null) { | ||||
|             signTask.mustRunAfter(debugTestTask) | ||||
|         } | ||||
|         // Task ':compileTestKotlin<platform>' uses this output of task ':sign<platform>Publication' without declaring an explicit or implicit dependency | ||||
|         def testTask = tasks.findByName("compileTestKotlin$pubName") | ||||
|         if (testTask != null) { | ||||
|             signTask.mustRunAfter(testTask) | ||||
|         } | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -1 +1 @@ | ||||
| {"licenses":[{"id":"Apache-2.0","title":"Apache Software License 2.0","url":"https://github.com/InsanusMokrassar/MicroUtils/blob/master/LICENSE"}],"mavenConfig":{"name":"${project.name}","description":"It is set of projects with micro tools for avoiding of routines coding","url":"https://github.com/InsanusMokrassar/MicroUtils/","vcsUrl":"https://github.com/InsanusMokrassar/MicroUtils.git","developers":[{"id":"InsanusMokrassar","name":"Aleksei Ovsiannikov","eMail":"ovsyannikov.alexey95@gmail.com"},{"id":"000Sanya","name":"Syrov Aleksandr","eMail":"000sanya.000sanya@gmail.com"}],"repositories":[{"name":"GithubPackages","url":"https://maven.pkg.github.com/InsanusMokrassar/MicroUtils"},{"name":"Gitea","url":"https://git.inmo.dev/api/packages/InsanusMokrassar/maven","credsType":{"type":"dev.inmo.kmppscriptbuilder.core.models.MavenPublishingRepository.CredentialsType.HttpHeaderCredentials","headerName":"Authorization","headerValueProperty":"GITEA_TOKEN"}},{"name":"sonatype","url":"https://oss.sonatype.org/service/local/staging/deploy/maven2/"}],"gpgSigning":{"type":"dev.inmo.kmppscriptbuilder.core.models.GpgSigning.Optional"}}} | ||||
| {"licenses":[{"id":"Apache-2.0","title":"Apache Software License 2.0","url":"https://github.com/InsanusMokrassar/MicroUtils/blob/master/LICENSE"}],"mavenConfig":{"name":"${project.name}","description":"It is set of projects with micro tools for avoiding of routines coding","url":"https://github.com/InsanusMokrassar/MicroUtils/","vcsUrl":"https://github.com/InsanusMokrassar/MicroUtils.git","developers":[{"id":"InsanusMokrassar","name":"Aleksei Ovsiannikov","eMail":"ovsyannikov.alexey95@gmail.com"},{"id":"000Sanya","name":"Syrov Aleksandr","eMail":"000sanya.000sanya@gmail.com"}],"repositories":[{"name":"GithubPackages","url":"https://maven.pkg.github.com/InsanusMokrassar/MicroUtils"},{"name":"InmoNexus","url":"https://nexus.inmo.dev/repository/maven-releases/"},{"name":"sonatype","url":"https://oss.sonatype.org/service/local/staging/deploy/maven2/"}],"gpgSigning":{"type":"dev.inmo.kmppscriptbuilder.core.models.GpgSigning.Optional"}}} | ||||
							
								
								
									
										2
									
								
								repos/cache/build.gradle
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								repos/cache/build.gradle
									
									
									
									
										vendored
									
									
								
							| @@ -4,7 +4,7 @@ plugins { | ||||
|     id "com.android.library" | ||||
| } | ||||
|  | ||||
| apply from: "$mppProjectWithSerializationPresetPath" | ||||
| apply from: "$mppJvmJsAndroidLinuxMingwLinuxArm64ProjectPresetPath" | ||||
|  | ||||
| kotlin { | ||||
|     sourceSets { | ||||
|   | ||||
| @@ -4,7 +4,7 @@ plugins { | ||||
|     id "com.android.library" | ||||
| } | ||||
|  | ||||
| apply from: "$mppProjectWithSerializationPresetPath" | ||||
| apply from: "$mppJvmJsAndroidLinuxMingwLinuxArm64ProjectPresetPath" | ||||
|  | ||||
| kotlin { | ||||
|     sourceSets { | ||||
|   | ||||
| @@ -1,14 +1,19 @@ | ||||
| package dev.inmo.micro_utils.repos.exposed | ||||
|  | ||||
| import dev.inmo.micro_utils.repos.CRUDRepo | ||||
| import kotlinx.coroutines.channels.BufferOverflow | ||||
|  | ||||
| abstract class AbstractExposedCRUDRepo<ObjectType, IdType, InputValueType>( | ||||
|     flowsChannelsSize: Int = 0, | ||||
|     tableName: String = "" | ||||
|     tableName: String = "", | ||||
|     replyCacheInFlows: Int = 0, | ||||
|     onBufferOverflowBehaviour: BufferOverflow = BufferOverflow.SUSPEND | ||||
| ) : | ||||
|     AbstractExposedWriteCRUDRepo<ObjectType, IdType, InputValueType>( | ||||
|         flowsChannelsSize, | ||||
|         tableName | ||||
|         tableName, | ||||
|         replyCacheInFlows, | ||||
|         onBufferOverflowBehaviour | ||||
|     ), | ||||
|     ExposedCRUDRepo<ObjectType, IdType>, | ||||
|     CRUDRepo<ObjectType, IdType, InputValueType> | ||||
|   | ||||
| @@ -2,6 +2,7 @@ package dev.inmo.micro_utils.repos.exposed | ||||
|  | ||||
| import dev.inmo.micro_utils.repos.UpdatedValuePair | ||||
| import dev.inmo.micro_utils.repos.WriteCRUDRepo | ||||
| import kotlinx.coroutines.channels.BufferOverflow | ||||
| import kotlinx.coroutines.flow.* | ||||
| import org.jetbrains.exposed.sql.* | ||||
| import org.jetbrains.exposed.sql.statements.* | ||||
| @@ -11,19 +12,26 @@ import java.util.Objects | ||||
| abstract class AbstractExposedWriteCRUDRepo<ObjectType, IdType, InputValueType>( | ||||
|     flowsChannelsSize: Int = 0, | ||||
|     tableName: String = "", | ||||
|     replyCacheInFlows: Int = 0 | ||||
|     replyCacheInFlows: Int = 0, | ||||
|     onBufferOverflowBehaviour: BufferOverflow = BufferOverflow.SUSPEND | ||||
| ) : | ||||
|     AbstractExposedReadCRUDRepo<ObjectType, IdType>(tableName), | ||||
|     ExposedCRUDRepo<ObjectType, IdType>, | ||||
|     WriteCRUDRepo<ObjectType, IdType, InputValueType> | ||||
| { | ||||
|     protected val _newObjectsFlow = MutableSharedFlow<ObjectType>(replyCacheInFlows, flowsChannelsSize) | ||||
|     protected val _updatedObjectsFlow = MutableSharedFlow<ObjectType>(replyCacheInFlows, flowsChannelsSize) | ||||
|     protected val _deletedObjectsIdsFlow = MutableSharedFlow<IdType>(replyCacheInFlows, flowsChannelsSize) | ||||
|     protected open val _newObjectsFlow = MutableSharedFlow<ObjectType>(replyCacheInFlows, flowsChannelsSize, onBufferOverflowBehaviour) | ||||
|     protected open val _updatedObjectsFlow = MutableSharedFlow<ObjectType>(replyCacheInFlows, flowsChannelsSize, onBufferOverflowBehaviour) | ||||
|     protected open val _deletedObjectsIdsFlow = MutableSharedFlow<IdType>(replyCacheInFlows, flowsChannelsSize, onBufferOverflowBehaviour) | ||||
|  | ||||
|     override val newObjectsFlow: Flow<ObjectType> = _newObjectsFlow.asSharedFlow() | ||||
|     override val updatedObjectsFlow: Flow<ObjectType> = _updatedObjectsFlow.asSharedFlow() | ||||
|     override val deletedObjectsIdsFlow: Flow<IdType> = _deletedObjectsIdsFlow.asSharedFlow() | ||||
|     override val newObjectsFlow: Flow<ObjectType> by lazy { | ||||
|         _newObjectsFlow.asSharedFlow() | ||||
|     } | ||||
|     override val updatedObjectsFlow: Flow<ObjectType> by lazy { | ||||
|         _updatedObjectsFlow.asSharedFlow() | ||||
|     } | ||||
|     override val deletedObjectsIdsFlow: Flow<IdType> by lazy { | ||||
|         _deletedObjectsIdsFlow.asSharedFlow() | ||||
|     } | ||||
|  | ||||
|     protected abstract fun InsertStatement<Number>.asObject(value: InputValueType): ObjectType | ||||
|  | ||||
|   | ||||
| @@ -1,12 +1,10 @@ | ||||
| package dev.inmo.micro_utils.repos.exposed.onetomany | ||||
| 
 | ||||
| import dev.inmo.micro_utils.pagination.* | ||||
| import dev.inmo.micro_utils.repos.ReadKeyValueRepo | ||||
| import dev.inmo.micro_utils.repos.ReadKeyValuesRepo | ||||
| import dev.inmo.micro_utils.repos.exposed.* | ||||
| import dev.inmo.micro_utils.repos.exposed.utils.selectPaginated | ||||
| import org.jetbrains.exposed.sql.* | ||||
| import org.jetbrains.exposed.sql.SqlExpressionBuilder.eq | ||||
| import org.jetbrains.exposed.sql.transactions.transaction | ||||
| 
 | ||||
| abstract class AbstractExposedReadKeyValuesRepo<Key, Value>( | ||||
| @@ -73,4 +71,26 @@ abstract class AbstractExposedReadKeyValuesRepo<Key, Value>( | ||||
|     override suspend fun contains(k: Key, v: Value): Boolean = transaction(database) { | ||||
|         select { selectById(k).and(selectByValue(v)) }.limit(1).any() | ||||
|     } | ||||
| 
 | ||||
|     override suspend fun getAll(reverseLists: Boolean): Map<Key, List<Value>> = transaction(database) { | ||||
|         val query = if (reverseLists) { | ||||
|             selectAll().orderBy(keyColumn, SortOrder.DESC) | ||||
|         } else { | ||||
|             selectAll() | ||||
|         } | ||||
|         query.asSequence().map { it.asKey to it.asObject }.groupBy { it.first }.mapValues { | ||||
|             it.value.map { it.second } | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     override suspend fun getAll(k: Key, reverseLists: Boolean): List<Value> = transaction(database) { | ||||
|         val query = if (reverseLists) { | ||||
|             select { selectById(k) }.orderBy(keyColumn, SortOrder.DESC) | ||||
|         } else { | ||||
|             select { selectById(k) } | ||||
|         } | ||||
|         query.map { | ||||
|             it.asObject | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @@ -16,6 +16,6 @@ dependencies { | ||||
| } | ||||
|  | ||||
| java { | ||||
|     sourceCompatibility = JavaVersion.VERSION_1_8 | ||||
|     targetCompatibility = JavaVersion.VERSION_1_8 | ||||
|     sourceCompatibility = JavaVersion.VERSION_17 | ||||
|     targetCompatibility = JavaVersion.VERSION_17 | ||||
| } | ||||
|   | ||||
| @@ -5,7 +5,7 @@ plugins { | ||||
|     id "com.google.devtools.ksp" | ||||
| } | ||||
|  | ||||
| apply from: "$mppProjectWithSerializationPresetPath" | ||||
| apply from: "$mppJvmJsAndroidLinuxMingwLinuxArm64ProjectPresetPath" | ||||
|  | ||||
|  | ||||
| kotlin { | ||||
|   | ||||
| @@ -4,7 +4,7 @@ plugins { | ||||
|     id "com.android.library" | ||||
| } | ||||
|  | ||||
| apply from: "$mppProjectWithSerializationPresetPath" | ||||
| apply from: "$mppJvmJsAndroidLinuxMingwLinuxArm64ProjectPresetPath" | ||||
|  | ||||
| kotlin { | ||||
|     sourceSets { | ||||
|   | ||||
| @@ -4,7 +4,7 @@ plugins { | ||||
|     id "com.android.library" | ||||
| } | ||||
|  | ||||
| apply from: "$mppProjectWithSerializationPresetPath" | ||||
| apply from: "$mppJvmJsAndroidLinuxMingwLinuxArm64ProjectPresetPath" | ||||
|  | ||||
| kotlin { | ||||
|     sourceSets { | ||||
|   | ||||
| @@ -4,7 +4,7 @@ plugins { | ||||
|     id "com.android.library" | ||||
| } | ||||
|  | ||||
| apply from: "$mppProjectWithSerializationPresetPath" | ||||
| apply from: "$mppJvmJsAndroidLinuxMingwLinuxArm64ProjectPresetPath" | ||||
|  | ||||
| kotlin { | ||||
|     sourceSets { | ||||
|   | ||||
							
								
								
									
										21
									
								
								resources/build.gradle
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								resources/build.gradle
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,21 @@ | ||||
| plugins { | ||||
|     id "org.jetbrains.kotlin.multiplatform" | ||||
|     id "org.jetbrains.kotlin.plugin.serialization" | ||||
|     id "com.android.library" | ||||
| } | ||||
|  | ||||
| apply from: "$mppJvmJsAndroidLinuxMingwLinuxArm64ProjectPresetPath" | ||||
|  | ||||
| kotlin { | ||||
|     sourceSets { | ||||
|         commonMain { | ||||
|             dependencies { | ||||
|                 api project(":micro_utils.language_codes") | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         androidMain { | ||||
|             dependsOn(jvmMain) | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,21 @@ | ||||
| package dev.inmo.micro_utils.strings | ||||
|  | ||||
| import android.content.Context | ||||
| import android.content.res.Configuration | ||||
| import android.content.res.Resources | ||||
| import android.os.Build | ||||
| import dev.inmo.micro_utils.language_codes.toIetfLanguageCode | ||||
|  | ||||
| fun StringResource.translation(configuration: Configuration): String = translation( | ||||
|     if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N) { | ||||
|         configuration.locales[0] | ||||
|     } else { | ||||
|         configuration.locale | ||||
|     } | ||||
| ) | ||||
| fun StringResource.translation(resources: Resources): String = translation(resources.configuration) | ||||
| fun StringResource.translation(context: Context): String = translation(context.resources) | ||||
|  | ||||
| fun Configuration.translation(resource: StringResource): String = resource.translation(this) | ||||
| fun Resources.translation(resource: StringResource): String = configuration.translation(resource) | ||||
| fun Context.translation(resource: StringResource): String = resources.translation(resource) | ||||
							
								
								
									
										32
									
								
								resources/src/commonMain/kotlin/StringResource.kt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								resources/src/commonMain/kotlin/StringResource.kt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,32 @@ | ||||
| package dev.inmo.micro_utils.strings | ||||
|  | ||||
| import dev.inmo.micro_utils.language_codes.IetfLanguageCode | ||||
|  | ||||
| class StringResource( | ||||
|     val default: String, | ||||
|     val map: Map<IetfLanguageCode, Lazy<String>> | ||||
| ) { | ||||
|     class Builder( | ||||
|         var default: String | ||||
|     ) { | ||||
|         private val map = mutableMapOf<IetfLanguageCode, Lazy<String>>() | ||||
|  | ||||
|         infix fun IetfLanguageCode.variant(value: Lazy<String>) { | ||||
|             map[this] = value | ||||
|         } | ||||
|         infix fun IetfLanguageCode.variant(value: String) = this variant lazyOf(value) | ||||
|         infix fun String.variant(value: Lazy<String>) = IetfLanguageCode(this) variant value | ||||
|         infix fun String.variant(value: String) = this variant lazyOf(value) | ||||
|  | ||||
|         fun build() = StringResource(default, map.toMap()) | ||||
|     } | ||||
|  | ||||
|     fun translation(languageCode: IetfLanguageCode): String = (map[languageCode] ?: map[IetfLanguageCode(languageCode.withoutDialect)]) ?.value ?: default | ||||
| } | ||||
|  | ||||
| inline fun buildStringResource( | ||||
|     default: String, | ||||
|     builder: StringResource.Builder.() -> Unit | ||||
| ): StringResource { | ||||
|     return StringResource.Builder(default).apply(builder).build() | ||||
| } | ||||
							
								
								
									
										10
									
								
								resources/src/jvmMain/kotlin/StringResourceLocaleGetter.kt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										10
									
								
								resources/src/jvmMain/kotlin/StringResourceLocaleGetter.kt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,10 @@ | ||||
| package dev.inmo.micro_utils.strings | ||||
|  | ||||
| import dev.inmo.micro_utils.language_codes.toIetfLanguageCode | ||||
| import java.util.Locale | ||||
|  | ||||
| fun StringResource.translation(locale: Locale = Locale.getDefault()): String { | ||||
|     return translation(locale.toIetfLanguageCode()) | ||||
| } | ||||
|  | ||||
| fun Locale.translation(resource: StringResource): String = resource.translation(this) | ||||
| @@ -4,7 +4,7 @@ plugins { | ||||
|     id "com.android.library" | ||||
| } | ||||
|  | ||||
| apply from: "$mppProjectWithSerializationPresetPath" | ||||
| apply from: "$mppJvmJsAndroidLinuxMingwLinuxArm64ProjectPresetPath" | ||||
|  | ||||
| kotlin { | ||||
|     sourceSets { | ||||
|   | ||||
| @@ -4,7 +4,7 @@ plugins { | ||||
|     id "com.android.library" | ||||
| } | ||||
|  | ||||
| apply from: "$mppProjectWithSerializationPresetPath" | ||||
| apply from: "$mppJvmJsAndroidLinuxMingwLinuxArm64ProjectPresetPath" | ||||
|  | ||||
| kotlin { | ||||
|     sourceSets { | ||||
|   | ||||
| @@ -4,7 +4,7 @@ plugins { | ||||
|     id "com.android.library" | ||||
| } | ||||
|  | ||||
| apply from: "$mppProjectWithSerializationPresetPath" | ||||
| apply from: "$mppJvmJsAndroidLinuxMingwLinuxArm64ProjectPresetPath" | ||||
|  | ||||
| kotlin { | ||||
|     sourceSets { | ||||
|   | ||||
| @@ -4,4 +4,4 @@ plugins { | ||||
|     id "com.android.library" | ||||
| } | ||||
|  | ||||
| apply from: "$mppProjectWithSerializationPresetPath" | ||||
| apply from: "$mppJvmJsAndroidLinuxMingwLinuxArm64ProjectPresetPath" | ||||
|   | ||||
| @@ -4,4 +4,4 @@ plugins { | ||||
|     id "com.android.library" | ||||
| } | ||||
|  | ||||
| apply from: "$mppProjectWithSerializationPresetPath" | ||||
| apply from: "$mppJvmJsAndroidLinuxMingwLinuxArm64ProjectPresetPath" | ||||
|   | ||||
| @@ -4,4 +4,4 @@ plugins { | ||||
|     id "com.android.library" | ||||
| } | ||||
|  | ||||
| apply from: "$mppProjectWithSerializationPresetPath" | ||||
| apply from: "$mppJvmJsAndroidLinuxMingwLinuxArm64ProjectPresetPath" | ||||
|   | ||||
| @@ -43,6 +43,8 @@ String[] includes = [ | ||||
|     ":startup:plugin", | ||||
|     ":startup:launcher", | ||||
|  | ||||
|     ":resources", | ||||
|  | ||||
|     ":fsm:common", | ||||
|     ":fsm:repos:common", | ||||
|  | ||||
| @@ -59,5 +61,3 @@ includes.each { originalName -> | ||||
|     project.name = projectName | ||||
|     project.projectDir = new File(projectDirectory) | ||||
| } | ||||
|  | ||||
| enableFeaturePreview("VERSION_CATALOGS") | ||||
|   | ||||
| @@ -28,8 +28,8 @@ application { | ||||
| } | ||||
|  | ||||
| java { | ||||
|     sourceCompatibility = JavaVersion.VERSION_1_8 | ||||
|     targetCompatibility = JavaVersion.VERSION_1_8 | ||||
|     sourceCompatibility = JavaVersion.VERSION_17 | ||||
|     targetCompatibility = JavaVersion.VERSION_17 | ||||
| } | ||||
|  | ||||
| dependencies { | ||||
|   | ||||
| @@ -10,7 +10,6 @@ kotlin { | ||||
|         commonMain { | ||||
|             dependencies { | ||||
|                 api libs.koin | ||||
|                 api libs.kt.serialization | ||||
|                 api libs.kslog | ||||
|                 api libs.kt.reflect | ||||
|                 api project(":micro_utils.coroutines") | ||||
|   | ||||
| @@ -5,7 +5,7 @@ plugins { | ||||
|     alias(libs.plugins.compose) | ||||
| } | ||||
|  | ||||
| apply from: "$mppProjectWithSerializationPresetPath" | ||||
| apply from: "$mppJvmJsAndroidLinuxMingwLinuxArm64ProjectPresetPath" | ||||
|  | ||||
| kotlin { | ||||
|     sourceSets { | ||||
|   | ||||
| @@ -4,4 +4,4 @@ plugins { | ||||
|     id "com.android.library" | ||||
| } | ||||
|  | ||||
| apply from: "$mppProjectWithSerializationPresetPath" | ||||
| apply from: "$mppJvmJsAndroidLinuxMingwLinuxArm64ProjectPresetPath" | ||||
|   | ||||
		Reference in New Issue
	
	Block a user