mirror of
				https://github.com/InsanusMokrassar/MicroUtils.git
				synced 2025-10-25 17:20:24 +00:00 
			
		
		
		
	Compare commits
	
		
			26 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| f78359b5d7 | |||
| dbce612cb2 | |||
| 4322ffdb0a | |||
| 123b848d74 | |||
| b120fbd2b1 | |||
| d41c3c2de4 | |||
| a3cabd7a9e | |||
| 3dde486126 | |||
| 5978122dda | |||
| 4b4806ce34 | |||
| 987c6cc709 | |||
| 012c7e9bdf | |||
| d06bb265e5 | |||
| e2fb8bf21e | |||
| 60dea2a518 | |||
| 3877f49278 | |||
| a299a5b505 | |||
| a03f7201d2 | |||
| 94e26ee8a0 | |||
| 2d8ad47083 | |||
| e9aec238a1 | |||
| 844c33166c | |||
| cfe9f2159f | |||
| 61bccd5f48 | |||
| e5a608a315 | |||
| 9b4f35eea1 | 
							
								
								
									
										16
									
								
								.github/workflows/gradle_build.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								.github/workflows/gradle_build.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,16 @@ | |||||||
|  | name: Build | ||||||
|  |  | ||||||
|  | on: [push] | ||||||
|  |  | ||||||
|  | jobs: | ||||||
|  |   build: | ||||||
|  |     runs-on: ubuntu-latest | ||||||
|  |  | ||||||
|  |     steps: | ||||||
|  |       - uses: actions/checkout@v2 | ||||||
|  |       - name: Set up JDK 1.8 | ||||||
|  |         uses: actions/setup-java@v1 | ||||||
|  |         with: | ||||||
|  |           java-version: 1.8 | ||||||
|  |       - name: Build with Gradle | ||||||
|  |         run: ./gradlew build | ||||||
							
								
								
									
										33
									
								
								CHANGELOG.md
									
									
									
									
									
								
							
							
						
						
									
										33
									
								
								CHANGELOG.md
									
									
									
									
									
								
							| @@ -1,5 +1,38 @@ | |||||||
