picocli.groovy.PicocliScript Maven / Gradle / Ivy
Show all versions of picocli-groovy Show documentation
/*
Copyright 2017 Remko Popma
Licensed 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 picocli.groovy;
import org.codehaus.groovy.transform.GroovyASTTransformationClass;
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
/**
*
* Annotation to give Groovy scripts convenient access to picocli functionality.
* Scripts may annotate the package statement, an import statement or a local variable with
* {@code @PicocliScript} and the script base class will be {@link PicocliScriptASTTransformation transformed} to
* {@link picocli.groovy.PicocliBaseScript}.
*
* Also, any {@link picocli.CommandLine.Command} annotation on the same variable or import statement will be added to
* the script class. With the {@code @Command} annotation scripts can customize elements shown in the usage message
* like command name, description, headers, footers etc.
*
* Example usage:
*
*
* @Command(name = "myCommand", description = "does something special")
* @PicocliScript
* import picocli.groovy.PicocliScript
* import picocli.CommandLine.Command
* import picocli.CommandLine.Option
* import groovy.transform.Field
*
* @Option(names = "-x", description = "number of repetitions")
* @Field int count;
*
* @Option(names = ["-h", "--help"], usageHelp = true, description = "print this help message and exit")
* @Field boolean helpRequested;
*
* //if (helpRequested) { CommandLine.usage(this, System.err); return 0; } // PicocliBaseScript takes care of this
* count.times {
* println "hi"
* }
* assert this == theScript
* assert this.commandLine.commandName == "myCommand"
*
*
* Otherwise, this annotation works similar to the Groovy built-in {@link groovy.transform.BaseScript}.
* Using this annotation will override the base script set by Groovy compiler or
* {@link org.codehaus.groovy.control.CompilerConfiguration} of {@link groovy.lang.GroovyShell}.
*
* To customize further, a base script class extending {@link picocli.groovy.PicocliBaseScript}
* may be specified as the value of this annotation, for example:
*
* @PicocliScript(com.mycompany.MyScriptBaseClass)
* import picocli.groovy.PicocliScript
*
* An alternative way to customize the base script is annotating a local variable with {@code @PicocliScript}.
* This way the variable type will be used as the base script class and
* the annotated variable will become a shortcut to {@code this} object.
* The type of the annotated variable must extend {@link picocli.groovy.PicocliBaseScript}.
*
* import picocli.groovy.PicocliScript
* import com.mycompany.MyScriptBaseClass
* @PicocliScript MyScriptBaseClass theScript;
*
*
* @see PicocliScriptASTTransformation
* @author Remko Popma
* @since 2.0
*/
@java.lang.annotation.Documented
@Retention(RetentionPolicy.SOURCE)
@Target({ElementType.LOCAL_VARIABLE, ElementType.PACKAGE, ElementType.TYPE, ElementType.FIELD /*, ElementType.IMPORT*/})
@GroovyASTTransformationClass("picocli.groovy.PicocliScriptASTTransformation")
public @interface PicocliScript {
Class> value() default PicocliBaseScript.class;
}