Releases: python-cmd2/cmd2
Releases · python-cmd2/cmd2
0.9.12 (April 22, 2019) 🌍
- Bug Fixes
- Fixed a bug in how redirection and piping worked inside
pyorpyscriptcommands - Fixed bug in
async_alertwhere it didn't account for prompts that contained newline characters - Fixed path completion case when CWD is just a slash. Relative path matches were incorrectly prepended with a slash.
- Fixed a bug in how redirection and piping worked inside
- Enhancements
- Added ability to include command name placeholders in the message printed when trying to run a disabled command.
- See docstring for
disable_command()ordisable_category()for more details.
- See docstring for
- Added instance attributes to customize error messages without having to override methods. Theses messages can also be colored.
help_error- the error that prints when no help information can be founddefault_error- the error that prints when a non-existent command is run
- The
with_argparserdecorators now add the Statement object created when parsing the command line to theargparse.Namespaceobject they pass to thedo_*methods. It is stored in an attribute called__statement__. This can be useful if a command function needs to know the command line for things like logging. - Added a
-toption to theloadcommand for automatically generating a transcript based on a script file - When in a pyscript, the stdout and stderr streams of shell commands and processes being piped to are now captured and included in the
CommandResultstructure.
- Added ability to include command name placeholders in the message printed when trying to run a disabled command.
- Potentially breaking changes
- The following commands now write to stderr instead of stdout when printing an error. This will make catching errors easier in pyscript.
do_help()- when no help information can be founddefault()- in all cases since this is called when an invalid command name is run_report_disabled_command_usage()- in all cases since this is called when a disabled command is run
- Removed *** from beginning of error messages printed by
do_help()anddefault() - Significantly refactored
cmd.Cmdclass so that all class attributes got converted to instance attributes, also:- Added
allow_redirection,terminators,multiline_commands, andshortcutsas optional arguments tocmd2.Cmd.__init__() - A few instance attributes were moved inside
StatementParserand properties were created for accessing them
- Added
self.pipe_procis now calledself.cur_pipe_proc_readerand is aProcReaderclass.- Shell commands and commands being piped to while in a pyscript will function as if their output is going to a pipe and not a tty. This was necessary to be able to capture their output.
- Removed
reserved_wordsclass attribute due to lack of use - Removed
keywordsinstance attribute due to lack of use
- The following commands now write to stderr instead of stdout when printing an error. This will make catching errors easier in pyscript.
0.9.11 (March 13, 2019)
- Bug Fixes
- Fixed bug in how history command deals with multiline commands when output to a script
- Fixed a bug when the
with_argument_listdecorator is called with the optionalpreserve_quotesargument - Fix bug in
perror()where it would try to print an exception Traceback even if none existed
- Enhancements
- Improvements to the history command
- Simplified the display format and made it more similar to bash
- Added -x, --expanded flag
- output expanded commands instead of entered command (expands aliases, macros, and shortcuts)
- Added -v, --verbose flag
- display history and include expanded commands if they differ from the typed command
- Added support for negative indices
- Added
matches_sort_keyto override the default way tab completion matches are sorted - Added
StdSim.pause_storagemember which when True will causeStdSimto not save the output sent to it. See documentation forCommandResultinpyscript_bridge.pyfor reasons pausing the storage can be useful. - Added ability to disable/enable individual commands and entire categories of commands. When a command is disabled, it will not show up in the help menu or tab complete. If a user tries to run the command or call help on it, a command-specific message supplied by the developer will be printed. The following commands were added to support this feature.
enable_command()enable_category()disable_command()disable_category()
- Improvements to the history command
- Potentially breaking changes
- Made
cmd2_appa positional and required argument ofAutoCompletersince certain functionality now requires that it can't beNone. AutoCompleterno longer assumesCompletionItemresults are sorted. Therefore you should follow thecmd2convention of settingself.matches_sortedto True before returning the results if you have already sorted theCompletionItemlist. Otherwise it will be sorted usingself.matches_sort_key.- Removed support for bash completion since this feature had slow performance. Also it relied on
AutoCompleterwhich has since developed a dependency oncmd2methods. - Removed ability to call commands in
pyscriptas if they were functions (e.gapp.help()) in favor of only supporting onepyscriptinterface. This simplifies future maintenance. - No longer supporting C-style comments. Hash (#) is the only valid comment marker.
- No longer supporting comments embedded in a command. Only command line input where the first non-whitespace character is a # will be treated as a comment. This means any # character appearing later in the command will be treated as a literal. The same applies to a # in the middle of a multiline command, even if it is the first character on a line.
- # this is a comment
- this # is not a comment
- Made
0.9.10 (February 22, 2019)
0.9.10 (February 22, 2019)
- Bug Fixes
- Fixed unit test that hangs on Windows
0.9.9 (February 21, 2019)
- Bug Fixes
- Fixed bug where the
setcommand was not tab completing from the currentsettabledictionary.
- Fixed bug where the
- Enhancements
- Changed edit command to use do_shell() instead of calling os.system()
0.9.8 (February 06, 2019)
- Bug Fixes
- Fixed issue with echoing strings in StdSim. Because they were being sent to a binary buffer, line buffering was being ignored.
- Enhancements
- Made quit() and exit() functions available to scripts run with pyscript. This allows those scripts to exit back to the console's prompt instead of exiting the whole application.
0.9.7 (January 08, 2019)
- Bug Fixes
- Fixed bug when user chooses a zero or negative index when calling
Cmd.select() - Restored behavior where
cmd_echoalways starts as False in a py script. This was broken in 0.9.5.
- Fixed bug when user chooses a zero or negative index when calling
- Enhancements
- cmdloop now only attempts to register a custom signal handler for SIGINT if running in the main thread
- commands run as a result of
default_to_shellbeing True now run viado_shell()and are saved
to history. - Added more tab completion to pyscript command.
- Deletions (potentially breaking changes)
- Deleted
Cmd.colorize()andCmd._colorcodeswhich were deprecated in 0.9.5 - Replaced
dir_exe_onlyanddir_onlyflags inpath_completewith optionalpath_filterfunction
that is used to filter paths out of completion results. perror()no longer prepends "ERROR: " to the error message being printed
- Deleted
0.9.6 (October 13, 2018)
- Bug Fixes
- Fixed bug introduced in 0.9.5 caused by backing up and restoring
self.promptinpseudo_raw_input.
As part of this fix, continuation prompts will not be redrawn withasync_update_promptorasync_alert.
- Fixed bug introduced in 0.9.5 caused by backing up and restoring
- Enhancements
- All platforms now depend on wcwidth to assist with asynchronous alerts.
- Macros now accept extra arguments when called. These will be tacked onto the resolved command.
- All cmd2 commands run via
pynow go throughonecmd_plus_hooks.
0.9.5 (October 11, 2018)
- Bug Fixes
- Fixed bug where
get_all_commandscould return non-callable attributes - Fixed bug where alias command was dropping quotes around arguments
- Fixed bug where running help on argparse commands didn't work if they didn't support -h
- Fixed transcript testing bug where last command in transcript has no expected output
- Fixed bugs with how AutoCompleter and ArgparseFunctor handle argparse
arguments with nargs=argparse.REMAINDER. Tab completion now correctly
matches how argparse will parse the values. Command strings generated by
ArgparseFunctor should now be compliant with how argparse expects
REMAINDER arguments to be ordered. - Fixed bugs with how AutoCompleter handles flag prefixes. It is no
longer hard-coded to use '-' and will check against the prefix_chars in
the argparse object. Also, single-character tokens that happen to be a
prefix char are not treated as flags by argparse and AutoCompleter now
matches that behavior. - Fixed bug where AutoCompleter was not distinguishing between a negative number and a flag
- Fixed bug where AutoCompleter did not handle -- the same way argparse does (all args after -- are non-options)
- Fixed bug where
- Enhancements
- Added
exit_codeattribute ofcmd2.Cmdclass- Enables applications to return a non-zero exit code when exiting from
cmdloop
- Enables applications to return a non-zero exit code when exiting from
ACHelpFormatternow inherits fromargparse.RawTextHelpFormatterto make it easier
for formatting help/description text- Aliases are now sorted alphabetically
- The set command now tab-completes settable parameter names
- Added
async_alert,async_update_prompt, andset_window_titlefunctions- These allow you to provide feedback to the user in an asychronous fashion, meaning alerts can
display when the user is still entering text at the prompt. See async_printing.py
for an example.
- These allow you to provide feedback to the user in an asychronous fashion, meaning alerts can
- Cross-platform colored output support
coloramagets initialized properly inCmd.__init()- The
Cmd.colorssetting is no longer platform dependent and now has three values:- Terminal (default) - output methods do not strip any ANSI escape sequences when output is a terminal, but
if the output is a pipe or a file the escape sequences are stripped - Always - output methods never strip ANSI escape sequences, regardless of the output destination
- Never - output methods strip all ANSI escape sequences
- Terminal (default) - output methods do not strip any ANSI escape sequences when output is a terminal, but
- Added
macrocommand to create macros, which are similar to aliases, but can take arguments when called - All cmd2 command functions have been converted to use argparse.
- Renamed argparse_example.py to decorator_example.py to help clarify its intent
- Added
- Deprecations
- Deprecated the built-in
cmd2support for colors includingCmd.colorize()andCmd._colorcodes
- Deprecated the built-in
- Deletions (potentially breaking changes)
- The
preparse,postparsing_precmd, andpostparsing_postcmdmethods deprecated in the previous release
have been deleted- The new application lifecycle hook system allows for registration of callbacks to be called at various points
in the lifecycle and is more powerful and flexible than the previous system
- The new application lifecycle hook system allows for registration of callbacks to be called at various points
aliasis now a command with sub-commands to create, list, and delete aliases. Therefore its syntax
has changed. All current alias commands in startup scripts or transcripts will break with this release.unaliaswas deleted sincealias deletereplaced it
- The
0.9.4 (August 21, 2018)
- Bug Fixes
- Fixed bug where
preparsewas not getting called - Fixed bug in parsing of multiline commands where matching quote is on another line
- Fixed bug where
- Enhancements
- Improved implementation of lifecycle hooks to support a plugin
framework, seedocs/hooks.rstfor details. - New dependency on
attrsthird party module - Added
matches_sortedmember to support custom sorting of tab-completion matches - Added tab_autocomp_dynamic.py example
- Demonstrates updating the argparse object during init instead of during class construction
- Improved implementation of lifecycle hooks to support a plugin
- Deprecations
- Deprecated the following hook methods, see
hooks.rstfor full details:cmd2.Cmd.preparse()- equivalent functionality available
viacmd2.Cmd.register_postparsing_hook()cmd2.Cmd.postparsing_precmd()- equivalent functionality available
viacmd2.Cmd.register_postparsing_hook()cmd2.Cmd.postparsing_postcmd()- equivalent functionality available
viacmd2.Cmd.register_postcmd_hook()
- Deprecated the following hook methods, see
0.8.9 (August 20, 2018)
- Bug Fixes
- Fixed extra slash that could print when tab completing users on Windows
NOTE: This is likely the final release of cmd2 for Python 2.7