mirror of
				https://github.com/InsanusMokrassar/MicroUtils.git
				synced 2025-10-25 01:00:36 +00:00 
			
		
		
		
	Compare commits
	
		
			47 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 0337d1b82d | |||
| f5bd4c5ccb | |||
| 630f9bc0d4 | |||
| 18b4ffece1 | |||
| f64e1effa3 | |||
| 847fcbb488 | |||
| 88002ec8e7 | |||
| 7f8db6a29d | |||
| b183b82443 | |||
| 5dad27de72 | |||
| 6b66084d0e | |||
| 50b56a7c39 | |||
| 7ab7d14471 | |||
| bdcc179b7b | |||
| 55ffd4b46f | |||
| 7fc5ee70e1 | |||
| a24a335743 | |||
| ef9af71960 | |||
| 925702d315 | |||
| d50dffec8c | |||
| cef2081a13 | |||
| 06c8bde7c9 | |||
| c9bbfa3820 | |||
| eed7cfdc42 | |||
| bd9b0d16ab | |||
| ea6c33b497 | |||
| dc80ade2fb | |||
| f6a06ee8ea | |||
| 2644f27975 | |||
| 3dc68a7b8b | |||
| 97fc1d6239 | |||
| 662f4d22a3 | |||
| b70aa12be9 | |||
| 71f12f5f19 | |||
| e10504eeeb | |||
| 2dea9f3bc0 | |||
| 35c9dda5bc | |||
| e831f3949a | |||
| b0b39cc693 | |||
| fc03be3f73 | |||
| b61f6b81f1 | |||
| f5bc1c1fce | |||
| a729f9568c | |||
| 5749e00377 | |||
| ef73c24a0c | |||
| 94717ee351 | |||
| 9a18ded65b | 
							
								
								
									
										12
									
								
								.github/workflows/build.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										12
									
								
								.github/workflows/build.yml
									
									
									
									
										vendored
									
									
								
							| @@ -1,12 +0,0 @@ | |||||||
| name: Regular build |  | ||||||
| on: [push] |  | ||||||
| jobs: |  | ||||||
|   build: |  | ||||||
|     runs-on: ubuntu-latest |  | ||||||
|     steps: |  | ||||||
|       - uses: actions/checkout@v2 |  | ||||||
|       - uses: actions/setup-java@v1 |  | ||||||
|         with: |  | ||||||
|           java-version: 1.8 |  | ||||||
|       - name: Build |  | ||||||
|         run: ./gradlew build |  | ||||||
							
								
								
									
										3
									
								
								.github/workflows/dokka_push.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								.github/workflows/dokka_push.yml
									
									
									
									
										vendored
									
									
								
							| @@ -11,6 +11,9 @@ jobs: | |||||||
|       - uses: actions/setup-java@v1 |       - uses: actions/setup-java@v1 | ||||||
|         with: |         with: | ||||||
|           java-version: 1.8 |           java-version: 1.8 | ||||||
|  |       - name: Fix android 31.0.0 dx | ||||||
|  |         continue-on-error: true | ||||||
|  |         run: cd /usr/local/lib/android/sdk/build-tools/31.0.0/ && mv d8 dx && cd lib  && mv d8.jar dx.jar | ||||||
|       - name: Build |       - name: Build | ||||||
|         run: ./gradlew dokkaHtml |         run: ./gradlew dokkaHtml | ||||||
|       - name: Publish KDocs |       - name: Publish KDocs | ||||||
|   | |||||||
							
								
								
									
										4
									
								
								.github/workflows/packages_push.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.github/workflows/packages_push.yml
									
									
									
									
										vendored
									
									
								
							| @@ -9,6 +9,9 @@ jobs: | |||||||
