From dd7734dfcf5da9b4089a656b4727b8a9c36ef1b6 Mon Sep 17 00:00:00 2001 From: DatLag Date: Thu, 30 May 2024 19:58:42 +0200 Subject: [PATCH] fix datastore crash --- .../aniflow/module/PlatformModule.android.kt | 18 ++++++++++++++++-- 1 file changed, 16 insertions(+), 2 deletions(-) diff --git a/composeApp/src/androidMain/kotlin/dev/datlag/aniflow/module/PlatformModule.android.kt b/composeApp/src/androidMain/kotlin/dev/datlag/aniflow/module/PlatformModule.android.kt index d0fd305..f108c76 100644 --- a/composeApp/src/androidMain/kotlin/dev/datlag/aniflow/module/PlatformModule.android.kt +++ b/composeApp/src/androidMain/kotlin/dev/datlag/aniflow/module/PlatformModule.android.kt @@ -17,6 +17,8 @@ import dev.datlag.aniflow.other.BurningSeriesResolver import dev.datlag.aniflow.other.Constants import dev.datlag.aniflow.other.StateSaver import dev.datlag.aniflow.settings.* +import dev.datlag.tooling.createAsFileSafely +import dev.datlag.tooling.existsRWSafely import io.github.aakira.napier.Napier import io.ktor.client.* import io.ktor.client.engine.okhttp.* @@ -97,7 +99,13 @@ actual object PlatformModule { fileSystem = FileSystem.SYSTEM, serializer = UserSettingsSerializer, producePath = { - app.filesDir.toOkioPath().resolve("datastore").resolve("user.settings") + val path = app.filesDir.toOkioPath() + .resolve("datastore") + .resolve("user.settings").also { + it.toFile().createAsFileSafely() + } + + path } ) ) @@ -109,7 +117,13 @@ actual object PlatformModule { fileSystem = FileSystem.SYSTEM, serializer = AppSettingsSerializer, producePath = { - app.filesDir.toOkioPath().resolve("datastore").resolve("app.settings") + val path = app.filesDir.toOkioPath() + .resolve("datastore") + .resolve("app.settings").also { + it.toFile().createAsFileSafely() + } + + path } ) )