Cobra Versions Save

A Commander for modern Go CLI interactions

v1.8.0

5 months ago

โœจ Features

๐Ÿ› Bug fixes

๐Ÿ”ง Maintenance

๐Ÿงช Testing & CI/CD

โœ๏ธ Documentation


Thank you everyone who contributed to this release and all your hard work! Cobra and this community would never be possible without all of you!!!! ๐Ÿ

Full Changelog: https://github.com/spf13/cobra/compare/v1.7.0...v1.8.0

v1.7.0

1 year ago

โœจ Features

  • Allow to preserve ordering of completions in bash, zsh, pwsh, & fish: @h4ck3rk3y #1903
  • Add support for PowerShell 7.2+ in completions: @oldium #1916
  • Allow sourcing zsh completion script: @marckhouzam #1917

๐Ÿ› Bug fixes

  • Don't remove flag values that match sub-command name: @brianpursley #1781
  • Fix powershell completions not returning single word: @totkeks #1850
  • Remove masked template import variable name: @yashLadha #1879
  • Correctly detect completions with dash in argument: @oncilla #1817

๐Ÿงช Testing & CI/CD

  • Deprecate Go 1.15 in CI: @umarcor #1866
  • Deprecate Go 1.16 in CI: @umarcor #1926
  • Add testing for Go 1.20 in CI: @umarcor #1925
  • Add tests to illustrate unknown flag bug: @brianpursley #1854

๐Ÿ”ง Maintenance

  • Update main image to better handle dark backgrounds: @Deleplace and @marckhouzam #1883
  • Fix stale.yaml mispellings: @enrichman #1863
  • Remove stale bot from GitHub actions: @jpmcb #1908
  • Add makefile target for installing dependencies: @umarcor #1865
  • Add Sia to projects using Cobra: @mike76-dev #1844
  • Add Vitess and Arewefastyet to projects using cobra: @frouioui #1932
  • Fixup for Kubescape github org: @dwertent #1874
  • Fix route for GitHub workflows badge: @sh-cho #1884
  • Fixup for GoDoc style documentation: @yashLadha #1885
  • Various bash scripting improvements for completion: @scop #1702
  • Add Constellation to projects using Cobra: @datosh #1829

โœ๏ธ Documentation

  • Add documentation about disabling completion descriptions: @Shihta #1901
  • Improve MarkFlagsMutuallyExclusive example in user guide: @janhn #1904
  • Update shell_completions.md: @gusega #1907
  • Update copywrite year: @umarcor #1927
  • Document suggested layout of subcommands: @lcarva #1930
  • Replace deprecated ExactValidArgs with MatchAll in doc: @doniacld #1836

This release contains several long running fixes, improvements to powershell completions, and further optimizations for completions.

Thank you everyone who contributed to this release and all your hard work! Cobra and this community would never be possible without all of you! ๐Ÿ

Full changelog: https://github.com/spf13/cobra/compare/v1.6.1...v1.7.0

v1.6.1

1 year ago

Bug fixes ๐Ÿ›

  • Fixes a panic when AddGroup isn't called before AddCommand(my-sub-command) is executed. This can happen within more complex cobra file structures that have many different inits to be executed. Now, the check for groups has been moved to ExecuteC and provides more flexibility when working with grouped commands - @marckhouzam (and shout out to @aawsome, @andig and @KINGSABRI for a deep investigation into this! ๐Ÿ‘๐Ÿผ)

v1.6.0

1 year ago

Summer 2022 Release

Some exciting changes make their way to Cobra! Command completions continue to get better and better (including adding --help and --version automatic flags to the completions list). Grouping is now possible in your help output as well! And you can now use the OnFinalize method to cleanup things when all "work" is done. Checkout the full changelog below:


Features ๐ŸŒ 

  • Add groups for commands in help: @aawsome @marckhouzam #1003
  • Support for case-insensitive command names: @YuviGold #1802
  • Expose ValidateRequiredFlags and ValidateFlagGroups: @skeetwu #1760
  • Add --version flag to help output: @fnickels #1707
  • Add --help and --version flag in completions: @marckhouzam #1813
  • Add OnFinalize method: @yann-soubeyrand #1788
  • Allow user to add completion for powershell alias: @marckhouzam #1621
  • Make InitDefaultcompletionCmd public: @gssbzn #1467

Deprecation ๐Ÿ‘Ž๐Ÿผ

  • ExactValidArgs is deprecated (but not being removed entirely). This is abit nuanced, so checkout #1643 for further information and the updated user_guide.md on how this may affect you (and how you can take advantage of the correct behavior in the validators): @umarcor #1643

Bug fixes ๐Ÿ›

  • Fix (bash-v2) activeHelp length check syntax: @scop #1762
  • Fix correct command path in see_also for yaml documentation: @zregvart #1771
  • Fix showing flags that shadow parent persistent flag in child help messaging: @brianpursley #1776