|       - uses: actions/setup-java@v1 |       - uses: actions/setup-java@v1 | ||||||
|         with: |         with: | ||||||
|           java-version: 1.8 |           java-version: 1.8 | ||||||
|  |       - name: Fix android 31.0.0 dx | ||||||
|  |         continue-on-error: true | ||||||
|  |         run: cd /usr/local/lib/android/sdk/build-tools/31.0.0/ && mv d8 dx && cd lib  && mv d8.jar dx.jar | ||||||
|       - name: Rewrite version |       - name: Rewrite version | ||||||
|         run: | |         run: | | ||||||
|           branch="`echo "${{ github.ref }}" | grep -o "[^/]*$"`" |           branch="`echo "${{ github.ref }}" | grep -o "[^/]*$"`" | ||||||
| @@ -18,6 +21,7 @@ jobs: | |||||||
|       - name: Build |       - name: Build | ||||||
|         run: ./gradlew build |         run: ./gradlew build | ||||||
|       - name: Publish |       - name: Publish | ||||||
|  |         continue-on-error: true | ||||||
|         run: ./gradlew --no-parallel publishAllPublicationsToGithubPackagesRepository -x signJsPublication -x signJvmPublication -x signKotlinMultiplatformPublication -x signAndroidDebugPublication -x signAndroidReleasePublication -x signKotlinMultiplatformPublication |         run: ./gradlew --no-parallel publishAllPublicationsToGithubPackagesRepository -x signJsPublication -x signJvmPublication -x signKotlinMultiplatformPublication -x signAndroidDebugPublication -x signAndroidReleasePublication -x signKotlinMultiplatformPublication | ||||||
|         env: |         env: | ||||||
|           GITHUBPACKAGES_USER: ${{ github.actor }} |           GITHUBPACKAGES_USER: ${{ github.actor }} | ||||||
|   | |||||||
							
								
								
									
										64
									
								
								CHANGELOG.md
									
									
									
									
									
								
							
							
						
						
									
										64
									
								
								CHANGELOG.md
									
									
									
									
									
								
							| @@ -1,5 +1,69 @@ | |||||||
