Fix AbsoluteFileFolder resolving with absolute path

This commit is contained in:
Karlatemp 2021-11-19 21:14:28 +08:00 committed by Him188
parent a97749e736
commit 813d8485b6
2 changed files with 21 additions and 1 deletions

View File

@ -363,6 +363,9 @@ internal class AbsoluteFolderImpl(
override suspend fun resolveFolder(name: String): AbsoluteFolder? { override suspend fun resolveFolder(name: String): AbsoluteFolder? {
if (name.isBlank()) throw IllegalArgumentException("folder name cannot be blank.") if (name.isBlank()) throw IllegalArgumentException("folder name cannot be blank.")
if (!FileSystem.isLegal(name)) return null if (!FileSystem.isLegal(name)) return null
if (name[0] == '/') {
return root.resolveFolder(name.substring(1))
}
return getItemsFlow().firstOrNull { it.folderInfo?.folderName == name }?.resolve() as AbsoluteFolder? return getItemsFlow().firstOrNull { it.folderInfo?.folderName == name }?.resolve() as AbsoluteFolder?
} }
@ -380,6 +383,10 @@ internal class AbsoluteFolderImpl(
if (path.isBlank()) throw IllegalArgumentException("path cannot be blank.") if (path.isBlank()) throw IllegalArgumentException("path cannot be blank.")
if (!FileSystem.isLegal(path)) return emptyFlow() if (!FileSystem.isLegal(path)) return emptyFlow()
if (path[0] == '/') {
return root.resolveFiles(path.substring(1))
}
if (!path.contains('/')) { if (!path.contains('/')) {
return getItemsFlow().filter { it.fileInfo?.fileName == path }.map { it.resolve() as AbsoluteFile } return getItemsFlow().filter { it.fileInfo?.fileName == path }.map { it.resolve() as AbsoluteFile }
} }
@ -392,8 +399,14 @@ internal class AbsoluteFolderImpl(
if (path.isBlank()) throw IllegalArgumentException("path cannot be blank.") if (path.isBlank()) throw IllegalArgumentException("path cannot be blank.")
if (!FileSystem.isLegal(path)) return Stream.empty() if (!FileSystem.isLegal(path)) return Stream.empty()
if (path[0] == '/') {
return root.resolveFilesStream(path.substring(1))
}
if (!path.contains('/')) { if (!path.contains('/')) {
return getItemsSequence().filter { it.fileInfo?.fileName == path }.map { it.resolve() as AbsoluteFile } return getItemsSequence()
.filter { it.fileInfo?.fileName == path }
.map { it.resolve() as AbsoluteFile }
.asStream() .asStream()
} }
@ -403,6 +416,9 @@ internal class AbsoluteFolderImpl(
override suspend fun resolveAll(path: String): Flow<AbsoluteFileFolder> { override suspend fun resolveAll(path: String): Flow<AbsoluteFileFolder> {
if (path.isBlank()) throw IllegalArgumentException("path cannot be blank.") if (path.isBlank()) throw IllegalArgumentException("path cannot be blank.")
if (!FileSystem.isLegal(path)) return emptyFlow() if (!FileSystem.isLegal(path)) return emptyFlow()
if (path[0] == '/') {
return root.resolveAll(path.substring(1))
}
if (!path.contains('/')) { if (!path.contains('/')) {
return getItemsFlow().mapNotNull { it.resolve() } return getItemsFlow().mapNotNull { it.resolve() }
} }
@ -414,6 +430,9 @@ internal class AbsoluteFolderImpl(
override suspend fun resolveAllStream(path: String): Stream<AbsoluteFileFolder> { override suspend fun resolveAllStream(path: String): Stream<AbsoluteFileFolder> {
if (path.isBlank()) throw IllegalArgumentException("path cannot be blank.") if (path.isBlank()) throw IllegalArgumentException("path cannot be blank.")
if (!FileSystem.isLegal(path)) return Stream.empty() if (!FileSystem.isLegal(path)) return Stream.empty()
if (path[0] == '/') {
return root.resolveAllStream(path.substring(1))
}
if (!path.contains('/')) { if (!path.contains('/')) {
return getItemsSequence().mapNotNull { it.resolve() }.asStream() return getItemsSequence().mapNotNull { it.resolve() }.asStream()
} }

View File

@ -31,6 +31,7 @@ internal fun AbsoluteFolder.impl(): AbsoluteFolderImpl = this.cast()
internal val AbsoluteFolder?.idOrRoot get() = this?.id ?: AbsoluteFolder.ROOT_FOLDER_ID internal val AbsoluteFolder?.idOrRoot get() = this?.id ?: AbsoluteFolder.ROOT_FOLDER_ID
internal val AbstractAbsoluteFileFolder.parentOrRoot get() = parent ?: contact.files.root internal val AbstractAbsoluteFileFolder.parentOrRoot get() = parent ?: contact.files.root
internal val AbstractAbsoluteFileFolder.root get() = contact.files.root
/** /**
* @see AbsoluteFileFolder * @see AbsoluteFileFolder