Dependencies ๐Ÿ—ณ๏ธ

  • Upgrade to use gopkg.in/yaml.v3: @tklauser #1766

Testing ๐Ÿค”

  • Test on Golang 1.19: @umarcor & @jpmcb #1782
  • Renamed powershell completion tests: @marckhouzam #1803
  • Use action/setup-go cache: @umarcor #1783
  • Add workflow_dispatch to CI actions: @umarcor #1387
  • Add minimum GitHub token permissions for workflows: @varunsh-coder #1792

Docs โœ๏ธ

  • Fixup spelling for GitHub CLI: @eltociear #1744
  • Clarify SetContext documentation: @katexochen #1748
  • Instruct user to go install for binary: @marckhouzam #1726
  • User guide cleanup: @marckhouzam #1656
  • Document option to hide the default completion command: @marckhouzam #1779

Misc ๐Ÿ’ญ

  • Add KubeVirt, CloudQuery, Cilium, Okteto, Zitadel, Allero to projects using cobra: @maiqueb #1741, @yevgenypats #1742, @tklauser #1745, @jLopezbarb #1759, @fforootd #1772, @dimabru #1819
  • Use correct stale action exempt yaml keys: @jpmcb #1800
  • Add missing license headers: @umarcor #1809

Note: Per #1804, we will be moving away from "seasonal" releases and doing more generic point release targets. Continue to track the milestones and issues in the spf13/cobra GitHub repository for more information!

Great work everyone! Cobra would never be possible without your contributions! ๐Ÿ

Full Changelog: https://github.com/spf13/cobra/compare/v1.5.0...v1.6.0

v1.5.0

1 year ago

Spring 2022 Release ๐ŸŒฅ๏ธ

Hello everyone! Welcome to another release of cobra. Completions continue to get better and better. This release adds a few really cool new features. We also continue to patch versions of our dependencies as they become available via dependabot. Happy coding!

Active help ๐Ÿ‘๐Ÿผ

Shout out to @marckhouzam for a big value add: Active Help https://github.com/spf13/cobra/pull/1482. With active help, a program can provide some inline warnings or hints for users as they hit tab. Now, your CLIs can be even more intuitive to use!

Currently active help is only supported for bash V2 and zsh. Marc wrote a whole guide on how to do this, so make sure to give it a good read to learn how you can add this to your cobra code! https://github.com/spf13/cobra/blob/master/active_help.md

Group flags ๐Ÿง‘๐Ÿผโ€๐Ÿคโ€๐Ÿง‘๐Ÿผ

Cobra now has the ability to mark flags as required or exclusive as a group. Shout out to our newest maintainer @johnSchnake for this! https://github.com/spf13/cobra/pull/1654 Let's say you have a username flag that MUST be partnered with a password flag. Well, now, you can enforce those as being required together:

rootCmd.Flags().StringVarP(&u, "username", "u", "", "Username (required if password is set)")
rootCmd.Flags().StringVarP(&pw, "password", "p", "", "Password (required if username is set)")
rootCmd.MarkFlagsRequiredTogether("username", "password")

Flags may also be marked as "mutally exclusive" with the MarkFlagsMutuallyExclusive(string, string ... ) command API. Refer to our user guide documentation for further info!

Completions ๐Ÿ‘€

Documentation ๐Ÿ“

Testing & CI โš™๏ธ

Beep boop, bot commits ๐Ÿค–

Misc ๐Ÿ’ญ

Shoutout to ALL our contributors (and all the new first time contributors!!) - great work everyone!! Cobra and it's huge impact wouldn't be possible without you ๐Ÿ‘๐Ÿผ ๐Ÿš€ ๐Ÿ

Full Changelog: https://github.com/spf13/cobra/compare/v1.4.0...v1.5.0

v1.4.0

2 years ago

Winter 2022 Release โ„๏ธ

Another season, another release!

Goodbye viper! ๐Ÿ ๐Ÿš€

The core Cobra library no longer requires Viper and all of its indirect dependencies. This means that Cobra's dependency tree has been drastically thinned! The Viper dependency was included because of the cobra CLI generation tool. This tool has migrated to spf13/cobra-cli.

It's pretty unlikely you were importing and using the bootstrapping CLI tool as part of your application (after all, it's just a tool to get going with core cobra).

But if you were, replace occurrences of

"github.com/spf13/cobra/cobra"

with

"github.com/spf13/cobra-cli"

And in your go.mod, you'll want to also include this dependency:

github.com/spf13/cobra-cli v1.3.0

Again, the maintainers do not anticipate this being a breaking change to users of the core cobra library, so minimal work should be required for users to integrate with this new release. Moreover, this means the dependency tree for your application using Cobra should no longer require dependencies that were inherited from Viper. Huzzah! ๐Ÿฅณ

If you'd like to read more

Documentation ๐Ÿ“

Other ๐Ÿ’ญ

