From 0ce6ab5f2c8a5b695c72a185b25aed4de0957b49 Mon Sep 17 00:00:00 2001 From: hoangchungk53qx1 Date: Thu, 12 Oct 2023 18:04:48 +0700 Subject: [PATCH 1/2] refactor and optimize queryString --- .../precompose/navigation/QueryString.kt | 18 +++++----------- .../precompose/navigation/QueryStringTest.kt | 21 +++++++++++++------ 2 files changed, 20 insertions(+), 19 deletions(-) diff --git a/precompose/src/commonMain/kotlin/moe/tlaster/precompose/navigation/QueryString.kt b/precompose/src/commonMain/kotlin/moe/tlaster/precompose/navigation/QueryString.kt index 1ac19bf4..1f8b49e1 100644 --- a/precompose/src/commonMain/kotlin/moe/tlaster/precompose/navigation/QueryString.kt +++ b/precompose/src/commonMain/kotlin/moe/tlaster/precompose/navigation/QueryString.kt @@ -5,20 +5,12 @@ data class QueryString( ) { val map by lazy { rawInput - .split("?") - .lastOrNull() - .let { - it ?: "" - } - .split("&") - .asSequence() + .substringAfter("?") + .splitToSequence("&") .map { it.split("=") } - .filter { !it.firstOrNull().isNullOrEmpty() } - .filter { it.size in 1..2 } - .map { it[0] to it.elementAtOrNull(1) } - .groupBy { it.first } - .map { it.key to it.value.mapNotNull { it.second.takeIf { !it.isNullOrEmpty() } } } - .toList() + .filter { it.size in 1..2 && it[0].isNotEmpty() } + .groupBy({ it[0] }, { it.getOrNull(1) }) + .map { it -> it.key to it.value.mapNotNull { it?.takeIf { it.isNotEmpty() } } } .toMap() } } diff --git a/precompose/src/commonTest/kotlin/moe/tlaster/precompose/navigation/QueryStringTest.kt b/precompose/src/commonTest/kotlin/moe/tlaster/precompose/navigation/QueryStringTest.kt index 9f66ac1f..4021b5c6 100644 --- a/precompose/src/commonTest/kotlin/moe/tlaster/precompose/navigation/QueryStringTest.kt +++ b/precompose/src/commonTest/kotlin/moe/tlaster/precompose/navigation/QueryStringTest.kt @@ -7,30 +7,35 @@ import kotlin.test.assertTrue class QueryStringTest { @Test fun simpleQueryString() { + QueryString("&foo=bar").let { assertTrue(it.map.size == 1) assertTrue(it.map.containsKey("foo")) assertTrue(it.map.containsValue(listOf("bar"))) assertEquals(it.query("foo"), "bar") } + QueryString("foo=bar&").let { assertTrue(it.map.size == 1) assertTrue(it.map.containsKey("foo")) assertTrue(it.map.containsValue(listOf("bar"))) assertEquals(it.query("foo"), "bar") } + QueryString("foo=bar&&").let { assertTrue(it.map.size == 1) assertTrue(it.map.containsKey("foo")) assertTrue(it.map.containsValue(listOf("bar"))) assertEquals(it.query("foo"), "bar") } + QueryString("foo=bar").let { assertTrue(it.map.size == 1) assertTrue(it.map.containsKey("foo")) assertTrue(it.map.containsValue(listOf("bar"))) assertEquals(it.query("foo"), "bar") } + QueryString("a=1&b=2").let { assertTrue(it.map.size == 2) assertTrue(it.map.containsKey("a")) @@ -40,6 +45,7 @@ class QueryStringTest { assertEquals(it.query("a"), "1") assertEquals(it.query("b"), "2") } + QueryString("a=1&b=2&").let { assertTrue(it.map.size == 2) assertTrue(it.map.containsKey("a")) @@ -49,6 +55,7 @@ class QueryStringTest { assertEquals(it.query("a"), "1") assertEquals(it.query("b"), "2") } + QueryString("a=1&&b=2&").let { assertTrue(it.map.size == 2) assertTrue(it.map.containsKey("a")) @@ -58,32 +65,34 @@ class QueryStringTest { assertEquals(it.query("a"), "1") assertEquals(it.query("b"), "2") } + QueryString("a=1&a=2").let { assertTrue(it.map.size == 1) assertTrue(it.map.containsKey("a")) assertTrue(it.map.containsValue(listOf("1", "2"))) assertEquals(it.queryList("a"), listOf("1", "2")) } - QueryString("a=1;a=2").let { - assertTrue(it.map.isEmpty()) - } + + assertTrue(QueryString("a=1;a=2").map.isEmpty()) + QueryString("a=").let { assertTrue(it.map.size == 1) assertTrue(it.map.containsKey("a")) assertEquals(it.queryList("a"), emptyList()) } + QueryString("a=&").let { assertTrue(it.map.size == 1) assertTrue(it.map.containsKey("a")) assertEquals(it.queryList("a"), emptyList()) } + QueryString("a=&&").let { assertTrue(it.map.size == 1) assertTrue(it.map.containsKey("a")) assertEquals(it.queryList("a"), emptyList()) } - QueryString("").let { - assertTrue(it.map.isEmpty()) - } + + assertTrue(QueryString("").map.isEmpty()) } } From 32fb8661db54eb1cbf564b191e179319842cb4e7 Mon Sep 17 00:00:00 2001 From: hoangchungk53qx1 Date: Fri, 13 Oct 2023 09:29:15 +0700 Subject: [PATCH 2/2] spotless apply --- .../kotlin/moe/tlaster/precompose/navigation/QueryStringTest.kt | 1 - 1 file changed, 1 deletion(-) diff --git a/precompose/src/commonTest/kotlin/moe/tlaster/precompose/navigation/QueryStringTest.kt b/precompose/src/commonTest/kotlin/moe/tlaster/precompose/navigation/QueryStringTest.kt index 4021b5c6..bf9def31 100644 --- a/precompose/src/commonTest/kotlin/moe/tlaster/precompose/navigation/QueryStringTest.kt +++ b/precompose/src/commonTest/kotlin/moe/tlaster/precompose/navigation/QueryStringTest.kt @@ -7,7 +7,6 @@ import kotlin.test.assertTrue class QueryStringTest { @Test fun simpleQueryString() { - QueryString("&foo=bar").let { assertTrue(it.map.size == 1) assertTrue(it.map.containsKey("foo"))