mirror of
https://github.com/mamoe/mirai.git
synced 2025-01-07 16:40:43 +08:00
Fix AbsoluteFileFolder resolving with absolute path
This commit is contained in:
parent
a97749e736
commit
813d8485b6
@ -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()
|
||||||
}
|
}
|
||||||
|
@ -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
|
||||||
|
Loading…
Reference in New Issue
Block a user