Shoutout to our awesome contributors helping to make this cobra release possible!! @spf13 @marckhouzam @johnSchnake @jpmcb @liggitt @umarcor @hiljusti @marians @shyim @htroisi

v1.3.0

2 years ago

v1.3.0 - The Fall 2021 release ๐Ÿ

Completion fixes & enhancements ๐Ÿ’‡๐Ÿผ

In v1.2.0, we introduced a new model for completions. Thanks to everyone for trying it, giving feedback, and providing numerous fixes! Continue to work with the new model as the old one (as noted in code comments) will be deprecated in a coming release.

  • DisableFlagParsing now triggers custom completions for flag names #1161
  • Fixed unbound variables in bash completions causing edge case errors #1321
  • help completion formatting improvements & fixes #1444
  • All completions now follow the help example: short desc are now capitalized and removes extra spacing from long description #1455
  • Typo fixes in bash & zsh completions #1459
  • Fixed mixed tab/spaces indentation in completion scripts. Now just 4 spaces #1473
  • Support for different bash completion options. Bash completions v2 supports descriptions and requires descriptions to be removed for menu-complete, menu-complete-backward and insert-completions. These descriptions are now purposefully removed in support of this model. #1509
  • Fix for invalid shell completions when using ~/.cobra.yaml. Log message Using config file: ~/.cobra.yaml now printed to stderr #1510
  • Removes unnecessary trailing spaces from completion command descriptions #1520
  • Option to hide default completion command #1541
  • Remove __complete command for programs without subcommands #1563

Generator changes โš™๏ธ

Thanks to @spf13 for providing a number of changes to the Cobra generator tool, streamlining it for new users!

  • The Cobra generator now won't automatically include Viper and cleans up a number of unused imports when not using Viper.
  • The Cobra generator's default license is now none
  • The Cobra generator now works with Go modules
  • Documentation to reflect these changes

New Features โญ

  • License can be specified by their SPDX identifiers #1159
  • MatchAll allows combining several PositionalArgs to work in concert. This now allows for enabling composing PositionalArgs #896

Bug Fixes ๐Ÿ›

  • Fixed multiple error message from cobra init boilerplates #1463 #1552 #1557

Testing ๐Ÿ‘€

  • Now testing golang 1.16.x and 1.17.x in CI #1425
  • Fix for running diff test to ignore CR for windows #949
  • Added helper functions and reduced code reproduction in args_test #1426
  • Now using official golangci-lint github action #1477

Security ๐Ÿ”

Documentation ๐Ÿ“

  • Multiple projects added to the projects_using_cobra.md file: #1377 #1501 #1454
  • Removed ToC from main readme file as it is now automagically displayed by GitHub #1429
  • Documentation correct for when the --author flag is specified #1009
  • shell_completions.md has an easier to use snippet for copying and pasting shell completions #1372

Other ๐Ÿ’ญ

  • Bump version of cpuguy83/go-md2man to v2.0.1 #1460
  • Removed lesser typo from the GPL-2.0 license #880
  • Fixed spelling errors #1514

Thank you to all our amazing contributors โญ๐Ÿ๐Ÿš€

v1.2.1

2 years ago

Bug fixes

v1.2.0

2 years ago

:stars: v1.2.0 - The completions release

Welcome to v1.2.0 of Cobra! This release focuses on code completions, several critical bug fixes, some documentation updates, and security bumps. Upgrading should be simple but please take note of the introduction of bash completions V2 and their default use. The v1 completions library is still available, but will be deprecated in the future. Please open an issue with any problems!


New Features

  • Automatically adds a completion command for shell completions. If a completion command is already provided, uses that instead. This will automatically provide shell completions for bash, zsh, fish, and PowerShell https://github.com/spf13/cobra/pull/1192
    • Users can configure the command auto creation:
      • disable the creation of the completion command
      • disable completion descriptions
      • disable the --no-descriptions flag for "always on" completion descriptions
  • Introduction of bash completions V2, a uniform completion approach which include completion descriptions. The V1 bash completions are still available but will be deprecated in a later release - https://github.com/spf13/cobra/pull/1146
    • Note that projects providing completion through a different command name (say a command named "complete") will continue to use v1 for their own command but will also provide cobra's implicit "completion" command which will use v2, unless of course, these projects take the time to disable the default "completion" command as noted above.
  • Commands now support context being passed to completions - https://github.com/spf13/cobra/pull/1265
  • Removed dependency onmitchellh/go-homedir in favor of core Go os.UserHomeDir() - https://github.com/spf13/cobra/commit/8eaca5f0f49ad747a0722d39dca7a75c34abd21a

Bug Fixes

Testing

Security

Other

Thank you to all our amazing contributors :snake::rocket:

v1.1.3

3 years ago
  • Fix: release-branch.cobra1.1 only: Revert "Deprecate Go < 1.14" to maintain backward compatibility