Extensions for java.io.File
appendBytes
Appends an array of bytes to the content of this file.
fun File.appendBytes(array: ByteArray)
appendText
bufferedReader
Returns a new BufferedReader for reading the content of this file.
fun File.bufferedReader( charset: Charset = Charsets.UTF_8, bufferSize: Int = DEFAULT_BUFFER_SIZE ): BufferedReader
bufferedWriter
Returns a new BufferedWriter for writing the content of this file.
fun File.bufferedWriter( charset: Charset = Charsets.UTF_8, bufferSize: Int = DEFAULT_BUFFER_SIZE ): BufferedWriter
copyRecursively
Copies this file with all its children to the specified destination target path. If some directories on the way to the destination are missing, then they will be created.
fun File.copyRecursively( target: File, overwrite: Boolean = false, onError: (File, IOException) -> OnErrorAction = { _, exception -> throw exception } ): Boolean
copyTo
Copies this file to the given target file.
fun File.copyTo( target: File, overwrite: Boolean = false, bufferSize: Int = DEFAULT_BUFFER_SIZE ): File
deleteRecursively
Delete this file with all its children. Note that if this operation fails then partial deletion may have taken place.
fun File.deleteRecursively(): Boolean
endsWith
Determines whether this file path ends with the path of other file.
fun File.endsWith(other: File): Boolean
extension
Returns the extension of this file (not including the dot), or an empty string if it doesn't have one.
val File.extension: String
forEachBlock
forEachLine
inputStream
Constructs a new FileInputStream of this file and returns it as a result.
fun File.inputStream(): FileInputStream
invariantSeparatorsPath
Returns path of this File using the invariant separator '/' to separate the names in the name sequence.
val File.invariantSeparatorsPath: String
isRooted
Determines whether this file has a root or it represents a relative path.
val File.isRooted: Boolean
nameWithoutExtension
Returns file's name without an extension.
val File.nameWithoutExtension: String
normalize
Removes all . and resolves all possible .. in this file name. For instance, File("/foo/./bar/gav/../baaz").normalize()
is File("/foo/bar/baaz")
.
fun File.normalize(): File
outputStream
Constructs a new FileOutputStream of this file and returns it as a result.
fun File.outputStream(): FileOutputStream
printWriter
Returns a new PrintWriter for writing the content of this file.
fun File.printWriter( charset: Charset = Charsets.UTF_8 ): PrintWriter
readBytes
Gets the entire content of this file as a byte array.
fun File.readBytes(): ByteArray
reader
Returns a new FileReader for reading the content of this file.
fun File.reader( charset: Charset = Charsets.UTF_8 ): InputStreamReader
readLines
Reads the file content as a list of lines.
fun File.readLines( charset: Charset = Charsets.UTF_8 ): List<String>
readText
Gets the entire content of this file as a String using UTF-8 or specified charset.
fun File.readText(charset: Charset = Charsets.UTF_8): String
relativeTo
relativeToOrNull
relativeToOrSelf
resolve
Adds relative file to this, considering this as a directory. If relative has a root, relative is returned back. For instance, File("/foo/bar").resolve(File("gav"))
is File("/foo/bar/gav")
. This function is complementary with relativeTo, so f.resolve(g.relativeTo(f)) == g
should be always true
except for different roots case.
fun File.resolve(relative: File): File
resolveSibling
startsWith
toRelativeString
useLines
Calls the block callback giving it a sequence of all the lines in this file and closes the reader once the processing is complete.
fun <T> File.useLines( charset: Charset = Charsets.UTF_8, block: (Sequence<String>) -> T ): T
walk
Gets a sequence for visiting this directory and all its content.
fun File.walk( direction: FileWalkDirection = FileWalkDirection.TOP_DOWN ): FileTreeWalk
walkBottomUp
Gets a sequence for visiting this directory and all its content in bottom-up order. Depth-first search is used and directories are visited after all their files.
fun File.walkBottomUp(): FileTreeWalk
walkTopDown
Gets a sequence for visiting this directory and all its content in top-down order. Depth-first search is used and directories are visited before all their files.
fun File.walkTopDown(): FileTreeWalk
writeBytes
Sets the content of this file as an array of bytes. If this file already exists, it becomes overwritten.
fun File.writeBytes(array: ByteArray)
writer
Returns a new FileWriter for writing the content of this file.
fun File.writer( charset: Charset = Charsets.UTF_8 ): OutputStreamWriter
© 2010–2021 JetBrains s.r.o. and Kotlin Programming Language contributors
Licensed under the Apache License, Version 2.0.
https://kotlinlang.org/api/latest/jvm/stdlib/kotlin.io/java.io.-file/index.html