All Downloads are FREE. Search and download functionalities are using the official Maven repository.

groovy.util.FileTreeBuilder.groovy Maven / Gradle / Ivy

There is a newer version: 5.0.0-alpha-11
Show newest version
/*
 *  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