diff --git a/docs/autocomplete.adoc b/docs/autocomplete.adoc index 79631ff3e..3a77ee131 100644 --- a/docs/autocomplete.adoc +++ b/docs/autocomplete.adoc @@ -1,7 +1,7 @@ = Autocomplete for Java Command Line Applications //:author: Remko Popma //:email: rpopma@apache.org -:revnumber: 4.6.2 +:revnumber: 4.6.3-SNAPSHOT :revdate: 2021-11-05 :toc: left :numbered: diff --git a/docs/index.adoc b/docs/index.adoc index 70ab3999b..5f21aa83c 100644 --- a/docs/index.adoc +++ b/docs/index.adoc @@ -1,7 +1,7 @@ = picocli - a mighty tiny command line interface //:author: Remko Popma //:email: rpopma@apache.org -:revnumber: 4.6.2 +:revnumber: 4.6.3-SNAPSHOT :revdate: 2021-11-05 :toc: left :numbered: @@ -120,7 +120,7 @@ class CheckSum implements Callable { [[CheckSum-App-Groovy]] [source,groovy,role="secondary"] ---- -@Grab('info.picocli:picocli-groovy:4.6.2') +@Grab('info.picocli:picocli-groovy:4.6.3-SNAPSHOT') import picocli.CommandLine import static picocli.CommandLine.* @@ -152,7 +152,7 @@ class Checksum implements Callable { [[CheckSum-App-Groovy-Script]] [source,groovy,role="secondary"] ---- -@Grab('info.picocli:picocli-groovy:4.6.2') +@Grab('info.picocli:picocli-groovy:4.6.3-SNAPSHOT') import static picocli.CommandLine.* import groovy.transform.Field import java.security.MessageDigest @@ -273,7 +273,7 @@ Below are examples of configuring Gradle or Maven to use picocli as an external [source,groovy,role="primary"] ---- dependencies { - implementation 'info.picocli:picocli:4.6.2' + implementation 'info.picocli:picocli:4.6.3-SNAPSHOT' } ---- .Maven @@ -282,7 +282,7 @@ dependencies { info.picocli picocli - 4.6.2 + 4.6.3-SNAPSHOT ---- @@ -319,8 +319,8 @@ https://immutables.github.io/apt.html[This page] shows the steps to configure Ec [source,groovy,role="primary"] ---- dependencies { - implementation 'info.picocli:picocli:4.6.2' - annotationProcessor 'info.picocli:picocli-codegen:4.6.2' + implementation 'info.picocli:picocli:4.6.3-SNAPSHOT' + annotationProcessor 'info.picocli:picocli-codegen:4.6.3-SNAPSHOT' } @@ -342,7 +342,7 @@ compileJava { info.picocli picocli-codegen - 4.6.2 + 4.6.3-SNAPSHOT @@ -362,7 +362,7 @@ then replace `annotationProcessor` with `kapt`: apply plugin: 'kotlin-kapt' // required dependencies { // ... - kapt 'info.picocli:picocli-codegen:4.6.2' + kapt 'info.picocli:picocli-codegen:4.6.3-SNAPSHOT' } ``` @@ -393,7 +393,7 @@ Now, assuming we created a jar named `checksum.jar` containing our compiled `Che [source,bash] ---- -java -cp "picocli-4.6.2.jar:checksum.jar" CheckSum --algorithm SHA-1 hello.txt +java -cp "picocli-4.6.3-SNAPSHOT.jar:checksum.jar" CheckSum --algorithm SHA-1 hello.txt ---- You may want to package your application in such a way that end users can invoke it with a short command like this: @@ -9709,7 +9709,7 @@ Eventually, we are ready to run our application: [source,bash] ---- -java -cp "picocli-4.6.2.jar;myapp.jar" org.myorg.GreetingApp Sarah Lea +java -cp "picocli-4.6.3-SNAPSHOT.jar;myapp.jar" org.myorg.GreetingApp Sarah Lea ---- With no command line parameter `--locale` given, the message texts are printed in the default language (here: English): @@ -9723,7 +9723,7 @@ In order to control the locale choosen for our output, we have to make use of th [source,bash] ---- -java -cp "picocli-4.6.2.jar;myapp.jar" org.myorg.GreetingApp --locale=es Sarah Lea +java -cp "picocli-4.6.3-SNAPSHOT.jar;myapp.jar" org.myorg.GreetingApp --locale=es Sarah Lea ---- Now our message texts are printed in Spanish: @@ -10994,21 +10994,21 @@ Since picocli dependencies are not available in the Spring Initializr, we have t info.picocli picocli-spring-boot-starter - 4.6.2 + 4.6.3-SNAPSHOT ---- .Gradle (Groovy) [source,groovy,role="secondary"] ---- dependencies { - implementation 'info.picocli:picocli-spring-boot-starter:4.6.2' + implementation 'info.picocli:picocli-spring-boot-starter:4.6.3-SNAPSHOT' } ---- .Gradle (Kotlin) [source,kotlin,role="secondary"] ---- dependencies { - implementation("info.picocli:picocli-spring-boot-starter:4.6.2") + implementation("info.picocli:picocli-spring-boot-starter:4.6.3-SNAPSHOT") } ---- @@ -12296,7 +12296,7 @@ As mentioned in <>, earlier in this manual, one way to [source,bash] ---- -java -cp "picocli-4.6.2.jar;myapp.jar" org.myorg.MyMainClass --option=value arg0 arg1 +java -cp "picocli-4.6.3-SNAPSHOT.jar;myapp.jar" org.myorg.MyMainClass --option=value arg0 arg1 ---- That is quite verbose. You may want to package your application in such a way that end users can invoke it by its command name like this: @@ -12315,7 +12315,7 @@ On unix-based operating systems, you can ask your users to define an alias. For [source,bash] ---- -alias mycommand='java -cp "/path/to/picocli-4.6.2.jar:/path/to/myapp.jar" org.myorg.MainClass' +alias mycommand='java -cp "/path/to/picocli-4.6.3-SNAPSHOT.jar:/path/to/myapp.jar" org.myorg.MainClass' ---- Append the above line to your `~/.bashrc` file to make this alias available in every new shell session. @@ -12364,7 +12364,7 @@ After installing GraalVM and installing the `native-image` generator utility (wi you can then create a native image by invoking the `native-image` command: ---- -path/to/native-image -cp picocli-4.6.2.jar --static -jar myapp.jar +path/to/native-image -cp picocli-4.6.3-SNAPSHOT.jar --static -jar myapp.jar ---- CAUTION: To create a native image, the compiler toolchain for your platform needs to be installed. See https://www.infoq.com/articles/java-native-cli-graalvm-picocli/[Build Great Native CLI Apps in Java with Graalvm and Picocli] for details. @@ -12483,7 +12483,7 @@ The script body is executed if the user input was valid and did not request usag [source,groovy] ---- -@Grab('info.picocli:picocli-groovy:4.6.2') +@Grab('info.picocli:picocli-groovy:4.6.3-SNAPSHOT') @GrabConfig(systemClassLoader=true) @Command(name = "myScript", mixinStandardHelpOptions = true, // add --help and --version options @@ -12524,7 +12524,7 @@ The table below compares these two base classes. WARNING: When upgrading scripts from picocli versions older than 4.0, just changing the version number is not enough! -Scripts should use `@Grab('info.picocli:picocli-groovy:4.6.2')`. The old artifact id `@Grab('info.picocli:picocli:4.6.2')` will not work, +Scripts should use `@Grab('info.picocli:picocli-groovy:4.6.3-SNAPSHOT')`. The old artifact id `@Grab('info.picocli:picocli:4.6.3-SNAPSHOT')` will not work, because the `@picocli.groovy.PicocliScript` annotation class and supporting classes have been moved into a separate module, `picocli-groovy`. ==== Closures in Annotations @@ -12581,7 +12581,7 @@ NOTE: When using a Groovy version older than 2.4.7, use this workaround for the [source,groovy] ---- -@Grab('info.picocli:picocli-groovy:4.6.2') +@Grab('info.picocli:picocli-groovy:4.6.3-SNAPSHOT') @GrabExclude('org.codehaus.groovy:groovy-all') // work around GROOVY-7613 ... ---- @@ -12724,14 +12724,14 @@ You can add picocli as an external dependency to your project, or you can includ .Gradle [source,groovy,role="primary"] ---- -implementation 'info.picocli:picocli:4.6.2' +implementation 'info.picocli:picocli:4.6.3-SNAPSHOT' ---- .Gradle (Kotlin) [source,kotlin,role="secondary"] ---- dependencies { - implementation("info.picocli:picocli:4.6.2") + implementation("info.picocli:picocli:4.6.3-SNAPSHOT") } ---- @@ -12741,46 +12741,46 @@ dependencies { info.picocli picocli - 4.6.2 + 4.6.3-SNAPSHOT ---- .Scala SBT [source,role="secondary"] ---- -libraryDependencies += "info.picocli" % "picocli" % "4.6.2" +libraryDependencies += "info.picocli" % "picocli" % "4.6.3-SNAPSHOT" ---- .Ivy [source,role="secondary"] ---- - + ---- .Grape [source,role="secondary"] ---- @Grapes( - @Grab(group='info.picocli', module='picocli', version='4.6.2') + @Grab(group='info.picocli', module='picocli', version='4.6.3-SNAPSHOT') ) ---- .Leiningen [source,role="secondary"] ---- -[info.picocli/picocli "4.6.2"] +[info.picocli/picocli "4.6.3-SNAPSHOT"] ---- .Buildr [source,role="secondary"] ---- -'info.picocli:picocli:jar:4.6.2' +'info.picocli:picocli:jar:4.6.3-SNAPSHOT' ---- .JBang [source,role="secondary"] ---- -//DEPS info.picocli:picocli:4.6.2 +//DEPS info.picocli:picocli:4.6.3-SNAPSHOT ---- === Source diff --git a/docs/picocli-programmatic-api.adoc b/docs/picocli-programmatic-api.adoc index 1660e906c..6cebbe319 100644 --- a/docs/picocli-programmatic-api.adoc +++ b/docs/picocli-programmatic-api.adoc @@ -1,7 +1,7 @@ = Programmatic API //:author: Remko Popma //:email: rpopma@apache.org -:revnumber: 4.6.2 +:revnumber: 4.6.3-SNAPSHOT :revdate: 2021-11-05 :toc: left :numbered: diff --git a/docs/quick-guide.adoc b/docs/quick-guide.adoc index 0bd453893..ad4a7e271 100644 --- a/docs/quick-guide.adoc +++ b/docs/quick-guide.adoc @@ -1,7 +1,7 @@ = Quick Guide //:author: Remko Popma //:email: rpopma@apache.org -:revnumber: 4.6.2 +:revnumber: 4.6.3-SNAPSHOT :revdate: 2021-11-05 :toc: left :numbered: @@ -52,7 +52,7 @@ Below we show a small but fully functional example picocli-based command line ap .Invoking the command ---- -$ java -cp "myapp.jar;picocli-4.6.2.jar" ASCIIArt --font-size=9 Hello picocli +$ java -cp "myapp.jar;picocli-4.6.3-SNAPSHOT.jar" ASCIIArt --font-size=9 Hello picocli # # # # # # # # # # # # # # *** # # **** #*** # **# **** **# # # @@ -162,7 +162,7 @@ The application can be used as follows: .Resolving two letter language codes ---- -$ java -cp "myapp.jar;picocli-4.6.2.jar" ISOCodeResolver language de cs en sd se +$ java -cp "myapp.jar;picocli-4.6.3-SNAPSHOT.jar" ISOCodeResolver language de cs en sd se de: German cs: Czech en: English @@ -172,7 +172,7 @@ se: Northern Sami .Resolving two letter country codes ---- -$ java -cp "myapp.jar;picocli-4.6.2.jar" ISOCodeResolver country cn fr th ro no +$ java -cp "myapp.jar;picocli-4.6.3-SNAPSHOT.jar" ISOCodeResolver country cn fr th ro no CN: China FR: France TH: Thailand diff --git a/gradle.properties b/gradle.properties index 3be9f5530..15ce6edf3 100644 --- a/gradle.properties +++ b/gradle.properties @@ -16,12 +16,12 @@ junitVersion = 4.12 springBootVersion = 2.5.6 # projectPreviousPublishedVersion is non-SNAPSHOT, only published releases -projectPreviousPublishedVersion = 4\\.6\\.1 +projectPreviousPublishedVersion = 4\\.6\\.2 # projectPreviousVersionRegex may be a SNAPSHOT -projectPreviousVersionRegex = 4\\.6\\.2-SNAPSHOT -projectVersion = 4.6.2 +projectPreviousVersionRegex = 4\\.6\\.2 +projectVersion = 4.6.3-SNAPSHOT releaseDate = 2021-11-05 -releaseDatePreviousRegex = 2021\\-01\\-03 +releaseDatePreviousRegex = 2021\\-11\\-05 systemRulesVersion = 1.17.1 diff --git a/gradle/release-tasks.gradle b/gradle/release-tasks.gradle index 1a357022e..247e0d65f 100644 --- a/gradle/release-tasks.gradle +++ b/gradle/release-tasks.gradle @@ -122,6 +122,7 @@ Release procedure: 8. commit -m "Release picocli version ..." 9. tag v$version 10. ./gradlew publishReleasePublicationToSonatypeRepository - creates staging repository, and uploads artifacts +// for automation: stagingProfileId = '5db36034f05d47' 11. edit version numbers: increase minor version and add -SNAPSHOT classifier 12. ./gradlew bumpVersion diff --git a/picocli-codegen/src/main/java/picocli/codegen/aot/graalvm/DynamicProxyConfigGenerator.java b/picocli-codegen/src/main/java/picocli/codegen/aot/graalvm/DynamicProxyConfigGenerator.java index 67e0e6091..cc2baae08 100644 --- a/picocli-codegen/src/main/java/picocli/codegen/aot/graalvm/DynamicProxyConfigGenerator.java +++ b/picocli-codegen/src/main/java/picocli/codegen/aot/graalvm/DynamicProxyConfigGenerator.java @@ -58,7 +58,7 @@ public class DynamicProxyConfigGenerator { }, footerHeading = "%nExample%n", footer = { - " java -cp \"myapp.jar;picocli-4.6.2.jar;picocli-codegen-4.6.2.jar\" " + + " java -cp \"myapp.jar;picocli-4.6.3-SNAPSHOT.jar;picocli-codegen-4.6.3-SNAPSHOT.jar\" " + "picocli.codegen.aot.graalvm.DynamicProxyConfigGenerator my.pkg.MyClass" }, mixinStandardHelpOptions = true, version = "picocli-codegen gen-proxy-config " + CommandLine.VERSION) diff --git a/picocli-codegen/src/main/java/picocli/codegen/aot/graalvm/JniConfigGenerator.java b/picocli-codegen/src/main/java/picocli/codegen/aot/graalvm/JniConfigGenerator.java index 417c32745..66d8e4f55 100644 --- a/picocli-codegen/src/main/java/picocli/codegen/aot/graalvm/JniConfigGenerator.java +++ b/picocli-codegen/src/main/java/picocli/codegen/aot/graalvm/JniConfigGenerator.java @@ -31,7 +31,7 @@ public class JniConfigGenerator { }, footerHeading = "%nExample%n", footer = { - " java -cp \"myapp.jar;picocli-4.6.2.jar;picocli-codegen-4.6.2.jar\" " + + " java -cp \"myapp.jar;picocli-4.6.3-SNAPSHOT.jar;picocli-codegen-4.6.3-SNAPSHOT.jar\" " + "picocli.codegen.aot.graalvm.JniConfigGenerator my.pkg.MyClass" }, mixinStandardHelpOptions = true, sortOptions = false, diff --git a/picocli-codegen/src/main/java/picocli/codegen/aot/graalvm/ReflectionConfigGenerator.java b/picocli-codegen/src/main/java/picocli/codegen/aot/graalvm/ReflectionConfigGenerator.java index 298800789..ca726f14c 100644 --- a/picocli-codegen/src/main/java/picocli/codegen/aot/graalvm/ReflectionConfigGenerator.java +++ b/picocli-codegen/src/main/java/picocli/codegen/aot/graalvm/ReflectionConfigGenerator.java @@ -95,7 +95,7 @@ public class ReflectionConfigGenerator { }, footerHeading = "%nExample%n", footer = { - " java -cp \"myapp.jar;picocli-4.6.2.jar;picocli-codegen-4.6.2.jar\" " + + " java -cp \"myapp.jar;picocli-4.6.3-SNAPSHOT.jar;picocli-codegen-4.6.3-SNAPSHOT.jar\" " + "picocli.codegen.aot.graalvm.ReflectionConfigGenerator my.pkg.MyClass" }, mixinStandardHelpOptions = true, sortOptions = false, diff --git a/picocli-codegen/src/main/java/picocli/codegen/aot/graalvm/ResourceConfigGenerator.java b/picocli-codegen/src/main/java/picocli/codegen/aot/graalvm/ResourceConfigGenerator.java index b60027379..424ba702c 100644 --- a/picocli-codegen/src/main/java/picocli/codegen/aot/graalvm/ResourceConfigGenerator.java +++ b/picocli-codegen/src/main/java/picocli/codegen/aot/graalvm/ResourceConfigGenerator.java @@ -54,7 +54,7 @@ public class ResourceConfigGenerator { }, footerHeading = "%nExample%n", footer = { - " java -cp \"myapp.jar;picocli-4.6.2.jar;picocli-codegen-4.6.2.jar\" " + + " java -cp \"myapp.jar;picocli-4.6.3-SNAPSHOT.jar;picocli-codegen-4.6.3-SNAPSHOT.jar\" " + "picocli.codegen.aot.graalvm.ResourceConfigGenerator my.pkg.MyClass" }, mixinStandardHelpOptions = true, version = "picocli-codegen gen-resource-config " + CommandLine.VERSION) diff --git a/picocli-codegen/src/main/java/picocli/codegen/docgen/manpage/ManPageGenerator.java b/picocli-codegen/src/main/java/picocli/codegen/docgen/manpage/ManPageGenerator.java index 23ae9e208..be5cdd8f9 100644 --- a/picocli-codegen/src/main/java/picocli/codegen/docgen/manpage/ManPageGenerator.java +++ b/picocli-codegen/src/main/java/picocli/codegen/docgen/manpage/ManPageGenerator.java @@ -190,7 +190,7 @@ private void verboseDetailed(String message, Object... params) { "", "Example", "-------", - " java -Duser.language=de -cp \"myapp.jar;picocli-4.6.2.jar;picocli-codegen-4.6.2.jar\" " + + " java -Duser.language=de -cp \"myapp.jar;picocli-4.6.3-SNAPSHOT.jar;picocli-codegen-4.6.3-SNAPSHOT.jar\" " + "picocli.codegen.docgen.manpage.ManPageGenerator my.pkg.MyClass" } ) diff --git a/src/main/java/picocli/AutoComplete.java b/src/main/java/picocli/AutoComplete.java index 95c91b7d0..dd267fb0e 100644 --- a/src/main/java/picocli/AutoComplete.java +++ b/src/main/java/picocli/AutoComplete.java @@ -108,7 +108,7 @@ private static boolean syspropDefinedAndNotFalse(String key) { "", "Example", "-------", - " java -cp \"myapp.jar;picocli-4.6.2.jar\" \\", + " java -cp \"myapp.jar;picocli-4.6.3-SNAPSHOT.jar\" \\", " picocli.AutoComplete my.pkg.MyClass" }, exitCodeListHeading = "%nExit Codes:%n", diff --git a/src/main/java/picocli/CommandLine.java b/src/main/java/picocli/CommandLine.java index a0acda4c7..8bd98e20d 100644 --- a/src/main/java/picocli/CommandLine.java +++ b/src/main/java/picocli/CommandLine.java @@ -145,7 +145,7 @@ public class CommandLine { /** This is picocli version {@value}. */ - public static final String VERSION = "4.6.2"; + public static final String VERSION = "4.6.3-SNAPSHOT"; private final Tracer tracer = new Tracer(); private CommandSpec commandSpec; @@ -8787,7 +8787,7 @@ private String[] expandVariables(String[] desc) { /** Returns the root option or positional parameter (on the parent command), if this option or positional parameter was inherited; * or {@code null} if it was not. * @see Option#scope() - * @since 4.6.2 */ + * @since 4.6.3-SNAPSHOT */ public ArgSpec root() { return root; } /** Returns the type to convert the option or positional parameter to before {@linkplain #setValue(Object) setting} the value. @@ -9425,7 +9425,7 @@ private static String inferLabel(String label, String fieldName, ITypeInfo typeI /** Returns the root option or positional parameter (on the parent command), if this option or positional parameter was inherited; * or {@code null} if it was not. * @see Option#scope() - * @since 4.6.2 */ + * @since 4.6.3-SNAPSHOT */ public ArgSpec root() { return root; } /** Returns the type to convert the option or positional parameter to before {@linkplain #setValue(Object) setting} the value. @@ -9568,7 +9568,7 @@ private static String inferLabel(String label, String fieldName, ITypeInfo typeI /** * Sets the root object for this inherited option, and returns this builder. - * @since 4.6.2 */ + * @since 4.6.3-SNAPSHOT */ public T root(ArgSpec root) { this.root = root ; return self(); } /** Sets the type to convert the option or positional parameter to before {@linkplain #setValue(Object) setting} the value, and returns this builder. diff --git a/src/test/java/picocli/AutoCompleteTest.java b/src/test/java/picocli/AutoCompleteTest.java index d33cb0b40..78eb118d5 100644 --- a/src/test/java/picocli/AutoCompleteTest.java +++ b/src/test/java/picocli/AutoCompleteTest.java @@ -303,7 +303,7 @@ private static String toString(Object obj) { "%n" + "Example%n" + "-------%n" + - " java -cp \"myapp.jar;picocli-4.6.2.jar\" \\%n" + + " java -cp \"myapp.jar;picocli-4.6.3-SNAPSHOT.jar\" \\%n" + " picocli.AutoComplete my.pkg.MyClass%n"); @Test diff --git a/src/test/java/picocli/CommandLineTest.java b/src/test/java/picocli/CommandLineTest.java index 814cdd12b..edac2d3cc 100644 --- a/src/test/java/picocli/CommandLineTest.java +++ b/src/test/java/picocli/CommandLineTest.java @@ -138,7 +138,7 @@ class App { } @Test public void testVersion() { - assertEquals("4.6.2", CommandLine.VERSION); + assertEquals("4.6.3-SNAPSHOT", CommandLine.VERSION); } @Test public void testArrayPositionalParametersAreReplacedNotAppendedTo() {