0.055002 -- 2022-02-14
[Bug fixes]
- benchmarks/grep_vs_search.pl
Fix duplicate '-i' option in `grep_vs_search.pl`.
- t/*
Work around GNU readline interaction with xterm. Tests can fail if GNU
readline is told to use STDIN/STDOUT: it may inadvertently output a
`ESC-[?1034h` sequence ("interpret Meta key, enable 8-bit input"), which
does not play well with our `Test::Output` tests.
To avoid this, we specify `filehandles => []` to the `Term::CLI`
constructor.
So far this only manifested itself on OpenBSD 7.0, and only on the
i386 build of that. Still, I want my tests to pass...
[Building / Testing]
- Leave POD test prereqs out of the distribution.
- Improve test coverage (also add tests for `Term::CLI::Util`).
- Fix enviroment testing for skipping tests.
The `Test::Class` `SKIP_ALL` method does not work as advertised.
[Enhancements]
Term::CLI::Util
Make find_* routines a little faster. The `last if ...` check
when iterating over possible matches is not necessary. A simple
unqualified `last` will do.
Term::CLI::Argument::Filename
- Promote `_glob_complete` to `glob_complete`.
0.055001 -- 2022-02-12
[Enhancements]
- Context-sensitive Completion / Validation
`complete` methods now receive a second argument: a HashRef
with "state" information that includes the preceding words on
the command line (in the `$state->{processed}` ArrayRef) and a
collection of options seen so far (in the `$state->{options}`
HashRef).
Argument validators also receive a "state" parameter HashRef
(although it has a different different structure than that of
`complete`, see documentation).
See the demo script in `examples/context_sensitive_completion/`.
- Dynamic Enum Arguments
The `value_list` of Term::CLI::Argument::Enum objects now accepts
a CodeRef, which will be called when the list of values needs
to be fetched.
The new `values` method returns the actual list of values.
The `cache_values` boolean attribute can be used to to execute
the list expansion only once.
The tutorial has been updated to include this.
- Dynamic Command Lists
The `commands` argument of Term::CLI and Term::CLI::Commands
objects (through Term::CLI::Role::CommandSet) now accepts a
CodeRef, which will only be called the first time the command
list is needed. This allows for delayed command building,
which, if used in deeper levels of a command hierarchy, can
reduce start-up time.
A new `delete_command` method allows for dynamic command
hierarchies [RFE#16]. See `examples/dynamic_commands.pl` for
a demo of this.
- New `state` attribute for Term::CLI and Term::CLI::Command
These classes now use a new role called Term::CLI::Role::State
that provides a "state" HashRef that can be used to store
application-specific state.
- Term::CLI
Create a ReadLine object that uses `STDIN` and `STDOUT`
by default, instead of letting (Gnu) ReadLine find and open
the TTY separately. This ensures that:
perl readline_app < input_file
- will actually read input from `input_file`, while also
making sure that whatever encoding you have on the standard I/O
handles (e.g. `use open qw(:std :utf8)`) will also be applied
to ReadLine's I/O. This means that Estonians can write "tõsi"
for "true" and Macedonians can write "лажни" for "false".
- Term::CLI::Argument::Boolean
Completions now match the case of the partial text, so "TR"
gets completed to "TRUE" instead of "TRue".
- Term::CLI::Role::CommandSet
Command lists are now always sorted by name internally. This
allows for optimised searching/matching.
- Term::CLI::Argument::Enum
Value lists are always sorted internally. This allows for
optimised searching/matching, see also examples/big_enum.pl
[New]
- Term::CLI::Util
New module with a few utility functions for other modules.
- Term::CLI::Role::State
A `Moo::Role` that adds a `state` hash to objects.
See examples/state_demo.pl.
- benchmarks/*
A few scripts with benchmarks for different approaches to
particular algorithms.
- examples/cli_context.pl
Demo script for CLI context (provided by djerius).
[Tests]
- Various updates and fixes to test the new functionalities.
[Bug Fixes]
- Term::CLI::Argument::Bool
- Fix case-sensitive completion (used `lc` where we shouldn't).
- Fix test cases for case-insenstive (enum) completion.
- tutorial/example_17_suspend.pl
Don't suspend if there was an error on the command line input.
- Fix Boolean bug in tutorial (and accompanying code).
We specified "1" as a valid value for "false"; that should be "0".
[Miscellaneous]
- Eliminate unnecessary `shift` of function argument in favour
of assigning from `@_`.
- Improve Dutch translation of "unknown (sub-)command"
- Fix dependency on Test::MockModule so it builds on FreeBSD 12.
- POD fixes and updates.
- Term::CLI::Command
Modify error message for invalid arguments for readability.
0.054002 -- 2022-01-05
[Testing]
- Fix test for help command.
Take into account that help text can be rendered using overstrike.
Files modified:
t/065-Term-CLI-Command-Help.t
0.054001 -- 2022-01-04
[Code Cleanup]
- Tests and modules pass perlcritic's "stern" (-4) filter.
- Apply perltidy.
- Properly localise %SIG in `readline`.
- POD fixes.
- Remove unnecessary `else` and `elsif`.
- Run code through perltidy.
- Eliminate some unnecessary else/elsif.
- Remove default export of `loc` from `Term::CLI::L10N`
Explicitly import `loc` in all modules that need it.
- Do not use `package Foo {}` syntax.
All modules have only one `package`, so the block syntax
doesn't add anything and causes perltidy to unnecessarily
indent all code.
[Enhancements]
- Improve filename completion for non-GNU readline
The glob variation now uses a trick when completing directory
names that prevents the readline module from adding a space.
Files modified:
lib/Term/CLI/Argument/Filename.pm
- Add CONTRIBUTING.md, Contributors; fix README
- Add a `clear_error` method to Term::CLI::Base
and use it instead of `set_error('')`.
[Bug Fixes]
- Fix potential bug in line splitting (Term::CLI).
- Work around for old Pod::Text::Termcap, closes #12
Versions of `Pod::Text::Termcap` before 4.11 had a bug (#124447)
that resulted in it using a screen width of 80, regardless of what
was specified in the constructor call or environment. As a result,
the high `=over` indents could cause very strange output or even
make `Pod::Text::Termcap` spin into an eternal loop.
To make life easier for those with older Perl installations,
we test for the older `Pod::Text::Termcap` version and use
`Pod::Text::Overstrike` instead if necessary. The overstrike
variant does not contain the screen width bug, although it does
require a pager that understands overstrike sequences. The default
pager for `Term::CLI` (`less`) does, so the invonvenience should
be minor.
Thanks to djerius for reporting and diagnosing the problem.
Files modified:
lib/Term/CLI/Command/Help.pm
0.053006 -- 2021-12-27
[Compatibility]
- Fix versions of used modules for Perl 5.14.1
If we claim to to be compatible with Perl 5.14, then we should
make sure that the minimum required version of modules included
in the default distribution match up with what we require.
Files modified:
lib/**/*.pm
t/**/*.t
- Use `bsd_glob` instead of `:bsd_glob`
`File::Glob` in Perl 5.14 didn't have the `:bsd_glob` tag yet.
Since we only need the `bsd_glob()` function, just import the
function.
Files modified:
lib/Term/CLI/Argument/Filename.pm
[Bug Fixes]
- Term::CLI::ReadLine
- Make sure Term::ReadKey uses a "TTY" filehandle.
In cases of e.g. automated runs, STDIN and STDOUT may be
redirected. `Term::ReadLine` can handle that, `Term::ReadKey`
cannot, so we need to be explicit.
- Minor POD fixes.
0.053005 -- 2021-12-23
- Validate keyboard signal names before using them.
Files modified:
lib/Term/CLI/ReadLine.pm
- Add back the dependency on Term::ReadLine::Gnu
Tests will break on MSWIN if the ::Perl backend is chosen.
Files modified:
dist.ini
0.053004 -- 2021-12-23
[Bug Fixes]
- Don't use `state` hash; not supported on older Perls
Use `state $xx = { ... }` instead.
Files modified:
lib/Term/CLI/ReadLine.pm
0.053003 -- 2021-12-23
[Packaging]
- Remove author tests from MANIFEST.SKIP
0.053002 -- 2021-12-23
[Packaging]
- Fix MANIFEST.
0.053001 -- 2021-12-22
[Features]
- Now indepenent of Term::ReadLine implementation
I.e. compatible with Term::ReadLine::Perl and Term::ReadLine::Stub
as well (though Term::ReadLine::Gnu is still the best supported).
- Improved signal handling:
- Add `ignore_keyboard_signal`.
- Ignore QUIT control sequence (makes ::Gnu behave like ::Perl).
- Allow Term::CLI::Argument::Enum values to be provided dynamically
Term::CLI::Argument::Enum's value_list attribute may be a coderef,
which should return an array reference of valid values.
(Pull request #13 from djerius/dynamic-enum.)
- Add "cleanup" attribute.
[Tutorial]
- Formatting fixes.
- Add SIGNAL HANDLING section.
- Add HISTORY HANDLING section.
- Add tutorial/example_17_suspend.pl
- Use `local($SIG{...})` in `sleep` command.
[Refactoring]
- Move most history logic to Term::CLI::ReadLine
Term::CLI::ReadLine is much more of a compatibility layer
between Term::CLI and Term::ReadLine now, providing compatibility
code to compensate for missing functionality in the underlying
Term::ReadLine implementation.
[Bug Fixes]
- Fix Enum validation - closes #10
Enum validation finds potential matches to an argument by performing
prefix comparison against the list of valid values. This works fine
as long as the valid values are not prefixes of each other; if they
are, then the shorter strings will never be considered valid input.
- GNU ReadLine - exclude prompt ornaments for leading/trailing whitespace.
The Term::ReadLine::GNU implementation will just slap the prompt
between the ornament-start/ornament-end sequences, but this looks
ugly if there are leading/trailing spaces and the ornament is set
to e.g. underline or standout. This is now brought in line with how
the Term::ReadLine::Perl implementation handles it, by inserting
relevant escape sequences where necessary.
[Packaging]
- Various build fixes.
- Remove prereq on Term::ReadLine::Gnu.
0.052005 -- 2021-05-27
- Increase coverage of Term::CLI.
Files modified:
lib/Term/CLI.pm
t/055-Term-CLI.t
- Remove reference to Modern::Perl
Files modified:
lib/Term/CLI/Tutorial.pod
- Clean up `use` statements and `#!` in examples and tutorials.
Files modified:
examples/*
tutorial/*
0.052004 -- 2021-05-27
- Ignore; tagged without changelog, see 0.052005 instead.
0.052003 -- 2021-05-26
- Packaging fixes
- Get rid of Term::CLI::PerlFeatures again
CPANTS kwalitee indicator complains about missing `use strict`
and `use warnings`. :-(
- Add test coverage for `help --all --pod`
- CLI::Tutorial POD: fix link to "Term::CLI/History Control".
0.052002 -- 2021-05-19
- Packaging fixes.
- POD fixes.
- Get rid of `Modern::Perl` dependency (add `Term::CLI::PerlFeatures`)
- Force use of `Term::ReadLine::Gnu`
`Term::ReadLine` *always* looks at the `PERL_RL` environment variable.
This is a problem if your applications depends on not just
`Term::ReadLine`, but features of `Term::ReadLine::Gnu` in particular.
The way we can force the issue, is to make sure we override `PERL_RL`
before loading `Term::ReadLine`.
The workaround only works if `Term::ReadLine` has not been loaded by
another module yet.
Hopefully, this fixes the CPAN tests on FreeBSD as well.
0.052001 -- 2021-04-30
- Update copyright.
- Packaging fixes.
- Improve "help":
- Fix "help" test suite to fit new POD format.
- Add "--all" flag to "help" command.
- Refactor help text generation.
- POD fixes.
- Update tutorial.
- POD and whitespace fixes.
0.051007 -- 2019-11-18
- Get rid of bogus file "xx".
0.051006 -- 2019-11-18
- Add script to get current version.
Files added:
scratch/get_version.pl
- Autoincrement version if argument is +1.
Files modified:
scratch/fix_version_number.pl
- Do not try to load Term::ReadLine::Gnu directly.
Term::ReadLine::Gnu should not be loaded directly. Instead,
the Term::CLI::ReadLine->new method will check whether a
newly created Term::ReadLine object is of the "::Gnu" variety.
If not, it will call "Carp::confess()".
Files modified:
lib/Term/CLI/ReadLine.pm
0.051005 -- 2019-11-06
- Bad lexical scope for $has_terminator
Re-declared $has_terminator as "my" in the case
of Getopt::Long < 2.51, which made it pretty much a no-op.
Files modified:
lib/Term/CLI/Command.pm
- Fix BuildRequires and Provides in Fedora pkg spec.
Files modified:
pkg/fedora/perl-Term-CLI.spec
0.051004 -- 2019-11-05
- Work around changed Getopt::Long 2.51 behaviour
Getopt::Long 2.51 fixed its documented behaviour ("--" is kept
in the argument list if "pass_through" is specified). Previous
versions removed it. Term::CLI now checks for the Getopt::Long
version and adapts where necessary.
Files modified:
lib/Term/CLI/Command.pm
- Add perl-generators to BuildRequires
Files modified:
pkg/fedora/perl-Term-CLI.spec
- Fix hint on tagging/pushing.
Files modified:
RELEASING
0.051003 -- 2018-07-11
- POD fixes:
- Minor POD polishing.
Files modified:
lib/Term/CLI.pm
lib/Term/CLI/Command.pm
lib/Term/CLI/Intro.pod
- Fix ::Int -> ::Float in POD.
Files modified:
lib/Term/CLI/Argument/Number/Float.pm
- "bss>" -> "bssh>"
Files modified:
lib/Term/CLI/Tutorial.pod
- Fix examples.
Files modified:
lib/Term/CLI/Tutorial.pod
- fix missing comma on callback option
Files modified:
lib/Term/CLI.pm
0.051002 -- 2018-03-16
- Fix version number.
0.05002 might look like "0.05.2", but is in fact "0.50.20".
Insert a digit to make fix this: "0.051002" translates to
"0.51.2".
Files modified:
lib/**/*.pm
0.05002 -- 2018-03-16
[Bug Fixes]
- Don't "reset_after_signal" after re-throwing.
Files modified:
lib/Term/CLI.pm
0.05001 -- 2018-03-16
[Bug Fixes]
- Fix signal handling
- WINCH is now handled correctly.
- TTIN, TTOU, HUP, and TERM are now handled as well.
Files modified:
lib/Term/CLI.pm
- Fix heuristic =over determination.
Files modified:
lib/Term/CLI/Command/Help.pm
[Features]
- Expand tutorial(s).
Files modified:
tutorial/*.t
lib/Term/CLI/Tutorial.pod
[POD fixes]
- Term::CLI::L10N: Add EXAMPLES and DESCRIPTION.
- Term::CLI::Intro: Include L10N modules and Bool argument class.
- Term::CLI: Bring POD in line with code.
- Term::CLI::L10N::nl: its => it's
[Miscellaneous Changes]
- pkg/fedora/perl-Term-CLI.spec: Fix packager.
- lib/**/*.pm: Reduce length of "#==...==" lines.
- Update POD on signal handling.
Files modified:
lib/Term/CLI.pm
- Fix tutorial file names.
Files modified:
lib/Term/CLI/Tutorial.pod
- Update with dzil build.
Files modified:
MANIFEST
0.04009 -- 2018-03-14
- Use $^X to find current Perl interpreter.
Also, remove "#!" line from "fake pager".
Files modified:
t/065-Term-CLI-Command-Help.t
t/scripts/pager.pl
- Lower versions for FindBin, strict, subs, warnings.
Files modified:
t/*
lib/*
0.04008 -- 2018-03-13
[Bug Fixes]
- Fake pager should drain STDIN before exiting.
This should finally fix the failing test in
t/065-Term-CLI-Command-Help.t
Files modified:
t/scripts/pager.pl
[Other Changes]
- Better check and diagnostics for pager error.
Files modified:
t/065-Term-CLI-Command-Help.t
0.04007 -- 2018-03-13
[Bug Fixes]
- Try to add a "diag" to failing test.
Files modified:
t/065-Term-CLI-Command-Help.t
[Other Changes]
- $SIG instead of $::SIG.
Files modified:
lib/Term/CLI/Command/Help.pm
0.04006 -- 2018-03-12
[Other Changes]
- Lower min. version for Moo, drop Moo::Role version.
Files modified:
lib/**/*.pm
- Remove use of POSIX.
Files modified:
lib/Term/CLI/Argument/Number/Float.pm
Makefile.PL
cpanfile
0.04005 -- 2018-03-12
[Bug Fixes]
- Separate STDOUT/pager output for help a bit more.
Also, set "status" to $? regardless of close() result.
Some tests for status still fail, and I'm suspecting a
race condition, making close() return "true". If this
fails as well, then I'll just skip the test. :-(
Files modified:
lib/Term/CLI/Command/Help.pm
[Other Changes]
- Require specific versions of modules.
Minimal versions come from Debian jessie (8) install. Wheezy has
a version of "Moo" that is too old.
Files modified: (almost all)
- Use MetaProvides::Package in dist.ini
Files modified:
dist.ini
- Clean up MANIFEST and gitignore
Files modified:
MANIFEST.SKIP, MANIFEST, .gitignore
- Add script to extract RPM provides from PM files.
Files added:
scratch/get_rpm_provides.pl
- Fix dependencies and provides.
Files modified:
pkg/fedora/perl-Term-CLI.spec
0.04004 -- 2018-03-10
[Bug Fixes]
- Don't check STDERR on pager error.
Something's off in checking STDERR when running an external
pager. Could be race condition? Anyway, we only care about
propagation of the exit status, so just test that.
Tests work in my dev. environment, but fail about 30-50% of
the time on CPAN testers.
Files modified:
t/065-Term-CLI-Command-Help.t
t/scripts/pager.pl
0.04003 -- 2018-03-09
[Bug Fixes]
- Use custom script for pager error exit.
Running external commands in tests is not as easy
as it seems...
Files added:
t/scripts/pager.pl
Files modified:
t/065-Term-CLI-Command-Help.t
[Other Changes]
- Copy MANIFEST from D::Z build.
Files modified:
dist.ini
- Add MANIFEST from D::Z build.
Files added:
MANIFEST
0.04002 -- 2018-03-09
[Bug Fixes]
- Ignore SIGPIPE in _execute_help -- closes #5
Files modified:
lib/Term/CLI/Command/Help.pm
- Select raw STDOUT for help output.
Files modified:
t/065-Term-CLI-Command-Help.t
- Fix English-centred error message check.
Files modified:
t/075-Term-CLI-History.t
[Features]
- Allow empty "pager" (dump to STDOUT)
Instead of falling back to "cat", fall back to
raw STDOUT printing. An empty pager list will
select STDOUT as well.
Files modified:
lib/Term/CLI/Command/Help.pm
[Other Changes]
- Clean up commented-out code.
Files modified:
lib/Term/CLI/Command/Help.pm
0.04001 -- 2018-03-08
[Features]
- Multi-language support through Locale::Maketext.
Files: many
- Add min_len and max_len restrictions to
Term::CLI::Argument::String.
Files:
lib/Term/CLI/Argument/String.pm
- Improve usage text formatting.
Files:
lib/Term/CLI/Role/HelpText.pm
[New Modules]
- Add Term::CLI::L10N
- Add Term::CLI::L10N::en
- Add Term::CLI::L10N::nl
Files:
lib/Term/CLI/L10N.pm
lib/Term/CLI/L10N/en.pm
lib/Term/CLI/L10N/nl.pm
- Add Term::CLI::Argument::Bool
Files:
lib/Term/CLI/Argument/Bool.pm
[Bug Fixes]
- Fix various (POD and diagnostic message) typos.
- Don't use POSIX's strtod() and strtol() for number conversions;
rely on regex and looks_like_number() instead.
Files:
lib/Term/CLI/Argument/Number.pm
lib/Term/CLI/Argument/Number/Float.pm
lib/Term/CLI/Argument/Number/Int.pm
- Tests now force the 'en' language where necessary.
Error messages are hard to verify without forcing
a particular language.
Files:
lib/Term/CLI/Role/HelpText.pm
- Fix usage text with variable number of arguments.
Files:
lib/Term/CLI/Role/HelpText.pm
- Check SUPER's validate with defined(), not boolean eval.
Files:
lib/Term/CLI/Argument/Enum.pm
- Fix "=over" size in command summary to a maximum.
Files:
lib/Term/CLI/Command/Help.pm
- Fix test on FreeBSD - closes #2
Error message from "cat" on invalid option differs from
Linux to FreeBSD. Just check for "cat:" in the error
message instead.
Files:
t/065-Term-CLI-Command-Help.t
- Fix tests for non-English locales - closes #3
Tests were assuming that external commands
communicate their diagnostics in English.
Files:
t/065-Term-CLI-Command-Help.t
t/075-Term-CLI-History.t
- Turn off "-T"
Files:
t/065-Term-CLI-Command-Help.t
0.03002 -- 2018-02-26
[Bug Fixes]
- Fix float comparision in test -- fixes #1
On Perl installs compiled with -Duselongdouble,
1.23e-4 is 0.000123000000000000008, not 0.000123.
- dist.ini: add dependencies not picked up by AutoPrereqs
[Other Changes]
- Update version and dependencies.
0.03001 -- 2018-02-26
- Switch to using Dist::Zilla.
- Some code cleanups (remove unnecessary "use" clauses).
- Fix some POD pages.
0.02 -- 2018-02-24
- Fix version numbers: package Foo 0.02 { ... }
0.01 -- 2018-02-24
- First release.