From 9696cc246883d360f0d439e4d4e919f4f7dc7e22 Mon Sep 17 00:00:00 2001 From: Adam <152864218+adam-enko@users.noreply.github.com> Date: Thu, 31 Oct 2024 15:35:28 +0100 Subject: [PATCH] Update fileTree test util to only use NIO Path (#3892) `fileTree.kt` contains a utility for logging pretty file trees, which is useful in providing human-readable context for test failures. This PR updates the utility to only use NIO Path, rather than the older `java.io.File`. This change was split off from #3814 to make the PR smaller --- .../src/testFixtures/kotlin/fileTree.kt | 48 ++++--------------- 1 file changed, 10 insertions(+), 38 deletions(-) diff --git a/dokka-runners/dokka-gradle-plugin/src/testFixtures/kotlin/fileTree.kt b/dokka-runners/dokka-gradle-plugin/src/testFixtures/kotlin/fileTree.kt index 2a5592ef42..004135a6a6 100644 --- a/dokka-runners/dokka-gradle-plugin/src/testFixtures/kotlin/fileTree.kt +++ b/dokka-runners/dokka-gradle-plugin/src/testFixtures/kotlin/fileTree.kt @@ -3,8 +3,8 @@ */ package org.jetbrains.dokka.gradle.utils -import java.io.File import java.nio.file.Path +import kotlin.io.path.* // based on https://gist.github.com/mfwgenerics/d1ec89eb80c95da9d542a03b49b5e15b // context: https://kotlinlang.slack.com/archives/C0B8MA7FA/p1676106647658099 @@ -12,14 +12,8 @@ import java.nio.file.Path fun Path.toTreeString( fileFilter: FileFilter = FileFilter { true }, -): String = - toFile().toTreeString(fileFilter = fileFilter) - - -fun File.toTreeString( - fileFilter: FileFilter = FileFilter { true }, ): String = when { - isDirectory -> name + "/\n" + buildTreeString(dir = this, fileFilter = fileFilter) + isDirectory() -> name + "/\n" + buildTreeString(dir = this, fileFilter = fileFilter) else -> name } @@ -28,21 +22,21 @@ fun File.toTreeString( * Optionally include/exclude files. Directories will always be included. */ fun interface FileFilter { - operator fun invoke(file: File): Boolean + operator fun invoke(file: Path): Boolean } -private fun FileFilter.matches(file: File): Boolean = - if (file.isDirectory) { +private fun FileFilter.matches(file: Path): Boolean = + if (file.isDirectory()) { // don't include directories that have no matches - file.walk().any { it.isFile && invoke(it) } + file.walk().any { it.isRegularFile() && invoke(it) } } else { invoke(file) } private fun buildTreeString( - dir: File, + dir: Path, fileFilter: FileFilter = FileFilter { true }, margin: String = "", ): String { @@ -58,7 +52,7 @@ private fun buildTreeString( buildString { append("$margin${currentPrefix}${entry.name}") - if (entry.isDirectory) { + if (entry.isDirectory()) { append("/") if (entry.countDirectoryEntries(fileFilter) > 0) { append("\n") @@ -69,19 +63,11 @@ private fun buildTreeString( } } -private fun File.listDirectoryEntries(): Sequence = - walkTopDown() - .maxDepth(1) - .filter { it != this@listDirectoryEntries } - .sortedWith(FileSorter) - -private fun File.countDirectoryEntries( +private fun Path.countDirectoryEntries( fileFilter: FileFilter, ): Int = - listDirectoryEntries() - .filter { file -> fileFilter.matches(file) } - .count() + listDirectoryEntries().count { file -> fileFilter.matches(file) } private data class PrefixPair( @@ -98,17 +84,3 @@ private data class PrefixPair( val LAST_ENTRY = PrefixPair("└── ", " ") } } - - -/** - * Directories before files, otherwise sort by filename. - */ -private object FileSorter : Comparator { - override fun compare(o1: File, o2: File): Int { - return when { - o1.isDirectory && o2.isFile -> -1 // directories before files - o1.isFile && o2.isDirectory -> +1 // files after directories - else -> o1.name.compareTo(o2.name) - } - } -}