From d3f4ed5dd4cc7566ac3f991ad673150007edb9d1 Mon Sep 17 00:00:00 2001 From: Alexander Capehart Date: Fri, 27 Dec 2024 15:50:53 -0500 Subject: [PATCH] musikr: separate silo and covers --- .../oxycblt/auxio/music/covers/CoverSilo.kt | 44 +++++++++++++++++++ .../auxio/music/covers/SiloedCovers.kt | 24 ---------- 2 files changed, 44 insertions(+), 24 deletions(-) create mode 100644 app/src/main/java/org/oxycblt/auxio/music/covers/CoverSilo.kt diff --git a/app/src/main/java/org/oxycblt/auxio/music/covers/CoverSilo.kt b/app/src/main/java/org/oxycblt/auxio/music/covers/CoverSilo.kt new file mode 100644 index 000000000..8067b5c78 --- /dev/null +++ b/app/src/main/java/org/oxycblt/auxio/music/covers/CoverSilo.kt @@ -0,0 +1,44 @@ +/* + * Copyright (c) 2024 Auxio Project + * CoverSilo.kt is part of Auxio. + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation, either version 3 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program. If not, see . + */ + +package org.oxycblt.auxio.music.covers + +import java.util.UUID +import org.oxycblt.musikr.cover.CoverParams + +data class CoverSilo(val revision: UUID, val params: CoverParams) { + override fun toString() = "${revision}.${params.resolution}.${params.quality}" + + companion object { + fun parse(silo: String): CoverSilo? { + val parts = silo.split('.') + if (parts.size != 3) return null + val revision = parts[0].toUuidOrNull() ?: return null + val resolution = parts[1].toIntOrNull() ?: return null + val quality = parts[2].toIntOrNull() ?: return null + return CoverSilo(revision, CoverParams.of(resolution, quality)) + } + } +} + +private fun String.toUuidOrNull(): UUID? = + try { + UUID.fromString(this) + } catch (e: IllegalArgumentException) { + null + } diff --git a/app/src/main/java/org/oxycblt/auxio/music/covers/SiloedCovers.kt b/app/src/main/java/org/oxycblt/auxio/music/covers/SiloedCovers.kt index c0ebc40f6..9fffb07e3 100644 --- a/app/src/main/java/org/oxycblt/auxio/music/covers/SiloedCovers.kt +++ b/app/src/main/java/org/oxycblt/auxio/music/covers/SiloedCovers.kt @@ -20,13 +20,11 @@ package org.oxycblt.auxio.music.covers import android.content.Context import java.io.File -import java.util.UUID import kotlinx.coroutines.Dispatchers import kotlinx.coroutines.withContext import org.oxycblt.musikr.cover.Cover import org.oxycblt.musikr.cover.CoverFiles import org.oxycblt.musikr.cover.CoverFormat -import org.oxycblt.musikr.cover.CoverParams import org.oxycblt.musikr.cover.Covers import org.oxycblt.musikr.cover.MutableCovers import org.oxycblt.musikr.cover.ObtainResult @@ -72,21 +70,6 @@ class SiloedCovers( } } -data class CoverSilo(val revision: UUID, val params: CoverParams) { - override fun toString() = "${revision}.${params.resolution}.${params.quality}" - - companion object { - fun parse(silo: String): CoverSilo? { - val parts = silo.split('.') - if (parts.size != 3) return null - val revision = parts[0].toUuidOrNull() ?: return null - val resolution = parts[1].toIntOrNull() ?: return null - val quality = parts[2].toIntOrNull() ?: return null - return CoverSilo(revision, CoverParams.of(resolution, quality)) - } - } -} - class SiloedCover(silo: CoverSilo, val innerCover: Cover) : Cover by innerCover { private val innerId = SiloedCoverId(silo, innerCover.id) override val id = innerId.toString() @@ -104,10 +87,3 @@ data class SiloedCoverId(val silo: CoverSilo, val id: String) { } } } - -private fun String.toUuidOrNull(): UUID? = - try { - UUID.fromString(this) - } catch (e: IllegalArgumentException) { - null - }