From 438db8125291260b17e032b2fa73e00510bf4d12 Mon Sep 17 00:00:00 2001 From: Dewan Tawsif Date: Sat, 28 Sep 2024 08:24:04 +0600 Subject: [PATCH] Fix '?' prefix being unescaped on Android target --- .../main/kotlin/dev/icerock/gradle/utils/StringExt.kt | 10 +++------- .../stringsGenerator/XmlStringsToPlatformTest.kt | 10 +++++++++- 2 files changed, 12 insertions(+), 8 deletions(-) diff --git a/resources-generator/src/main/kotlin/dev/icerock/gradle/utils/StringExt.kt b/resources-generator/src/main/kotlin/dev/icerock/gradle/utils/StringExt.kt index f527d751..6f334b94 100644 --- a/resources-generator/src/main/kotlin/dev/icerock/gradle/utils/StringExt.kt +++ b/resources-generator/src/main/kotlin/dev/icerock/gradle/utils/StringExt.kt @@ -57,6 +57,8 @@ internal fun String.removeAndroidMirroringFormat(): String { .replace("""\@""", "@") } +private val androidLinkingCharacters = setOf('@', '?') + internal fun String.convertXmlStringToAndroidLocalization(): String { // Android resources should comply with requirements: // https://developer.android.com/guide/topics/resources/string-resource#escaping_quotes @@ -64,13 +66,7 @@ internal fun String.convertXmlStringToAndroidLocalization(): String { .unescapeXml(this) .replace("\n", "\\n") .let { StringEscapeUtils.escapeXml11(it) } - .let { - if (it.getOrNull(0) == '@') { - replaceFirst("@", """\@""") - } else { - it - } - } + .replaceFirstChar { if (it in androidLinkingCharacters) "\\$it" else "$it" } .replace(""", "\\"") .replace("'", "\\'") } diff --git a/resources-generator/src/test/kotlin/dev/icerock/gradle/generator/stringsGenerator/XmlStringsToPlatformTest.kt b/resources-generator/src/test/kotlin/dev/icerock/gradle/generator/stringsGenerator/XmlStringsToPlatformTest.kt index df66f22e..c188fc5b 100644 --- a/resources-generator/src/test/kotlin/dev/icerock/gradle/generator/stringsGenerator/XmlStringsToPlatformTest.kt +++ b/resources-generator/src/test/kotlin/dev/icerock/gradle/generator/stringsGenerator/XmlStringsToPlatformTest.kt @@ -124,10 +124,18 @@ class XmlStringsToPlatformTest { } @Test - fun stringLikeAndroidLinkOnStringAndroidTest() { + fun stringLikeAndroidResourceLinkOnStringAndroidTest() { assertEquals( expected = """\@same text""", actual = """@same text""".convertXmlStringToAndroidLocalization() ) } + + @Test + fun stringLikeAndroidAttributeLinkOnStringAndroidTest() { + assertEquals( + expected = """\?same text""", + actual = """?same text""".convertXmlStringToAndroidLocalization() + ) + } }