groovy.util.FileTreeBuilder.groovy Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of groovy Show documentation
Show all versions of groovy Show documentation
Groovy: A powerful, dynamic language for the JVM
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/
package groovy.util
import groovy.transform.CompileStatic
/**
* A builder dedicated at generating a file directory structure from a
* specification. For example, imagine that you want to create the following tree:
*
* src/
* |--- main
* | |--- groovy
* | |--- Foo.groovy
* |--- test
* |--- groovy
* |--- FooTest.groovy
*
*
*
* Then you can create the structure using:
*
* def tree = new FileTreeBuilder()
* tree.dir('src') {
* dir('main') {
* dir('groovy') {
* file('Foo.groovy', 'println "Hello"')
* }
* }
* dir('test') {
* dir('groovy') {
* file('FooTest.groovy', 'class FooTest extends GroovyTestCase {}')
* }
* }
* }
*
*
* or with this shorthand syntax:
*
* def tree = new FileTreeBuilder()
* tree.src {
* main {
* groovy {
* 'Foo.groovy'('println "Hello"')
* }
* }
* test {
* groovy {
* 'FooTest.groovy'('class FooTest extends GroovyTestCase {}')
* }
* }
* }
*
*
* @since 2.4.2
*/
@CompileStatic
class FileTreeBuilder {
File baseDir
FileTreeBuilder(File baseDir = new File('.')) {
this.baseDir = baseDir
}
/**
* Creates a file with the specified name and the text contents using the system default encoding.
* @param name name of the file to be created
* @param contents the contents of the file, written using the system default encoding
* @return the file being created
*/
File file(String name, CharSequence contents) {
new File(baseDir, name) << contents
}
/**
* Creates a file with the specified name and the specified binary contents
* @param name name of the file to be created
* @param contents the contents of the file
* @return the file being created
*/
File file(String name, byte[] contents) {
new File(baseDir, name) << contents
}
/**
* Creates a file with the specified name and the contents from the source file (copy).
* @param name name of the file to be created
* @param contents the contents of the file
* @return the file being created
*/
File file(String name, File source) {
// TODO: Avoid using bytes and prefer streaming copy
file(name, source.bytes)
}
/**
* Creates a new file in the current directory, whose contents is going to be generated in the
* closure. The delegate of the closure is the file being created.
* @param name name of the file to create
* @param spec closure for generating the file contents
* @return the created file
*/
File file(String name, @DelegatesTo(value = File, strategy = Closure.DELEGATE_FIRST) Closure spec) {
def file = new File(baseDir, name)
def clone = (Closure) spec.clone()
clone.delegate = file
clone.resolveStrategy = Closure.DELEGATE_FIRST
clone(file)
file
}
/**
* Creates a new empty directory
* @param name the name of the directory to create
* @return the created directory
*/
File dir(String name) {
def f = new File(baseDir, name)
f.mkdirs()
f
}
/**
* Creates a new directory and allows to specify a subdirectory structure using the closure as a specification
* @param name name of the directory to be created
* @param cl specification of the subdirectory structure
* @return the created directory
*/
File dir(String name, @DelegatesTo(value = FileTreeBuilder, strategy = Closure.DELEGATE_FIRST) Closure cl) {
def oldBase = baseDir
def newBase = dir(name)
try {
baseDir = newBase
cl.delegate = this
cl.resolveStrategy = Closure.DELEGATE_FIRST
cl()
} finally {
baseDir = oldBase
}
newBase
}
File call(@DelegatesTo(value = FileTreeBuilder, strategy = Closure.DELEGATE_FIRST) Closure spec) {
def clone = (Closure) spec.clone()
clone.delegate = this
clone.resolveStrategy = Closure.DELEGATE_FIRST
clone.call()
baseDir
}
@SuppressWarnings('Instanceof')
def methodMissing(String name, args) {
if (args instanceof Object[] && ((Object[]) args).length == 1) {
def arg = ((Object[]) args)[0]
if (arg instanceof Closure) {
dir(name, arg)
} else if (arg instanceof CharSequence) {
file(name, arg.toString())
} else if (arg instanceof byte[]) {
file(name, arg)
} else if (arg instanceof File) {
file(name, arg)
}
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy