Skip to content

Releases: spring-projects/spring-shell

3.0.0-RC1

11 Jan 10:44
Compare
Choose a tag to compare
3.0.0-RC1 Pre-release
Pre-release

Generic Notes

Fixes

This release candicate uses Spring Boot 3.0.1 and contains some notable changes:

  • Better model of defining error handling with annotations
  • CommandParser reports errors for unrecognised options
  • CommandRegistration Builder has a shared configurable instance
  • Global help options

Issues

#607 Create BuilderSupplier interface
#602 CommandParser unrecognised option support
#601 Option position may break required error
#597 Support exception handling with annotated methods
#596 Upgrade spring-boot 3.0.1
#593 BaseSingleItemSelector.preHandler returns null instead of this
#586 Global help option type is wrong
#585 Support shared CommandRegistration Builder
#582 Global help options
#579 Docs updates

2.1.5

11 Jan 10:45
Compare
Choose a tag to compare

Generic Notes

Fixes

This GA contains some notable changes:

  • Builds on Spring Boot 2.7.7
  • Some bug fixes backported

Issues

#604 backport(602) CommandParser unrecognised option support
#603 backport(601) Option position may break required error
#598 backport(593) BaseSingleItemSelector.preHandler returns null instead of this
#595 Upgrade spring-boot 2.7.7
#594 backport(526) Prevent ExtendedDefaultParser warning

3.0.0-M3

01 Dec 17:56
Compare
Choose a tag to compare
3.0.0-M3 Pre-release
Pre-release

Generic Notes

Fixes

This milestone uses Spring Boot 3.0.0 and contains some notable changes:

  • Usual bug fixes
  • New testing modules

Issues

#576 Build sample with musl on linux
#575 ShellOption not registered without hyphens
#574 Upgrade spring-boot 3.0.0
#572 Method execution should not error without value
#568 Upgrade spring-boot 3.0.0-RC2
#567 Handle whitespace in option value
#565 Auto-config classes should use @autoConfiguration
#558 Docs updates
#552 Fix e2e flow.test.ts locally
#516 JLine Terminal should be configurable
#489 Provide a testing framework

2.1.4

01 Dec 16:14
Compare
Choose a tag to compare

Generic Notes

Fixes

This GA contains some notable changes:

  • Builds on Spring Boot 2.7.6
  • Some bug fixes backported

Issues

#577 backport(575) ShellOption not registered without hyphens
#573 backport(572) Method execution should not error without value
#571 Upgrade spring-boot 2.7.6
#570 backport(567) Handle whitespace in option value

3.0.0-M2

24 Oct 13:02
Compare
Choose a tag to compare
3.0.0-M2 Pre-release
Pre-release

Generic Notes

Fixes

This milestone uses Spring Boot 3.0.0-RC1 and contains some notable changes:

  • Hidden commands
  • Truncate long text in components
  • Better exception handling
  • More descriptive error message when required option is not present
  • New PathSearch Component

Here are some screencasts for new functionality.

m2-hidden
m2-pathsearch
m2-truncate

Issues

#561 Make assertj dependency optional
#557 Upgrade spring-boot 3.0.0-RC1
#556 PathSearch component
#555 Docs updates
#548 Parser should process types
#543 Components should truncate long text
#503 More descriptive error message when required option is not present
#416 Support hidden commands

2.1.3

24 Oct 06:51
Compare
Choose a tag to compare

Generic Notes

Fixes

This GA contains some notable changes:

  • Builds on Spring Boot 2.7.5
  • Some bug fixes backported

Issues

#549 backport(548) Parser should process types
#547 Upgrade spring-boot 2.7.5

3.0.0-M1

04 Oct 14:56
Compare
Choose a tag to compare
3.0.0-M1 Pre-release
Pre-release

Generic Notes

Fixes

This milestone contains some notable changes:

  • Using Spring Boot 3.x
  • Support for GraalVM mostly complete
  • Project is now build with gradle

Issues

#540 Upgrade native-build-tools 0.9.14
#535 Fix release workflows for gradle
#529 Improve JPMS support by adding Automatic-Module-Name
#527 Docs changes
#526 Prevent ExtendedDefaultParser warning
#525 Add starter for jansi
#524 Move starter modules under starters
#523 Upgrade spring-boot 3.0.0-M5
#521 Could not find org.springframework.shell:spring-shell-management:3.0.0-SNAPSHOT.
#510 next does not work as expected in ComponentFlow
#506 Upgrade gradle 7.5.1
#504 Split builtin command docs
#495 Incorrect completion for options
#493 Spring shell is defaulting to the base Jakarta validator
#490 Provide needed aot configs
#486 Build publish broken
#470 Switch to gradle
#385 Rework for boot 3.x

PRs

#520 Docs correctness!

2.1.2

04 Oct 13:57
Compare
Choose a tag to compare

Generic Notes

Fixes

This GA contains some notable changes:

  • Builds on Spring Boot 2.7.4
  • Some bug fixes backported

Issues

#538 Upgrade spring-boot 2.7.4
#513 backport(510) next does not work as expected in ComponentFlow

2.1.1

19 Aug 13:40
Compare
Choose a tag to compare

Generic Notes

Fixes

This GA contains some notable changes:

  • Builds on Spring Boot 2.7.3
  • Some bug fixes backported

Issues

#505 backport(504) Split builtin command docs
#500 Upgrade spring-boot 2.7.3
#498 backport(495) Incorrect completion for options
#496 backport(493) Spring shell is defaulting to the base Jakarta validator

2.1.0

23 Jul 14:23
Compare
Choose a tag to compare

Generic Notes

Fixes

This GA contains some notable changes:

  • Builds on Spring Boot 2.7.2
  • Some styling changes
  • Help commands now knows about aliases
  • MultiItemSelector component can now have items selected on default
  • Some fixes on @ShellOption

Issues

#480 Add commands as list in help templating
#477 Upgrade to Spring Boot 2.7.2
#476 Component styling bad for black on white
#461 ShellOption booleans are now mandatory in 2.1.0-RC1
#458 Help should group commands with aliases
#454 Create GA release workflow
#446 Missing option error without ShellOption
#426 Add aliases info to help

PRs

#468 Add the possibility of default selection to MultiItemSelector
#455 Fix typos in using-shell-options-optional.adoc

Additional Notes

Recap

Earlier this year we started an effort align the project with latest Spring Boot and Spring Framework versions as it was difficult to use existing Spring Shell release of a spring family.

Originally the main issue we wanted to address was a removal of a bean cycles which Spring Boot is now enforcing by default. While this feature can be turned off it is not something Spring Shell should require. This required a lot of changes and we chose to handle it with rework of a shell internals. One big challenge was how the old Spring Shell worked by essentially keeping command info methods backed by @ShellMethod annotations and then calling those methods via reflection using not so well defined ways.

Now that it was clear that we needed to do a bigger overhaul it made sense to do further development now rather than waiting for Spring Boot 3 and Spring Framework 6 which Spring Shell eventually would have needed to support.

Here is a recap of the changes that were done:

Command Registration

CommandRegistration is a new programmatic way to define commands. The existing annotation model of commands translates to these registration behind a scene. This new registration model now allows to us control commands dynamically which wasn't the case in the old shell implementation.

Existing Annotations

What comes for @ShellMethod and @ShellOption We've tried to keep those compatible and future development will most likely introduce new annotations more aligned with CommandRegistration.

Theming

Modern terminal implementations are not bound to just show a simple text, but allow for different types of font styles and can be used with colors. In the old Spring Shell these were mostly hard coded while it was possible to use ANSI sequences via JLine to write anything into a console. It made sense to introduce a theming system where text written can be styled and figures chosen per style. Figures are just unicode characters supported by modern terminals which is the basis for creating pretty shell UI's.

sample-style-list

sample-figure-list

UI Components

You've mostly likely used various CLI tools which go beyond just asking some text from a user and then doing something based on that. For example GitHub CLI is a good example as some of its commands enter interactive mode and ask users for input using various tricks like selector lists and other sort of shell style forms.

What we wanted to accomplish in Spring Shell was to create these components which can be use independently or combine those into a flow.

component-flow-showcase-1

Graal

A big topic in a future Spring Framework release is native compilation with GraalVM. This obviously makes a big impact on the CLI side as that little jvm bootstrap timeout goes away when your existing code is translated into native binary.

With 2.1.x it was shown using our experimental Spring Native project that it is possible to create a Spring Shell application which works the same way in Linux, MacOS and Windows.

sample-version-linux

sample-version-win

sample-version-macos

Official support for GraalVM in Spring Shell comes with 3.x.

Templating

Writing a command into a terminal is easy as you essentially just write something. However what we've done in some of the built-in commands like help is not always something a user wants to have or they may have other reasons to modify how it looks. Some default outputs from Spring Shell are now based on templates based on ST4 from the ANTRL project.

This allows a user to replace templates used in Spring Shell and modify default behaviour. These templates also integrate into the theme framework so that it's possible to define templates per active theme.