| # Changelog | # Changelog | ||||||
|  |  | ||||||
|  | ## 0.4.26 | ||||||
|  |  | ||||||
|  | * `Versions`: | ||||||
|  |     * `Serialization`: `1.0.1` -> `1.1.0` | ||||||
|  |  | ||||||
|  | ## 0.4.25 | ||||||
|  |  | ||||||
|  | * `Matrix`: | ||||||
|  |     * Subproject has been created | ||||||
|  |  | ||||||
|  | ## 0.4.24 | ||||||
|  |  | ||||||
|  | * `Versions`: | ||||||
|  |     * `Kotlin`: `1.4.21` -> `1.4.30` | ||||||
|  |     * `Klock`: `2.0.4` -> `2.0.6` | ||||||
|  | * `Coroutines`: | ||||||
|  |     * New class `DoWithFirstBuilder` | ||||||
|  |     * Several new extensions like `firstOf`/`first`/`invokeOnFirstOf` | ||||||
|  |  | ||||||
|  | ## 0.4.23 | ||||||
|  |  | ||||||
|  | * `Versions`: | ||||||
|  |     * `Ktor`: `1.5.0` -> `1.5.1` | ||||||
|  | * `Serialization` | ||||||
|  |     * `Base64` | ||||||
|  |         * New serializer `Base64BytesToFromStringSerializer` has been added | ||||||
|  |  | ||||||
|  | ## 0.4.22 | ||||||
|  |  | ||||||
|  | * `Versions`: | ||||||
|  |     * `Exposed`: `0.28.1` -> `0.29.1` | ||||||
|  |     * `Klock`: `2.0.2` -> `2.0.4` | ||||||
|  |  | ||||||
| ## 0.4.21 | ## 0.4.21 | ||||||
|  |  | ||||||
| * `Common` | * `Common` | ||||||
|   | |||||||
| @@ -9,6 +9,19 @@ class DeferredAction<T, O>( | |||||||
|     suspend operator fun invoke() = callback(deferred.await()) |     suspend operator fun invoke() = callback(deferred.await()) | ||||||
| } | } | ||||||
|  |  | ||||||
|  | class DoWithFirstBuilder<T>( | ||||||
|  |     private val scope: CoroutineScope | ||||||
|  | ) { | ||||||
|  |     private val deferreds = mutableListOf<Deferred<T>>() | ||||||
|  |     operator fun plus(block: suspend CoroutineScope.() -> T) { | ||||||
|  |         deferreds.add(scope.async(start = CoroutineStart.LAZY, block = block)) | ||||||
|  |     } | ||||||
|  |     inline fun add(noinline block: suspend CoroutineScope.() -> T) = plus(block) | ||||||
|  |     inline fun include(noinline block: suspend CoroutineScope.() -> T) = plus(block) | ||||||
|  |  | ||||||
|  |     fun build() = deferreds.toList() | ||||||
|  | } | ||||||
|  |  | ||||||
| fun <T, O> Deferred<T>.buildAction(callback: suspend (T) -> O) = DeferredAction(this, callback) | fun <T, O> Deferred<T>.buildAction(callback: suspend (T) -> O) = DeferredAction(this, callback) | ||||||
|  |  | ||||||
| suspend fun <O> Iterable<DeferredAction<*, O>>.invokeFirstOf( | suspend fun <O> Iterable<DeferredAction<*, O>>.invokeFirstOf( | ||||||
| @@ -32,9 +45,41 @@ suspend fun <T, O> Iterable<Deferred<T>>.invokeOnFirst( | |||||||
|     callback: suspend (T) -> O |     callback: suspend (T) -> O | ||||||
| ): O = map { it.buildAction(callback) }.invokeFirstOf(scope, cancelOnResult) | ): O = map { it.buildAction(callback) }.invokeFirstOf(scope, cancelOnResult) | ||||||
|  |  | ||||||
|  | suspend fun <T, O> CoroutineScope.invokeOnFirstOf( | ||||||
|  |     cancelOnResult: Boolean = true, | ||||||
|  |     block: DoWithFirstBuilder<T>.() -> Unit, | ||||||
|  |     callback: suspend (T) -> O | ||||||
|  | ) = firstOf( | ||||||
|  |     DoWithFirstBuilder<T>(this).apply(block).build(), | ||||||
|  |     cancelOnResult | ||||||
|  | ).let { callback(it) } | ||||||
|  |  | ||||||
| suspend fun <T, O> invokeOnFirst( | suspend fun <T, O> invokeOnFirst( | ||||||
|     scope: CoroutineScope, |     scope: CoroutineScope, | ||||||
|     vararg variants: Deferred<T>, |     vararg variants: Deferred<T>, | ||||||
|     cancelOnResult: Boolean = true, |     cancelOnResult: Boolean = true, | ||||||
|     callback: suspend (T) -> O |     callback: suspend (T) -> O | ||||||
| ): O = variants.toList().invokeOnFirst(scope, cancelOnResult, callback) | ): O = variants.toList().invokeOnFirst(scope, cancelOnResult, callback) | ||||||
|  |  | ||||||
|  | suspend fun <T> CoroutineScope.firstOf( | ||||||
|  |     variants: Iterable<Deferred<T>>, | ||||||
|  |     cancelOnResult: Boolean = true | ||||||
|  | ) = variants.invokeOnFirst(this, cancelOnResult) { it } | ||||||
|  |  | ||||||
|  | suspend fun <T> CoroutineScope.firstOf( | ||||||
|  |     cancelOnResult: Boolean = true, | ||||||
|  |     block: DoWithFirstBuilder<T>.() -> Unit | ||||||
|  | ) = firstOf( | ||||||
|  |     DoWithFirstBuilder<T>(this).apply(block).build(), | ||||||
|  |     cancelOnResult | ||||||
|  | ) | ||||||
|  |  | ||||||
|  | suspend fun <T> CoroutineScope.firstOf( | ||||||
|  |     vararg variants: Deferred<T>, | ||||||
|  |     cancelOnResult: Boolean = true | ||||||
|  | ) = firstOf(variants.toList(), cancelOnResult) | ||||||
|  |  | ||||||
|  | suspend fun <T> List<Deferred<T>>.first( | ||||||
|  |     scope: CoroutineScope, | ||||||
|  |     cancelOnResult: Boolean = true | ||||||
|  | ) = scope.firstOf(this, cancelOnResult) | ||||||
|   | |||||||
| @@ -6,14 +6,14 @@ kotlin.incremental.js=true | |||||||
| android.useAndroidX=true | android.useAndroidX=true | ||||||
| android.enableJetifier=true | android.enableJetifier=true | ||||||
|  |  | ||||||
| kotlin_version=1.4.21 | kotlin_version=1.4.30 | ||||||
| kotlin_coroutines_version=1.4.2 | kotlin_coroutines_version=1.4.2 | ||||||
| kotlin_serialisation_core_version=1.0.1 | kotlin_serialisation_core_version=1.1.0 | ||||||
| kotlin_exposed_version=0.28.1 | kotlin_exposed_version=0.29.1 | ||||||
|  |  | ||||||
| ktor_version=1.5.0 | ktor_version=1.5.1 | ||||||
|  |  | ||||||
| klockVersion=2.0.2 | klockVersion=2.0.6 | ||||||
|  |  | ||||||
| github_release_plugin_version=2.2.12 | github_release_plugin_version=2.2.12 | ||||||
|  |  | ||||||
| @@ -44,5 +44,5 @@ dokka_version=1.4.20 | |||||||
| # Project data | # Project data | ||||||
|  |  | ||||||
| group=dev.inmo | group=dev.inmo | ||||||
| version=0.4.21 | version=0.4.26 | ||||||
| android_code_version=25 | android_code_version=30 | ||||||
|   | |||||||
							
								
								
									
										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-6.7.1-bin.zip | distributionUrl=https\://services.gradle.org/distributions/gradle-6.8.1-bin.zip | ||||||
| zipStoreBase=GRADLE_USER_HOME | zipStoreBase=GRADLE_USER_HOME | ||||||
| zipStorePath=wrapper/dists | zipStorePath=wrapper/dists | ||||||
|   | |||||||
							
								
								
									
										7
									
								
								matrix/build.gradle
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								matrix/build.gradle
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | |||||||
|  | plugins { | ||||||
|  |     id "org.jetbrains.kotlin.multiplatform" | ||||||
|  |     id "org.jetbrains.kotlin.plugin.serialization" | ||||||
|  |     id "com.android.library" | ||||||
|  | } | ||||||
|  |  | ||||||
|  | apply from: "$mppProjectWithSerializationPresetPath" | ||||||
| @@ -0,0 +1,3 @@ | |||||||
|  | package dev.inmo.micro_utils.matrix | ||||||
|  |  | ||||||
|  | typealias Matrix<T> = List<Row<T>> | ||||||
| @@ -0,0 +1,13 @@ | |||||||
|  | package dev.inmo.micro_utils.matrix | ||||||
|  |  | ||||||
|  | class MatrixBuilder<T> { | ||||||
|  |     private val mutMatrix: MutableList<List<T>> = ArrayList() | ||||||
|  |     val matrix: Matrix<T> | ||||||
|  |         get() = mutMatrix | ||||||
|  |  | ||||||
|  |     fun row(t: List<T>) = mutMatrix.add(t) | ||||||
|  |     operator fun List<T>.unaryPlus() = row(this) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | fun <T> MatrixBuilder<T>.row(block: RowBuilder<T>.() -> Unit) = +RowBuilder<T>().also(block).row | ||||||
|  | fun <T> MatrixBuilder<T>.row(vararg elements: T) = +elements.toList() | ||||||
| @@ -0,0 +1,17 @@ | |||||||
|  | package dev.inmo.micro_utils.matrix | ||||||
|  |  | ||||||
|  | fun <T> matrix(block: MatrixBuilder<T>.() -> Unit): Matrix<T> { | ||||||
|  |     return MatrixBuilder<T>().also(block).matrix | ||||||
|  | } | ||||||
|  |  | ||||||
|  | fun <T> flatMatrix(block: RowBuilder<T>.() -> Unit): Matrix<T> { | ||||||
|  |     return MatrixBuilder<T>().apply { | ||||||
|  |         row(block) | ||||||
|  |     }.matrix | ||||||
|  | } | ||||||
|  |  | ||||||
|  | fun <T> flatMatrix(vararg elements: T): Matrix<T> { | ||||||
|  |     return MatrixBuilder<T>().apply { | ||||||
|  |         row { elements.forEach { +it } } | ||||||
|  |     }.matrix | ||||||
|  | } | ||||||
| @@ -0,0 +1,3 @@ | |||||||
|  | package dev.inmo.micro_utils.matrix | ||||||
|  |  | ||||||
|  | typealias Row<T> = List<T> | ||||||
| @@ -0,0 +1,14 @@ | |||||||
|  | package dev.inmo.micro_utils.matrix | ||||||
|  |  | ||||||
|  | class RowBuilder<T> { | ||||||
|  |     private val mutRow: MutableList<T> = ArrayList() | ||||||
|  |     val row: Row<T> | ||||||
|  |         get() = mutRow | ||||||
|  |  | ||||||
|  |     fun column(t: T) = mutRow.add(t) | ||||||
|  |     operator fun T.unaryPlus() = column(this) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | fun <T> row(block: RowBuilder<T>.() -> Unit): List<T> = RowBuilder<T>().also(block).row | ||||||
|  | fun <T> RowBuilder<T>.columns(elements: List<T>) = elements.forEach(::column) | ||||||
|  | fun <T> RowBuilder<T>.columns(vararg elements: T) = elements.forEach(::column) | ||||||
| @@ -0,0 +1,45 @@ | |||||||
|  | package dev.inmo.micro_utils.matrix | ||||||
|  |  | ||||||
|  | import kotlin.test.Test | ||||||
|  | import kotlin.test.assertEquals | ||||||
|  |  | ||||||
|  | class SimpleTest { | ||||||
|  |     @Test | ||||||
|  |     fun simpleTest() { | ||||||
|  |         val expected = listOf( | ||||||
|  |             listOf(1, 2, 3), | ||||||
|  |             listOf(4, 5, 6) | ||||||
|  |         ) | ||||||
|  |  | ||||||
|  |         val fromMatrixWithVarargs = matrix<Int> { | ||||||
|  |             row(1, 2, 3) | ||||||
|  |             row(4, 5, 6) | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         val fromMatrixWithColumnsVarargs = matrix<Int> { | ||||||
|  |             row { | ||||||
|  |                 columns(1, 2, 3) | ||||||
|  |             } | ||||||
|  |             row { | ||||||
|  |                 columns(4, 5, 6) | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         val fromMatrixWithSimpleAdd = matrix<Int> { | ||||||
|  |             row { | ||||||
|  |                 column(1) | ||||||
|  |                 column(2) | ||||||
|  |                 column(3) | ||||||
|  |             } | ||||||
|  |             row { | ||||||
|  |                 column(4) | ||||||
|  |                 column(5) | ||||||
|  |                 column(6) | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         assertEquals(expected, fromMatrixWithVarargs) | ||||||
|  |         assertEquals(expected, fromMatrixWithColumnsVarargs) | ||||||
|  |         assertEquals(expected, fromMatrixWithSimpleAdd) | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										1
									
								
								matrix/src/main/AndroidManifest.xml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								matrix/src/main/AndroidManifest.xml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | <manifest package="dev.inmo.micro_utils.matrix"/> | ||||||
| @@ -4,7 +4,9 @@ project.group = "$group" | |||||||
| apply from: "$publishGradlePath" | apply from: "$publishGradlePath" | ||||||
|  |  | ||||||
| kotlin { | kotlin { | ||||||
|     jvm() |     jvm { | ||||||
|  |         compilations.main.kotlinOptions.useIR = true | ||||||
|  |     } | ||||||
|  |  | ||||||
|     sourceSets { |     sourceSets { | ||||||
|         commonMain { |         commonMain { | ||||||
|   | |||||||
| @@ -4,7 +4,9 @@ project.group = "$group" | |||||||
| apply from: "$publishGradlePath" | apply from: "$publishGradlePath" | ||||||
|  |  | ||||||
| kotlin { | kotlin { | ||||||
|     jvm() |     jvm { | ||||||
|  |         compilations.main.kotlinOptions.useIR = true | ||||||
|  |     } | ||||||
|     js (BOTH) { |     js (BOTH) { | ||||||
|         browser() |         browser() | ||||||
|         nodejs() |         nodejs() | ||||||
|   | |||||||
| @@ -1 +1 @@ | |||||||
| {"bintrayConfig":{"repo":"MicroUtils","packageName":"${project.name}","packageVcs":"https://github.com/InsanusMokrassar/MicroUtils","autoPublish":true,"overridePublish":true},"licenses":[{"id":"Apache-2.0","title":"Apache Software License 2.0","url":"https://git.inmo.dev/InsanusMokrassar/MicroUtils_mirror/src/master/LICENSE"}],"mavenConfig":{"name":"${project.name}","description":"","url":"https://git.inmo.dev/InsanusMokrassar/MicroUtils_mirror","vcsUrl":"ssh://git@git.inmo.dev:8322/InsanusMokrassar/MicroUtils_mirror.git","developers":[{"id":"InsanusMokrassar","name":"Aleksei Ovsiannikov","eMail":"ovsyannikov.alexey95@gmail.com"},{"id":"000Sanya","name":"Syrov Aleksandr","eMail":"000sanya.000sanya@gmail.com"}]}} | {"bintrayConfig":{"repo":"MicroUtils","packageName":"${project.name}","packageVcs":"https://github.com/InsanusMokrassar/MicroUtils","autoPublish":true,"overridePublish":true},"licenses":[{"id":"Apache-2.0","title":"Apache Software License 2.0","url":"https://git.inmo.dev/InsanusMokrassar/MicroUtils_mirror/src/master/LICENSE"}],"mavenConfig":{"name":"${project.name}","description":"It is set of projects with micro tools for avoiding of routines coding","url":"https://git.inmo.dev/InsanusMokrassar/MicroUtils_mirror","vcsUrl":"ssh://git@git.inmo.dev:8322/InsanusMokrassar/MicroUtils_mirror.git","includeGpgSigning":true,"publishToMavenCentral":true,"developers":[{"id":"InsanusMokrassar","name":"Aleksei Ovsiannikov","eMail":"ovsyannikov.alexey95@gmail.com"},{"id":"000Sanya","name":"Syrov Aleksandr","eMail":"000sanya.000sanya@gmail.com"}]}} | ||||||
| @@ -1,31 +1,16 @@ | |||||||
| apply plugin: 'maven-publish' | apply plugin: 'maven-publish' | ||||||
|  | apply plugin: 'signing' | ||||||
|  |  | ||||||
| task javadocsJar(type: Jar) { | task javadocsJar(type: Jar) { | ||||||
|     classifier = 'javadoc' |     classifier = 'javadoc' | ||||||
| } | } | ||||||
| task sourceJar (type : Jar) { |  | ||||||
|     classifier = 'sources' |  | ||||||
| } |  | ||||||
|  |  | ||||||
| afterEvaluate { |  | ||||||
|     project.publishing.publications.all { |  | ||||||
|         // rename artifacts |  | ||||||
|         groupId "${project.group}" |  | ||||||
|         if (it.name.contains('kotlinMultiplatform')) { |  | ||||||
|             artifactId = "${project.name}" |  | ||||||
|             artifact sourceJar |  | ||||||
|         } else { |  | ||||||
|             artifactId = "${project.name}-$name" |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| publishing { | publishing { | ||||||
|     publications.all { |     publications.all { | ||||||
|         artifact javadocsJar |         artifact javadocsJar | ||||||
|  |  | ||||||
|         pom { |         pom { | ||||||
|             description = "" |             description = "It is set of projects with micro tools for avoiding of routines coding" | ||||||
|             name = "${project.name}" |             name = "${project.name}" | ||||||
|             url = "https://git.inmo.dev/InsanusMokrassar/MicroUtils_mirror" |             url = "https://git.inmo.dev/InsanusMokrassar/MicroUtils_mirror" | ||||||
|  |  | ||||||
| @@ -70,7 +55,22 @@ publishing { | |||||||
|                     password = project.hasProperty('BINTRAY_KEY') ? project.property('BINTRAY_KEY') : System.getenv('BINTRAY_KEY') |                     password = project.hasProperty('BINTRAY_KEY') ? project.property('BINTRAY_KEY') : System.getenv('BINTRAY_KEY') | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|  |              | ||||||
|  |             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') | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |              | ||||||
|         } |         } | ||||||
|          |          | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | signing { | ||||||
|  |     useGpgCmd() | ||||||
|  |     sign publishing.publications | ||||||
|  | } | ||||||
|   | |||||||
| @@ -0,0 +1,17 @@ | |||||||
|  | package dev.inmo.micro_utils.serialization.base64 | ||||||
|  |  | ||||||
|  | import dev.inmo.micro_utils.crypto.* | ||||||
|  | import kotlinx.serialization.KSerializer | ||||||
|  | import kotlinx.serialization.builtins.serializer | ||||||
|  | import kotlinx.serialization.descriptors.SerialDescriptor | ||||||
|  | import kotlinx.serialization.encoding.Decoder | ||||||
|  | import kotlinx.serialization.encoding.Encoder | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Converts [ByteArray] into base64 encoded string due to serialization and decode base64 encoded string into bytes | ||||||
|  |  */ | ||||||
|  | object Base64BytesToFromStringSerializer: KSerializer<ByteArray> { | ||||||
|  |     override val descriptor: SerialDescriptor = String.serializer().descriptor | ||||||
|  |     override fun deserialize(decoder: Decoder): SourceBytes = decoder.decodeString().decodeBase64() | ||||||
|  |     override fun serialize(encoder: Encoder, value: SourceBytes) = encoder.encodeString(value.encodeBase64String()) | ||||||
|  | } | ||||||
| @@ -1,9 +1,6 @@ | |||||||
| package dev.inmo.micro_utils.serialization.base64 | package dev.inmo.micro_utils.serialization.base64 | ||||||
|  |  | ||||||
| import dev.inmo.micro_utils.crypto.* |  | ||||||
| import kotlinx.serialization.KSerializer | import kotlinx.serialization.KSerializer | ||||||
| import kotlinx.serialization.Serializer |  | ||||||
| import kotlinx.serialization.builtins.serializer |  | ||||||
| import kotlinx.serialization.descriptors.SerialDescriptor | import kotlinx.serialization.descriptors.SerialDescriptor | ||||||
| import kotlinx.serialization.encoding.Decoder | import kotlinx.serialization.encoding.Decoder | ||||||
| import kotlinx.serialization.encoding.Encoder | import kotlinx.serialization.encoding.Encoder | ||||||
| @@ -12,9 +9,9 @@ open class Base64Serializer<T>( | |||||||
|     private val converterFrom: (T) -> String, |     private val converterFrom: (T) -> String, | ||||||
|     private val converterTo: (String) -> T, |     private val converterTo: (String) -> T, | ||||||
| ) : KSerializer<T> { | ) : KSerializer<T> { | ||||||
|     override val descriptor: SerialDescriptor = String.serializer().descriptor |     override val descriptor: SerialDescriptor = Base64BytesToFromStringSerializer.descriptor | ||||||
|     override fun deserialize(decoder: Decoder): T = converterTo(decoder.decodeString().decodeBase64String()) |     override fun deserialize(decoder: Decoder): T = converterTo(Base64BytesToFromStringSerializer.deserialize(decoder).decodeToString()) | ||||||
|     override fun serialize(encoder: Encoder, value: T) = encoder.encodeString(converterFrom(value).encodeBase64String()) |     override fun serialize(encoder: Encoder, value: T) = Base64BytesToFromStringSerializer.serialize(encoder, converterFrom(value).encodeToByteArray()) | ||||||
| } | } | ||||||
|  |  | ||||||
| object Base64StringSerializer : Base64Serializer<String>({ it }, { it }) | object Base64StringSerializer : Base64Serializer<String>({ it }, { it }) | ||||||
|   | |||||||
| @@ -2,6 +2,7 @@ rootProject.name='micro_utils' | |||||||
|  |  | ||||||
| String[] includes = [ | String[] includes = [ | ||||||
|     ":common", |     ":common", | ||||||
|  |     ":matrix", | ||||||
|     ":crypto", |     ":crypto", | ||||||
|     ":selector:common", |     ":selector:common", | ||||||
|     ":pagination:common", |     ":pagination:common", | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user