dotty.tools.io.Directory.scala Maven / Gradle / Ivy
The newest version!
/* __ *\
** ________ ___ / / ___ Scala API **
** / __/ __// _ | / / / _ | (c) 2003-2013, LAMP/EPFL **
** __\ \/ /__/ __ |/ /__/ __ | http://scala-lang.org/ **
** /____/\___/_/ |_/____/_/ | | **
** |/ **
\* */
package dotty.tools.io
import java.nio.file.{Files, Paths}
/**
* ''Note: This library is considered experimental and should not be used unless you know what you are doing.''
*/
object Directory {
import scala.util.Properties.userDir
def Current: Option[Directory] =
if (userDir == "") None
else Some(apply(userDir).normalize)
def inTempDirectory[T](fn: Directory => T): T = {
val temp = Directory(Files.createTempDirectory("temp"))
try fn(temp)
finally temp.deleteRecursively()
}
def apply(path: String): Directory = apply(Paths.get(path))
def apply(path: JPath): Directory = new Directory(path)
}
/** An abstraction for directories.
*
* @author Paul Phillips
* @since 2.8
*
* ''Note: This is library is considered experimental and should not be used unless you know what you are doing.''
*/
class Directory(jpath: JPath) extends Path(jpath) {
override def toAbsolute: Directory = if (isAbsolute) this else super.toAbsolute.toDirectory
override def toDirectory: Directory = this
override def toFile: File = new File(jpath)
override def normalize: Directory = super.normalize.toDirectory
/** An iterator over the contents of this directory.
*/
def list: Iterator[Path] =
if (isDirectory) {
val fileStream = Files.list(jpath)
val files = fileStream.toArray(size => new Array[JPath](size))
fileStream.close()
files.iterator.map(Path.apply)
}
else Iterator.empty
def dirs: Iterator[Directory] = list collect { case x: Directory => x }
def files: Iterator[File] = list collect { case x: File => x }
override def walkFilter(cond: Path => Boolean): Iterator[Path] =
list filter cond flatMap (_ walkFilter cond)
def deepFiles: Iterator[File] = Path.onlyFiles(deepList())
/** If optional depth argument is not given, will recurse
* until it runs out of contents.
*/
def deepList(depth: Int = -1): Iterator[Path] =
if (depth < 0) list ++ (dirs flatMap (_ deepList (depth)))
else if (depth == 0) Iterator.empty
else list ++ (dirs flatMap (_ deepList (depth - 1)))
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy