From 4af8bed1fe533f6a0371da32c8e2c0ec5c81ebbf Mon Sep 17 00:00:00 2001 From: Joel Klinghed Date: Mon, 14 Oct 2024 23:09:08 +0200 Subject: Add path to Link It's implementation specific if path is relative or absolute but it contains the link target. Especially useful for NoTarget. --- .../java/org/the_jk/cleversync/io/sftp/SftpLink.kt | 27 ++++++++++++---------- 1 file changed, 15 insertions(+), 12 deletions(-) (limited to 'libs/sftp/src/main/java') diff --git a/libs/sftp/src/main/java/org/the_jk/cleversync/io/sftp/SftpLink.kt b/libs/sftp/src/main/java/org/the_jk/cleversync/io/sftp/SftpLink.kt index 0766f1a..161b5c1 100644 --- a/libs/sftp/src/main/java/org/the_jk/cleversync/io/sftp/SftpLink.kt +++ b/libs/sftp/src/main/java/org/the_jk/cleversync/io/sftp/SftpLink.kt @@ -13,17 +13,18 @@ internal class SftpLink( override val name: String, ) : ModifiableLink { override fun modifiableResolve(): ModifiableLink.ModifiableLinkTarget { - val (newPath, entry) = doResolve() - if (entry == null) return ModifiableLink.NoTarget + val (newPath, firstTarget, entry) = doResolve() + if (entry == null) return ModifiableLink.NoTarget(newPath) return when (entry.type) { NativeSftp.DirEntryType.DIR -> - ModifiableLink.ModifiableDirectoryTarget(SftpDirectory(conn, newPath, entry.name)) + ModifiableLink.ModifiableDirectoryTarget(firstTarget, SftpDirectory(conn, newPath, entry.name)) NativeSftp.DirEntryType.FILE -> ModifiableLink.ModifiableFileTarget( + firstTarget, SftpFile(conn, newPath, entry.name, entry.size, entry.lastModified), ) NativeSftp.DirEntryType.LINK -> - ModifiableLink.NoTarget + ModifiableLink.NoTarget(firstTarget) } } @@ -46,15 +47,15 @@ internal class SftpLink( } override fun resolve(): Link.LinkTarget { - val (newPath, entry) = doResolve() - if (entry == null) return Link.NoTarget + val (newPath, firstTarget, entry) = doResolve() + if (entry == null) return Link.NoTarget(newPath) return when (entry.type) { NativeSftp.DirEntryType.DIR -> - Link.DirectoryTarget(SftpDirectory(conn, newPath, entry.name)) + Link.DirectoryTarget(firstTarget, SftpDirectory(conn, newPath, entry.name)) NativeSftp.DirEntryType.FILE -> - Link.FileTarget(SftpFile(conn, newPath, entry.name, entry.size, entry.lastModified)) + Link.FileTarget(firstTarget, SftpFile(conn, newPath, entry.name, entry.size, entry.lastModified)) NativeSftp.DirEntryType.LINK -> - Link.NoTarget + Link.NoTarget(firstTarget) } } @@ -62,12 +63,14 @@ internal class SftpLink( override fun hashCode() = path.hashCode() override fun toString() = "$conn/$path" - private fun doResolve(): Pair { + private fun doResolve(): Triple { + var firstTarget: String? = null var linkPath = path - var paths = mutableSetOf(linkPath) + val paths = mutableSetOf(linkPath) var entry: NativeSftp.DirEntry? = null while (true) { val target = conn.readLink(linkPath) ?: break + if (firstTarget == null) firstTarget = target linkPath = PathUtils.resolve( PathUtils.join(PathUtils.dirname(linkPath), target), ) @@ -75,6 +78,6 @@ internal class SftpLink( entry = conn.entry(linkPath, followLink = false) ?: break if (entry.type != NativeSftp.DirEntryType.LINK) break } - return linkPath to entry + return Triple(linkPath, firstTarget ?: linkPath, entry) } } -- cgit v1.2.3-70-g09d2