| # Changelog | # Changelog | ||||||
|  |  | ||||||
|  | ## 0.5.29 | ||||||
|  |  | ||||||
|  | * `Versions`: | ||||||
|  |     * `Exposed`: `0.34.2` -> `0.35.1` | ||||||
|  |  | ||||||
|  | ## 0.5.28 | ||||||
|  |  | ||||||
|  | * `Versions`: | ||||||
|  |     * `Kotlin`: `1.5.30` -> `1.5.31` | ||||||
|  |     * `Klock`: `2.4.1` -> `2.4.2` | ||||||
|  |  | ||||||
|  | ## 0.5.27 | ||||||
|  |  | ||||||
|  | * `Versions`: | ||||||
|  |     * `Exposed`: `0.34.1` -> `0.34.2` | ||||||
|  |  | ||||||
|  | ## 0.5.26 | ||||||
|  |  | ||||||
|  | * `Repos`: | ||||||
|  |     * `InMemory`: | ||||||
|  |         * `MapCRUDRepo`s and `MapKeyValueRepo`s got `protected` methods and properties instead of private | ||||||
|  |  | ||||||
|  | ## 0.5.25 | ||||||
|  |  | ||||||
|  | * `Versions`: | ||||||
|  |     * `UUID`: `0.3.0` -> `0.3.1` | ||||||
|  | * `Common`: | ||||||
|  |     * New property `MPPFile#withoutSlashAtTheEnd` | ||||||
|  |     * Extension `clamp` has been deprecated | ||||||
|  |     * New extension `Iterable#diff` | ||||||
|  | * `Serialization`: | ||||||
|  |     * New operators `TypedSerializer#plusAssign` and `TypedSerializer#minusAssign` | ||||||
|  |  | ||||||
|  | ## 0.5.24 | ||||||
|  |  | ||||||
|  | * `Versions`: | ||||||
|  |     * `Coroutines`: `1.5.1` -> `1.5.2` | ||||||
|  |     * `Klock`: `2.3.4` -> `2.4.1` | ||||||
|  | * `Coroutines`: | ||||||
|  |     * New function `CoroutineScope` with safely exceptions handler as second parameter | ||||||
|  |  | ||||||
|  | ## 0.5.23 | ||||||
|  |  | ||||||
|  | * `Versions`: | ||||||
|  |     * `Exposed`: `0.33.1` -> `0.34.1` | ||||||
|  | * `Common`: | ||||||
|  |     * New extensions `Iterable#joinTo` and `Array#joinTo` | ||||||
|  |  | ||||||
|  | ## 0.5.22 | ||||||
|  |  | ||||||
|  | * `Versions` | ||||||
|  |     * `Kotlin`: `1.5.21` -> `1.5.30` | ||||||
|  |     * `Klock`: `2.3.2` -> `2.3.4` | ||||||
|  |     * `AppCompat`: `1.3.0` -> `1.3.1` | ||||||
|  |     * `Ktor`: `1.6.2` -> `1.6.3` | ||||||
|  |  | ||||||
|  | ## 0.5.21 | ||||||
|  |  | ||||||
|  | * `Versions` | ||||||
|  |     * `Klock`: `2.3.1` -> `2.3.2` | ||||||
|  | * `Serialization` | ||||||
|  |     * `Typed Serializer`: | ||||||
|  |         * `TypedSerializer` Descriptor serial name has been fixed | ||||||
|  |  | ||||||
| ## 0.5.20 | ## 0.5.20 | ||||||
|  |  | ||||||
| * `Repos`: | * `Repos`: | ||||||
|   | |||||||
| @@ -12,9 +12,7 @@ package dev.inmo.micro_utils.common | |||||||
|     AnnotationTarget.PROPERTY_GETTER, |     AnnotationTarget.PROPERTY_GETTER, | ||||||
|     AnnotationTarget.PROPERTY_SETTER, |     AnnotationTarget.PROPERTY_SETTER, | ||||||
|     AnnotationTarget.FUNCTION, |     AnnotationTarget.FUNCTION, | ||||||
|     AnnotationTarget.TYPE, |     AnnotationTarget.TYPEALIAS | ||||||
|     AnnotationTarget.TYPEALIAS, |  | ||||||
|     AnnotationTarget.TYPE_PARAMETER |  | ||||||
| ) | ) | ||||||
| annotation class PreviewFeature(val message: String = "It is possible, that behaviour of this thing will be changed or removed in future releases") | annotation class PreviewFeature(val message: String = "It is possible, that behaviour of this thing will be changed or removed in future releases") | ||||||
|  |  | ||||||
| @@ -30,8 +28,6 @@ annotation class PreviewFeature(val message: String = "It is possible, that beha | |||||||
|     AnnotationTarget.PROPERTY_GETTER, |     AnnotationTarget.PROPERTY_GETTER, | ||||||
|     AnnotationTarget.PROPERTY_SETTER, |     AnnotationTarget.PROPERTY_SETTER, | ||||||
|     AnnotationTarget.FUNCTION, |     AnnotationTarget.FUNCTION, | ||||||
|     AnnotationTarget.TYPE, |     AnnotationTarget.TYPEALIAS | ||||||
|     AnnotationTarget.TYPEALIAS, |  | ||||||
|     AnnotationTarget.TYPE_PARAMETER |  | ||||||
| ) | ) | ||||||
| annotation class Warning(val message: String) | annotation class Warning(val message: String) | ||||||
|   | |||||||
| @@ -1,10 +1,5 @@ | |||||||
| package dev.inmo.micro_utils.common | package dev.inmo.micro_utils.common | ||||||
|  |  | ||||||
|  | @Deprecated("Redundant", ReplaceWith("coerceIn(min, max)")) | ||||||
| @Suppress("NOTHING_TO_INLINE") | @Suppress("NOTHING_TO_INLINE") | ||||||
| inline fun <T : Comparable<T>> T.clamp(min: T, max: T): T { | inline fun <T : Comparable<T>> T.clamp(min: T, max: T): T = coerceIn(min, max) | ||||||
|     return when { |  | ||||||
|         this < min -> min |  | ||||||
|         this > max -> max |  | ||||||
|         else -> this |  | ||||||
|     } |  | ||||||
| } |  | ||||||
|   | |||||||
| @@ -2,6 +2,8 @@ | |||||||
|  |  | ||||||
| package dev.inmo.micro_utils.common | package dev.inmo.micro_utils.common | ||||||
|  |  | ||||||
|  | import kotlin.jvm.JvmInline | ||||||
|  |  | ||||||
| private inline fun <T> getObject( | private inline fun <T> getObject( | ||||||
|     additional: MutableList<T>, |     additional: MutableList<T>, | ||||||
|     iterator: Iterator<T> |     iterator: Iterator<T> | ||||||
| @@ -27,8 +29,8 @@ data class Diff<T> internal constructor( | |||||||
|  |  | ||||||
| private inline fun <T> performChanges( | private inline fun <T> performChanges( | ||||||
|     potentialChanges: MutableList<Pair<IndexedValue<T>?, IndexedValue<T>?>>, |     potentialChanges: MutableList<Pair<IndexedValue<T>?, IndexedValue<T>?>>, | ||||||
|     additionalsInOld: MutableList<T>, |     additionsInOld: MutableList<T>, | ||||||
|     additionalsInNew: MutableList<T>, |     additionsInNew: MutableList<T>, | ||||||
|     changedList: MutableList<Pair<IndexedValue<T>, IndexedValue<T>>>, |     changedList: MutableList<Pair<IndexedValue<T>, IndexedValue<T>>>, | ||||||
|     removedList: MutableList<IndexedValue<T>>, |     removedList: MutableList<IndexedValue<T>>, | ||||||
|     addedList: MutableList<IndexedValue<T>>, |     addedList: MutableList<IndexedValue<T>>, | ||||||
| @@ -52,20 +54,20 @@ private inline fun <T> performChanges( | |||||||
|                     newPotentials.first().second ?.let { addedList.add(it) } |                     newPotentials.first().second ?.let { addedList.add(it) } | ||||||
|                     newPotentials.drop(1).take(newPotentials.size - 2).forEach { (oldOne, newOne) -> |                     newPotentials.drop(1).take(newPotentials.size - 2).forEach { (oldOne, newOne) -> | ||||||
|                         addedList.add(newOne!!) |                         addedList.add(newOne!!) | ||||||
|                         oldOne ?.let { additionalsInOld.add(oldOne.value) } |                         oldOne ?.let { additionsInOld.add(oldOne.value) } | ||||||
|                     } |                     } | ||||||
|                     if (newPotentials.size > 1) { |                     if (newPotentials.size > 1) { | ||||||
|                         newPotentials.last().first ?.value ?.let { additionalsInOld.add(it) } |                         newPotentials.last().first ?.value ?.let { additionsInOld.add(it) } | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|                 newOneEqualToOldObject -> { |                 newOneEqualToOldObject -> { | ||||||
|                     newPotentials.first().first ?.let { removedList.add(it) } |                     newPotentials.first().first ?.let { removedList.add(it) } | ||||||
|                     newPotentials.drop(1).take(newPotentials.size - 2).forEach { (oldOne, newOne) -> |                     newPotentials.drop(1).take(newPotentials.size - 2).forEach { (oldOne, newOne) -> | ||||||
|                         removedList.add(oldOne!!) |                         removedList.add(oldOne!!) | ||||||
|                         newOne ?.let { additionalsInNew.add(newOne.value) } |                         newOne ?.let { additionsInNew.add(newOne.value) } | ||||||
|                     } |                     } | ||||||
|                     if (newPotentials.size > 1) { |                     if (newPotentials.size > 1) { | ||||||
|                         newPotentials.last().second ?.value ?.let { additionalsInNew.add(it) } |                         newPotentials.last().second ?.value ?.let { additionsInNew.add(it) } | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
| @@ -139,6 +141,10 @@ fun <T> Iterable<T>.calculateDiff( | |||||||
|  |  | ||||||
|     return Diff(removedObjects.toList(), changedObjects.toList(), addedObjects.toList()) |     return Diff(removedObjects.toList(), changedObjects.toList(), addedObjects.toList()) | ||||||
| } | } | ||||||
|  | inline fun <T> Iterable<T>.diff( | ||||||
|  |     other: Iterable<T>, | ||||||
|  |     strictComparison: Boolean = false | ||||||
|  | ): Diff<T> = calculateDiff(other, strictComparison) | ||||||
|  |  | ||||||
| inline fun <T> Diff(old: Iterable<T>, new: Iterable<T>) = old.calculateDiff(new) | inline fun <T> Diff(old: Iterable<T>, new: Iterable<T>) = old.calculateDiff(new) | ||||||
| inline fun <T> StrictDiff(old: Iterable<T>, new: Iterable<T>) = old.calculateDiff(new, true) | inline fun <T> StrictDiff(old: Iterable<T>, new: Iterable<T>) = old.calculateDiff(new, true) | ||||||
|   | |||||||
| @@ -0,0 +1,59 @@ | |||||||
|  | package dev.inmo.micro_utils.common | ||||||
|  |  | ||||||
|  | inline fun <I, R> Iterable<I>.joinTo( | ||||||
|  |     crossinline separatorFun: (I) -> R?, | ||||||
|  |     prefix: R? = null, | ||||||
|  |     postfix: R? = null, | ||||||
|  |     crossinline transform: (I) -> R? | ||||||
|  | ): List<R> { | ||||||
|  |     val result = mutableListOf<R>() | ||||||
|  |     val iterator = iterator() | ||||||
|  |  | ||||||
|  |     prefix ?.let(result::add) | ||||||
|  |  | ||||||
|  |     while (iterator.hasNext()) { | ||||||
|  |         val element = iterator.next() | ||||||
|  |         result.add(transform(element) ?: continue) | ||||||
|  |  | ||||||
|  |         if (iterator.hasNext()) { | ||||||
|  |             result.add(separatorFun(element) ?: continue) | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     postfix ?.let(result::add) | ||||||
|  |  | ||||||
|  |     return result | ||||||
|  | } | ||||||
|  |  | ||||||
|  | inline fun <I, R> Iterable<I>.joinTo( | ||||||
|  |     separator: R? = null, | ||||||
|  |     prefix: R? = null, | ||||||
|  |     postfix: R? = null, | ||||||
|  |     crossinline transform: (I) -> R? | ||||||
|  | ): List<R> = joinTo({ separator }, prefix, postfix, transform) | ||||||
|  |  | ||||||
|  | inline fun <I> Iterable<I>.joinTo( | ||||||
|  |     crossinline separatorFun: (I) -> I?, | ||||||
|  |     prefix: I? = null, | ||||||
|  |     postfix: I? = null | ||||||
|  | ): List<I> = joinTo<I, I>(separatorFun, prefix, postfix) { it } | ||||||
|  |  | ||||||
|  | inline fun <I> Iterable<I>.joinTo( | ||||||
|  |     separator: I? = null, | ||||||
|  |     prefix: I? = null, | ||||||
|  |     postfix: I? = null | ||||||
|  | ): List<I> = joinTo<I>({ separator }, prefix, postfix) | ||||||
|  |  | ||||||
|  | inline fun <I, reified R> Array<I>.joinTo( | ||||||
|  |     crossinline separatorFun: (I) -> R?, | ||||||
|  |     prefix: R? = null, | ||||||
|  |     postfix: R? = null, | ||||||
|  |     crossinline transform: (I) -> R? | ||||||
|  | ): Array<R> = asIterable().joinTo(separatorFun, prefix, postfix, transform).toTypedArray() | ||||||
|  |  | ||||||
|  | inline fun <I, reified R> Array<I>.joinTo( | ||||||
|  |     separator: R? = null, | ||||||
|  |     prefix: R? = null, | ||||||
|  |     postfix: R? = null, | ||||||
|  |     crossinline transform: (I) -> R? | ||||||
|  | ): Array<R> = asIterable().joinTo(separator, prefix, postfix, transform).toTypedArray() | ||||||
| @@ -7,7 +7,7 @@ import kotlin.jvm.JvmInline | |||||||
| @JvmInline | @JvmInline | ||||||
| value class FileName(val string: String) { | value class FileName(val string: String) { | ||||||
|     val name: String |     val name: String | ||||||
|         get() = string.takeLastWhile { it != '/' } |         get() = withoutSlashAtTheEnd.takeLastWhile { it != '/' } | ||||||
|     val extension: String |     val extension: String | ||||||
|         get() = name.takeLastWhile { it != '.' } |         get() = name.takeLastWhile { it != '.' } | ||||||
|     val nameWithoutExtension: String |     val nameWithoutExtension: String | ||||||
| @@ -17,6 +17,8 @@ value class FileName(val string: String) { | |||||||
|                 filename.substring(0, it) |                 filename.substring(0, it) | ||||||
|             } ?: filename |             } ?: filename | ||||||
|         } |         } | ||||||
|  |     val withoutSlashAtTheEnd: String | ||||||
|  |         get() = string.dropLastWhile { it == '/' } | ||||||
|     override fun toString(): String = string |     override fun toString(): String = string | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -11,7 +11,7 @@ class DiffUtilsTests { | |||||||
|         val withIndex = oldList.withIndex() |         val withIndex = oldList.withIndex() | ||||||
|  |  | ||||||
|         for (count in 1 .. (floor(oldList.size.toFloat() / 2).toInt())) { |         for (count in 1 .. (floor(oldList.size.toFloat() / 2).toInt())) { | ||||||
|             for ((i, v) in withIndex) { |             for ((i, _) in withIndex) { | ||||||
|                 if (i + count > oldList.lastIndex) { |                 if (i + count > oldList.lastIndex) { | ||||||
|                     continue |                     continue | ||||||
|                 } |                 } | ||||||
|   | |||||||
| @@ -147,3 +147,10 @@ suspend inline fun <T> runCatchingSafelyWithoutExceptions( | |||||||
| ): Result<T?> = runCatching { | ): Result<T?> = runCatching { | ||||||
|     safelyWithoutExceptions(onException, block) |     safelyWithoutExceptions(onException, block) | ||||||
| } | } | ||||||
|  |  | ||||||
|  | inline fun CoroutineScope( | ||||||
|  |     context: CoroutineContext, | ||||||
|  |     noinline defaultExceptionsHandler: ExceptionHandler<Unit> | ||||||
|  | ) = CoroutineScope( | ||||||
|  |     context + ContextSafelyExceptionHandler(defaultExceptionsHandler) | ||||||
|  | ) | ||||||
|   | |||||||
| @@ -7,29 +7,29 @@ android.useAndroidX=true | |||||||
| android.enableJetifier=true | android.enableJetifier=true | ||||||
| org.gradle.jvmargs=-Xmx2g | org.gradle.jvmargs=-Xmx2g | ||||||
|  |  | ||||||
| kotlin_version=1.5.21 | kotlin_version=1.5.31 | ||||||
| kotlin_coroutines_version=1.5.1 | kotlin_coroutines_version=1.5.2 | ||||||
| kotlin_serialisation_core_version=1.2.2 | kotlin_serialisation_core_version=1.2.2 | ||||||
| kotlin_exposed_version=0.33.1 | kotlin_exposed_version=0.35.1 | ||||||
|  |  | ||||||
| ktor_version=1.6.2 | ktor_version=1.6.3 | ||||||
|  |  | ||||||
| klockVersion=2.3.1 | klockVersion=2.4.2 | ||||||
|  |  | ||||||
| github_release_plugin_version=2.2.12 | github_release_plugin_version=2.2.12 | ||||||
|  |  | ||||||
| uuidVersion=0.3.0 | uuidVersion=0.3.1 | ||||||
|  |  | ||||||
| # ANDROID | # ANDROID | ||||||
|  |  | ||||||
| core_ktx_version=1.6.0 | core_ktx_version=1.6.0 | ||||||
| androidx_recycler_version=1.2.1 | androidx_recycler_version=1.2.1 | ||||||
| appcompat_version=1.3.0 | appcompat_version=1.3.1 | ||||||
|  |  | ||||||
| android_minSdkVersion=19 | android_minSdkVersion=19 | ||||||
| android_compileSdkVersion=30 | android_compileSdkVersion=31 | ||||||
| android_buildToolsVersion=30.0.3 | android_buildToolsVersion=31.0.0 | ||||||
| dexcount_version=2.1.0-RC01 | dexcount_version=3.0.0 | ||||||
| junit_version=4.12 | junit_version=4.12 | ||||||
| test_ext_junit_version=1.1.2 | test_ext_junit_version=1.1.2 | ||||||
| espresso_core=3.3.0 | espresso_core=3.3.0 | ||||||
| @@ -40,10 +40,10 @@ crypto_js_version=4.1.1 | |||||||
|  |  | ||||||
| # Dokka | # Dokka | ||||||
|  |  | ||||||
| dokka_version=1.5.0 | dokka_version=1.5.30 | ||||||
|  |  | ||||||
| # Project data | # Project data | ||||||
|  |  | ||||||
| group=dev.inmo | group=dev.inmo | ||||||
| version=0.5.20 | version=0.5.29 | ||||||
| android_code_version=61 | android_code_version=70 | ||||||
|   | |||||||
							
								
								
									
										2
									
								
								gradle/wrapper/gradle-wrapper.properties
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								gradle/wrapper/gradle-wrapper.properties
									
									
									
									
										vendored
									
									
								
							| @@ -1,5 +1,5 @@ | |||||||
| distributionBase=GRADLE_USER_HOME | distributionBase=GRADLE_USER_HOME | ||||||
| distributionPath=wrapper/dists | distributionPath=wrapper/dists | ||||||
| distributionUrl=https\://services.gradle.org/distributions/gradle-7.1.1-bin.zip | distributionUrl=https\://services.gradle.org/distributions/gradle-7.2-bin.zip | ||||||
| zipStoreBase=GRADLE_USER_HOME | zipStoreBase=GRADLE_USER_HOME | ||||||
| zipStorePath=wrapper/dists | zipStorePath=wrapper/dists | ||||||
|   | |||||||
| @@ -24,3 +24,9 @@ kotlin { | |||||||
| } | } | ||||||
|  |  | ||||||
| apply from: "$defaultAndroidSettingsPresetPath" | apply from: "$defaultAndroidSettingsPresetPath" | ||||||
|  |  | ||||||
|  | java { | ||||||
|  |     toolchain { | ||||||
|  |         languageVersion = JavaLanguageVersion.of(8) | ||||||
|  |     } | ||||||
|  | } | ||||||
|   | |||||||
| @@ -26,3 +26,9 @@ kotlin { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | java { | ||||||
|  |     toolchain { | ||||||
|  |         languageVersion = JavaLanguageVersion.of(8) | ||||||
|  |     } | ||||||
|  | } | ||||||
|   | |||||||
| @@ -48,3 +48,9 @@ kotlin { | |||||||
| } | } | ||||||
|  |  | ||||||
| apply from: "$defaultAndroidSettingsPresetPath" | apply from: "$defaultAndroidSettingsPresetPath" | ||||||
|  |  | ||||||
|  | java { | ||||||
|  |     toolchain { | ||||||
|  |         languageVersion = JavaLanguageVersion.of(8) | ||||||
|  |     } | ||||||
|  | } | ||||||
|   | |||||||
| @@ -23,13 +23,13 @@ class ReadMapCRUDRepo<ObjectType, IdType>( | |||||||
| } | } | ||||||
|  |  | ||||||
| abstract class WriteMapCRUDRepo<ObjectType, IdType, InputValueType>( | abstract class WriteMapCRUDRepo<ObjectType, IdType, InputValueType>( | ||||||
|     private val map: MutableMap<IdType, ObjectType> = mutableMapOf() |     protected val map: MutableMap<IdType, ObjectType> = mutableMapOf() | ||||||
| ) : WriteStandardCRUDRepo<ObjectType, IdType, InputValueType> { | ) : WriteStandardCRUDRepo<ObjectType, IdType, InputValueType> { | ||||||
|     private val _newObjectsFlow: MutableSharedFlow<ObjectType> = MutableSharedFlow() |     protected val _newObjectsFlow: MutableSharedFlow<ObjectType> = MutableSharedFlow() | ||||||
|     override val newObjectsFlow: Flow<ObjectType> = _newObjectsFlow.asSharedFlow() |     override val newObjectsFlow: Flow<ObjectType> = _newObjectsFlow.asSharedFlow() | ||||||
|     private val _updatedObjectsFlow: MutableSharedFlow<ObjectType> = MutableSharedFlow() |     protected val _updatedObjectsFlow: MutableSharedFlow<ObjectType> = MutableSharedFlow() | ||||||
|     override val updatedObjectsFlow: Flow<ObjectType> = _updatedObjectsFlow.asSharedFlow() |     override val updatedObjectsFlow: Flow<ObjectType> = _updatedObjectsFlow.asSharedFlow() | ||||||
|     private val _deletedObjectsIdsFlow: MutableSharedFlow<IdType> = MutableSharedFlow() |     protected val _deletedObjectsIdsFlow: MutableSharedFlow<IdType> = MutableSharedFlow() | ||||||
|     override val deletedObjectsIdsFlow: Flow<IdType> = _deletedObjectsIdsFlow.asSharedFlow() |     override val deletedObjectsIdsFlow: Flow<IdType> = _deletedObjectsIdsFlow.asSharedFlow() | ||||||
|  |  | ||||||
|     protected abstract suspend fun updateObject(newValue: InputValueType, id: IdType, old: ObjectType): ObjectType |     protected abstract suspend fun updateObject(newValue: InputValueType, id: IdType, old: ObjectType): ObjectType | ||||||
|   | |||||||
| @@ -8,7 +8,7 @@ import kotlinx.coroutines.flow.Flow | |||||||
| import kotlinx.coroutines.flow.MutableSharedFlow | import kotlinx.coroutines.flow.MutableSharedFlow | ||||||
|  |  | ||||||
| class ReadMapKeyValueRepo<Key, Value>( | class ReadMapKeyValueRepo<Key, Value>( | ||||||
|     private val map: Map<Key, Value> = emptyMap() |     protected val map: Map<Key, Value> = emptyMap() | ||||||
| ) : ReadStandardKeyValueRepo<Key, Value> { | ) : ReadStandardKeyValueRepo<Key, Value> { | ||||||
|     override suspend fun get(k: Key): Value? = map[k] |     override suspend fun get(k: Key): Value? = map[k] | ||||||
|  |  | ||||||
|   | |||||||
| @@ -8,11 +8,24 @@ import kotlin.reflect.KClass | |||||||
|  |  | ||||||
| open class TypedSerializer<T : Any>( | open class TypedSerializer<T : Any>( | ||||||
|     kClass: KClass<T>, |     kClass: KClass<T>, | ||||||
|     presetSerializers: Map<String, KSerializer<out T>> = emptyMap() |     presetSerializers: Map<String, KSerializer<out T>> = emptyMap(), | ||||||
| ) : KSerializer<T> { | ) : KSerializer<T> { | ||||||
|     protected val serializers = presetSerializers.toMutableMap() |     protected val serializers = presetSerializers.toMutableMap() | ||||||
|  |     @ExperimentalSerializationApi | ||||||
|     @InternalSerializationApi |     @InternalSerializationApi | ||||||
|     open override val descriptor: SerialDescriptor = buildSerialDescriptor( |     override val descriptor: SerialDescriptor = buildSerialDescriptor( | ||||||
|  |         "TypedSerializer", | ||||||
|  |         SerialKind.CONTEXTUAL | ||||||
|  |     ) { | ||||||
|  |         element("type", String.serializer().descriptor) | ||||||
|  |         element("value", ContextualSerializer(kClass).descriptor) | ||||||
|  |     } | ||||||
|  |     @InternalSerializationApi | ||||||
|  |     @Deprecated( | ||||||
|  |         "This descriptor was deprecated due to incorrect serial name. You may use it in case something require it, " + | ||||||
|  |             "but it is strongly recommended to migrate onto new descriptor" | ||||||
|  |     ) | ||||||
|  |     protected val oldDescriptor: SerialDescriptor = buildSerialDescriptor( | ||||||
|         "TextSourceSerializer", |         "TextSourceSerializer", | ||||||
|         SerialKind.CONTEXTUAL |         SerialKind.CONTEXTUAL | ||||||
|     ) { |     ) { | ||||||
| @@ -20,8 +33,9 @@ open class TypedSerializer<T : Any>( | |||||||
|         element("value", ContextualSerializer(kClass).descriptor) |         element("value", ContextualSerializer(kClass).descriptor) | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     @ExperimentalSerializationApi | ||||||
|     @InternalSerializationApi |     @InternalSerializationApi | ||||||
|     open override fun deserialize(decoder: Decoder): T { |     override fun deserialize(decoder: Decoder): T { | ||||||
|         return decoder.decodeStructure(descriptor) { |         return decoder.decodeStructure(descriptor) { | ||||||
|             var type: String? = null |             var type: String? = null | ||||||
|             lateinit var result: T |             lateinit var result: T | ||||||
| @@ -44,13 +58,15 @@ open class TypedSerializer<T : Any>( | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     @ExperimentalSerializationApi | ||||||
|     @InternalSerializationApi |     @InternalSerializationApi | ||||||
|     protected open fun <O: T> CompositeEncoder.encode(value: O) { |     protected open fun <O: T> CompositeEncoder.encode(value: O) { | ||||||
|         encodeSerializableElement(descriptor, 1, value::class.serializer() as KSerializer<O>, value) |         encodeSerializableElement(descriptor, 1, value::class.serializer() as KSerializer<O>, value) | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     @ExperimentalSerializationApi | ||||||
|     @InternalSerializationApi |     @InternalSerializationApi | ||||||
|     open override fun serialize(encoder: Encoder, value: T) { |     override fun serialize(encoder: Encoder, value: T) { | ||||||
|         encoder.encodeStructure(descriptor) { |         encoder.encodeStructure(descriptor) { | ||||||
|             val valueSerializer = value::class.serializer() |             val valueSerializer = value::class.serializer() | ||||||
|             val type = serializers.keys.first { serializers[it] == valueSerializer } |             val type = serializers.keys.first { serializers[it] == valueSerializer } | ||||||
| @@ -69,6 +85,16 @@ open class TypedSerializer<T : Any>( | |||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @InternalSerializationApi | ||||||
|  | operator fun <T : Any> TypedSerializer<T>.plusAssign(kClass: KClass<T>) { | ||||||
|  |     include(kClass.simpleName!!, kClass.serializer()) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | @InternalSerializationApi | ||||||
|  | operator fun <T : Any> TypedSerializer<T>.minusAssign(kClass: KClass<T>) { | ||||||
|  |     exclude(kClass.simpleName!!) | ||||||
|  | } | ||||||
|  |  | ||||||
| inline fun <reified T : Any> TypedSerializer( | inline fun <reified T : Any> TypedSerializer( | ||||||
|     presetSerializers: Map<String, KSerializer<out T>> = emptyMap() |     presetSerializers: Map<String, KSerializer<out T>> = emptyMap() | ||||||
| ) = TypedSerializer(T::class, presetSerializers) | ) = TypedSerializer(T::class, presetSerializers) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user