1.916   2021-12-11  Released-By: PERLANCAR; Urgency: medium

	- [bugfix] Forgot to adjust method call.


1.915   2021-12-10  Released-By: PERLANCAR; Urgency: medium; Backward-Incompatible: yes

	- This release continues the pluginizing process.

        [doc]

        - Add more documentation about plugins.

	[plugins]

        - [incompatible change] Rename plugins: Debugging::* -> Debug::* for
          brevity

        - [incompatible change] Rename plugin: Debugging::Exit -> Flow::Exit for
          clarity

        - [incompatible change] Rename plugin: Plugin::DisablePlugin ->
	  Plugin::Disable for brevity.

        - Move main logic of completion mode to plugin Run::Completion.

	- Move main logic of object-dumping mode to plugin Run::DumpObject.

        [removed]

        - [incompatible change] Remove hook_after_run.

	- [incompatible change] Remove support for PERINCI_CMDLINE_DUMP_ARGS &
          PERINCI_CMDLINE_DUMP_CONFIG.


1.914   2021-12-10  Released-By: PERLANCAR; Urgency: medium

	- [ux] Replace observing x.perinci.cmdline.default_from_schema in
	  argument specification to detecting default in argument
	  specification/schema; this means user does not have to explicitly
	  set that attribute in his function metadata.


1.913   2021-12-09  Released-By: PERLANCAR; Urgency: medium

	- [ux] Add a default 'title' metadata for the result, so result
	  formatted with Text::Table::HTML or Text::Table::HTML::DataTables
	  can be more descriptive.


1.912   2021-12-01  Released-By: PERLANCAR; Urgency: medium

	- Observe argument specification's attribute:
	  x.perinci.cmdline.default_from_schema. Setting this to true lets an
	  argument get default value from schema even if the argument is not
	  specified.

	- [dist] Add dzil plugin and weaver plugin Perinci::CmdLine.

	[internal]

        - Make log more concise by collapsing more request keys.

        - Always use Moo, no longer use Mo. We need BUILDARGS.

	[reorganization, plugins]

        - Move run as plugin event 'run'.

	- Move plugins attribute to Base.

        - Reorganize plugin subnamespace: use per-topic subnamespace, since we
	  will be anticipating many more plugins.

        - Simplify things by always providing -orig_ARGNAME arguments.


1.911   2021-10-02  Released-By: PERLANCAR; Urgency: low

	- No functional changes.

	- Edit previous Changes for clarity.


1.910   2021-10-01  Released-By: PERLANCAR; Urgency: medium

	- [bugfix] Do not use Complete::Bash::parse_cmdline() et al to parse
	  command-line options from environment variable as they are indeed not
	  suitable and will split e.g. a=b into three separate words; use
	  core-module Text::ParseWords instead. This bug affected parsing of
	  "PROGNAME_OPT" environment variables, e.g. in:

           % PROGNAME_OPT="--foo=val1 --bar=val2" progname --baz

          the command-line arguments incorrectly became ("--foo", "=", "val1",
          "--bar", "=", "val2", "--baz").


1.909   2021-10-01  Released-By: PERLANCAR; Urgency: medium

	- Add plugin: Exit.


1.908   2021-10-01  Released-By: PERLANCAR; Urgency: low

        - No functional changes.

        - [doc] Tweak documentation about plugin (list before_ & after_ events,
          add note about currently only a few events have been added)

        - [dist][committer Paul Cochrane] Add initial GitHub Actions
          configuration.

        - [internal] Make code pass standard perlcritic configuration.


1.907   2021-08-06  Released-By: PERLANCAR; Urgency: medium

	- Rename dependency Data::Clean::JSON -> Data::Clean::ForJSON
	  (GH#12).


1.906   2021-07-11  Released-By: PERLANCAR; Urgency: medium

	- [ux] Provide key to common options to be able to group them in
	  usage line (ref: Perinci::Sub::To::CLIDocData 0.298).


1.905   2021-06-23  Released-By: PERLANCAR; Urgency: medium

	- [bugfix] Add missing dependency to PerlIO::locale (ref:
          https://github.com/perlancar/perl-App-RegexpPatternUtils/issues/3).


1.904   2021-04-15  Released-By: PERLANCAR; Urgency: medium

	- [ux] Give .html suffix to tempfile() to convince Google Chrome to view
          a temporary file as HTML (for --format=html+datatables).


1.903   2021-01-30  Released-By: PERLANCAR; Urgency: low

	- No functional changes.

	- Edit Changes again.


1.902   2021-01-30  Released-By: PERLANCAR; Urgency: low

	- No functional changes.

	- Edit Changes.


1.901   2021-01-30  Released-By: PERLANCAR; Urgency: medium

	- [bugfix] Handle the missing assignment -n shortcut for --dry-run in
	  the case of hook_after_get_meta() is run twice (probably since we
	  added plugin support; haven't investigated yet)

        - [ux] Add shortcut -N for --no-dry-run.


1.900   2020-10-21  Released-By: PERLANCAR; Urgency: medium

        - Add plugin support, modeled after ScriptX.

	- Put Perinci::CmdLine object in $r->{cmdline}, for convenience.


1.829   2020-05-26  Released-By: PERLANCAR; Urgency: medium

	- [experimental] Inspect result's content_type and set default
	  viewer and processing for text/x-org content.

	- Add common option: --view-result:s, similar to what we previously
	  did with --page-result:s.


1.828   2020-04-27  Released-By: PERLANCAR; Urgency: medium

	- [ux] Add 'value_label' keys to common options, to be utilized in usage
	  line by Perinci::Sub::To::CLIDocData.

        - [ux] Wrap usage line which can now be potentially long because it now
          lists all options instead of just '[options]'.

	- [bugfix] Don't add a usage for --page-result, because that will
	  result in the --page-result option being shown a dedicated usage
	  line.


1.827   2020-04-01  Released-By: PERLANCAR; Urgency: medium

	- Add attribute: allow_unknown_opts.

	- Adjust to Perinci::CmdLine::Help 0.172 (must now pass
	  meta_is_normalized=1 or meta will be normalized first).


1.826   2020-01-31  Released-By: PERLANCAR; Urgency: medium

	- Add common option: --page-result:s.


1.825   2019-11-12  Released-By: PERLANCAR; Urgency: medium

	- [bugfix] Set default in 'dry_run' common option specification so
	  CLI scripts with features => {dry_run => {default=>1}} in their
	  metadata can have help that shows the more helpful --no-dry-run
	  instead of --dry-run.


1.824   2019-07-04  Released-By: PERLANCAR; Urgency: low

	- [experimental] Use pre-compiled validator code in
	  Sah::SchemaV::*.


1.823   2019-07-04  Released-By: PERLANCAR; Urgency: medium

	- Observe function feature 'validate_args' and skip validating args
	  if function states that it can validate args.

	- [ux][completion] Show message when trying to complete
	  --config-profile but no config is read.

	- [ux][completion] Show message when trying to complete not from
	  cmdline.

	- [Rinci] Remove usage of the deprecated x.schema.element_entity
	  attribute, use schema instead.


1.822   2019-06-26  Released-By: PERLANCAR

	- No functional changes.

	- Bump prereqs Complete::Bash=0.322 and
	  Perinci::Sub::Complete=0.935.


1.821   2019-06-25  Released-By: PERLANCAR

	- [ux] Show summaries when completing subcommands (via
	  Complete::Util 0.601) and option names (via
	  Perinci::Sub::Complete 0.934).


1.820   2019-06-20  Released-By: PERLANCAR

	- No functional changes.

	- Update dep: Perinci::Sub::GetArgs::Argv=0.842.


1.819   2019-06-02  Released-By: PERLANCAR

	- Introduce cmdline.resut.interactive and
	  cmdline.result.noninteractive.

	- Observe PERINCI_CMDLINE_DUMP_ARGS & PERINCI_CMDLINE_DUMP_CONFIG.

	- Rename PERINCI_CMDLINE_DUMP to PERINCI_CMDLINE_DUMP_OBJECT (old
	  name is still supported but no longer documented, will be removed
	  in the future).


1.818   2019-05-24  Released-By: PERLANCAR

	- Get result's schema in resmeta's schema (Rinci 1.1.90) before
	  function metadata result property.


1.817   2019-01-14  Released-By: PERLANCAR

	- Remove --format, --json, --naked-res when function metadata
	  specifies cmdline.skip_format => 1.


1.816   2018-11-22  Released-By: PERLANCAR

	- [ux] Dump %main::SPEC to x.main.spec.

	- Avoid duplicate config file reading.


1.815   2018-07-16  Released-By: PERLANCAR

	- Invoke hook_before_parse_argv() in do_completion() and do_dump()
	  so command-line options that might be introduced in this hook are
	  also recognized.


1.814   2018-06-14  Released-By: PERLANCAR

	- [ux] When response status is not between 200 and 555 (e.g. when
	  we use HTTP::Tiny's HTTP response status 599 Internal Exception
	  as response status), instead of complaining a 'bug' set response
	  status to 555 and note the original response status in result
	  meta's x.orig_status.


1.813   2018-05-29  Released-By: PERLANCAR

	- [Bugfix] To check whether script uses -P, -c, -C we need to get
	  meta first and this is only possible in script without
	  subcommand.


1.812   2018-05-01  Released-By: PERLANCAR

        - [ux] Add shortcut options when there is no conflict: -P for
	  --config-profile, -c for --config-path, -C for --no-config.

	- [internal] Add hook: before_parse_argv.

	- Observe LOG_DUMP_CONFIG environment variable.

	- [doc] Format/sort POD sections, document PERINCI_CMDLINE_DUMP.


1.811   2018-03-05  Released-By: PERLANCAR

	- Introduce new hook_config_file_section.

	- [doc] Remove documentation of old attribute.


1.810   2017-12-11  Released-By: PERLANCAR

        - [Experimental] Observe PERINCI_CMDLINE_OUTPUT_DIR to save program
          output to a JSON file.


1.80    2017-11-01  Released-By: PERLANCAR

	- [Bugfix] Wrap stream arguments as iterator.

	- [Bugfix] Make sure we turn off result stream when self-dumping.


1.79    2017-08-09  Released-By: PERLANCAR

	- Lite: Support format 'perl'.


1.78    2017-08-04  Released-By: PERLANCAR

	- Second attempt to switch from JSON to JSON::MaybeXS.


1.77    2017-07-22  Released-By: PERLANCAR

	- [ux] Add -n as a shortcut for common option --dry-run when there
	  is no conflict.

	- [ux] When in dry-run mode, default to log level 'info' instead of
	  'warn' because my convention is to use 'info' level to log
	  dry-run messages.

	- [doc] Update: per_arg_yaml actually defaults to off for Lite.


1.76    2017-07-14  Released-By: PERLANCAR

         - No functional changes since last dev release.


1.75_001 2017-07-12  Released-By: PERLANCAR

	- Use Log::ger::App, move up logger initialization code from Lite
	  to Base.


1.75     2017-06-28  Released-By: PERLANCAR

         - No functional changes since last dev release.


1.74_004 2017-06-21  Released-By: PERLANCAR

        - Remove Log::Any support. To show logs from Log::Any, install
          Log::Any::Adapter::LogGer and run CLI scripts with
          PERL5OPT=-MLog::Any::Adapter=LogGer.


1.74_003 2017-06-19  Released-By: PERLANCAR

        - Really replace Log::Any with Log::ger, previous couple of commits were
          screwed up.


1.74_002 2017-06-19  Released-By: PERLANCAR

        - No functional changes.

        - Forgot to update the summaries for --log-level, --debug, et al about
          not having to use LOG=1 etc crap.

        - UPDATE: this release was broken.


1.74_001 2017-06-19  Released-By: PERLANCAR

	- [Experimental] Switch from Log::Any to Log::ger. Log::ger provides
          smaller startup overhead and will allow us to change levels during
          program run. The effect of this switch is that logs produced by
          modules that use Log::Any won't show by default; to show Log::Any logs
          run your CLI scripts with LOG_ANY=1.

        - UPDATE: this release was broken.


1.74    2017-06-17  Released-By: PERLANCAR

	- [Bugfix] Don't check deps when in completion/dump mode.


1.73    2017-06-17  Released-By: PERLANCAR

        - Support cooperative dump mode to help Perinci::CmdLine::Dump create a
          more proper dump.


1.72    2017-01-16  Released-By: PERLANCAR

        - Add attribute: use_cleanser to allow skipping data cleansing.


1.71    2017-01-13  Released-By: PERLANCAR

	- [dist] Bump prereq versions Test::Perinci::CmdLine=1.47 &
	  Perinci::CmdLine::Util::Config=1.71 (to force upgrade of
	  Config::IOD::Reader to 0.31, to get implicit path encoding).

	- [Bugfix] Add _ prefix to default env name if program starts with
	  digit (so: 2plural -> _2PLURAL_OPT).


1.70    2017-01-10  Released-By: PERLANCAR

	- No functional changes.

	- Remove embedding of ShellQuote::Any::Tiny (I don't feel embedding
	  is elegant or worth the hassle, we should fatpack/datapack only
	  scripts).


1.69    2017-01-04  Released-By: PERLANCAR

	- [dist] Split Perinci::CmdLine::Util::Config to its own dist so it
	  can be depended by Perinci::CmdLine::Inline-generated scripts
	  without dragging us along with it.

	- [dist] Add x_alt_for prereq to Perinci::CmdLine::Classic.

	- Format html+datatables: use // instead of = to allow user to
	  override VIEW_RESULT & FORMAT_PRETTY_TABLE_BACKEND.


1.68    2016-12-29  Released-By: PERLANCAR

	[ENHANCEMENTS]

	- Support viewing result with an external viewer program
	  (cmdline.view_result, cmdline.viewer, VIEW_RESULT, VIEWER, BROWSER).

        - Add output format html+datatables. This will open a browser (BROWSER
          must be set, VIEWER must be unset or set to a browser) and when the
          data can be shown as a table, will show HTML table which you can
          search and sort using jQuery and DataTables jQuery plugin. Currently
          implemented by setting VIEW_RESULT to 1 and
          FORMAT_PRETTY_TABLE_BACKEND to Text::Table::HTML::DataTables. The said
          module is currently not listed as prereq so you have to install it
          manually.

	- Observe PAGE_RESULT to force paging or explicitly disable paging.


1.67    2016-12-17  Released-By: PERLANCAR

	- [ux] Add attribute: auto_abbrev_subcommand (default true) to
	  automatically complete subcommand name if given an unambiguous
	  abbreviation, like auto_abbrev behavior in Getopt::Long.


1.66    2016-12-15  Released-By: PERLANCAR

        - Observe default=>1 in 'dry_run' feature property in Rinci function
          metadata (Rinci 1.1.83).


1.65    2016-12-15  Released-By: PERLANCAR

	- [Enhancement] Add default_dry_run attribute to allow a script to be in
          dry-run mode by default.

        - [Bugfix] Workaround issue in Getopt::Long where gnu_compat disables
          bundling as a side effect, so we enable bundling after gnu_compat
          (ref: [RT#119165]).

        - Bump prereq version Perinci::Sub::GetArgs::Argv (support hash option:
          --arg k1=v1 --arg k2=v2 ...).


1.64    2016-12-02  Released-By: PERLANCAR

	- Set Getopt::Long configuration gnu_compat.


1.63    2016-10-27  Released-By: PERLANCAR

	- Add attribute: default_format.


1.62    2016-10-26  Released-By: PERLANCAR

        - Adjust with new version of Complete::{Fish,Zsh} which have their
          parse_cmdline() routine removed.

        - Avoid perl undef warning (for older perl, e.g. 5.10).


1.61    2016-09-28  Released-By: PERLANCAR

	- Also clean stream record before encoding to JSON.


1.60    2016-09-25  Released-By: PERLANCAR

	- Revert from JSON::MaybeXS to JSON because JSON::MaybeXS is not
	  depakable ATM (hard dependency to Cpanel::JSON::XS).

	- [doc] Document undocumented attributes: per_arg_json,
	  per_arg_yaml, extra_urls_for_version, riap_client, cleanser.

	- [Experimental] Provide original (pre-coerced) argument values in
	  -orig_ARGNAME special arguments.


1.59    2016-08-30  Released-By: PERLANCAR

        - [Bugfix] Forgot to add no_getopt_compat Getopt::Long option (we don't
          want to use + to start option e.g. for +h, +help).


1.58    2016-08-18  Released-By: PERLANCAR

	- [Bugfix][Regression] When section is not specified in
	  'config_filenames', include all sections from that config file.


1.57    2016-08-03  Released-By: PERLANCAR

        - The 'config_filename' attribute can now be an array of hash instead of
          just array of strings. Each hash can contain these keys: 'filename',
          as well as 'section' to specify which section should be read from the
          file (instead the default 'GLOBAL' section). This allows a scenario of
          main/general and more specific config files. For example, suppose you
          have a suite of applications called 'mysuite' and programs 'app1' and
          'app2' that belong to the suite. The program 'app1' can be set to read
          from 'mysuite.conf' as well as the more specific 'app1.conf'. But in
          'mysuite.conf', the configuration is read from the [app1] (or say
          [app.app1]) section. This allows 'mysuite.conf' to contain
          configuration for a hierarchy of programs/subsystems without being
          mixed up.

        - [Removed] Remove support for old section syntax in config: [SUBCOMMAND
          profile=P1 ...] now has to be written as [subcommand=SUBCOMMAND
          profile=P1 ...]. Otherwise, the name before the first key=value pair
          will be assumed to be a section name.


1.56    2016-07-20  Released-By: PERLANCAR

        - No functional changes.

        - [dist] Bump prereq versions to force upgrades (support for schemas
          based on other schemas): Data::Sah to 0.84,
          Perinci::Sub::GetArgs::Argv to 0.72.


1.55    2016-05-20  Released-By: PERLANCAR

	- Replace Perinci::Sub::CoerceArgs with Data::Sah 0.76+ coercion.


1.54    2016-05-09  Released-By: PERLANCAR

        - Properly complete Unicode filenames. This include converting
          command-line arguments from octets into Unicode strings (though this
          should probably be enabled only when LANG =~ /UTF-8/ or something),
          and converting completion filename answer entries from octets to
          Unicode strings (done by Complete-File).

        - [Internal] Move up attribute 'use_utf8' from PC:Lite to PC:Base.


1.53    2016-04-04  Released-By: PERLANCAR

	- [ux] For argument with cmdline_src=stdin_or_args, only get from
	  stdin when stdin is piped, otherwise sometimes user gets confused
	  because program seems to hang when such argument is not
	  specified.


1.52    2016-03-16  Released-By: PERLANCAR

	- No functional changes.

	- Replace JSON with JSON::MaybeXS.


1.51    2016-02-26  Released-By: PERLANCAR

	- Implement cmdline_src=stdin_or_args (Rinci 1.1.79).


1.50    2016-02-04  Released-By: PERLANCAR

	- [Bugfix] When streaming input (argument) has schema=array, use
	  its 'of' clause subschema.

	- Adjust to Complete::Bash 0.27.

	- In completing --config-profile, force reading of config files
	  (previously if program has subcommands and no subcommand name is
	  specified in ARGV, parse_argv() will skip directly to --help.


1.49    2016-01-23  Released-By: PERLANCAR

	- Allow filtering config section with env=...

	- [Bugfix] Config sections should be read according to the order
	  they are seen in the files.


1.48    2016-01-22  Released-By: PERLANCAR

	- Bump prereq version Test::Perinci::CmdLine to 1.37.

	- Observe cmdline.chomp (allow turning-off autochomping of
	  streaming input record).


1.47    2016-01-22  Released-By: PERLANCAR

        - Chomp streaming input record, unless type is 'buf'. Adjust to
          Test::Perinci::CmdLine 1.36.


1.46    2016-01-21  Released-By: PERLANCAR

	- Update to Test::Perinci::CmdLine 1.33.

	- Allow filtering config section with program=...

	- Add use_utf8 to Lite, just like in Classic.


1.45    2016-01-14  Released-By: PERLANCAR

	- [Lite] Add attribute 'use_utf8' just like in Classic.


1.44    2016-01-07  Released-By: PERLANCAR

	- Allow multiple config_filename.


1.43    2015-12-30  Released-By: PERLANCAR

	- Use Complete::Bash 0.23's new option truncate_current_word, like
	  in Getopt::Long::Complete and Getopt::Long::Subcommand.

	- Bump prereq version Log::Any::IfLOG to 0.07.


1.42    2015-12-02  Released-By: PERLANCAR

        - Adopt a new syntax for specifying configuration for subcommand.
          Previously to specify configuration for a subcommand, you use
          '[SCNAME]' section (or when you want to assign a profile: '[SCNAME
          profile=PNAME]', now you use '[subcommand=SCNAME]' (or when you want
          to assign a profile: '[subcommand=SCNAME profile=PNAME]' or
          '[profile=PNAME subcommand=SCNAME]'). Basically, we now regard IOD
          section as a whitespace-separated list of key=value pairs. This new
          syntax is clearer and more generic, it allows application to add its
          own key=value pair as needed. The old syntax is now not documented.
          Although it will still be supported for sometime, it will be removed
          in the future.


1.41    2015-11-29  Released-By: PERLANCAR

	- [Experimental] Detect 'td' (see App::td) at the right side of
	  pipeline and set default output format to json.


1.40    2015-11-27  Released-By: PERLANCAR

	- On error, don't display result as stream but show format &
	  display error message instead.


1.39    2015-11-21  Released-By: PERLANCAR

	- Adjust to Perinci::Result::Format::Lite 0.07 (CSV support).


1.38    2015-11-17  Released-By: PERLANCAR

	- No functional changes.

	- Bump prereq version Test::Perinci::CmdLine to 1.27 [CT].


1.37    2015-11-11  Released-By: PERLANCAR

	- No functional changes.

	- [dist] Add YAML::Old to TestRequires prereq [CT].

	- [doc] Remove duplicate documentation (configuration is documented
	  in Perinci::CmdLine::Manual).


1.36    2015-10-20  Released-By: PERLANCAR

	- No functional changes.

	- [dist] Downgrade prereq Term::ReadKey from requires to recommends
	  (it's only required when reading password argument from stdin),
	  this means that as of this release, the dependency chain of
	  Perinci::CmdLine::Lite (and ::Base) is now all PP/core (this
	  module is more convenient when used in fatpacking/datapacking).


1.35    2015-10-03  Released-By: PERLANCAR

	- No functional changes.

	- Update mentioned module App::fatten (has been renamed to
	  App::depak).


1.34    2015-09-29  Released-By: PERLANCAR

	- No functional changes.

        - Adjust to Test::Perinci::CmdLine 1.25.


1.33    2015-09-29  Released-By: PERLANCAR

	- Workaround for Perinci::CmdLine::Classic.


1.32    2015-09-18  Released-By: PERLANCAR

	- No functional changes.

	- Move manual to Perinci-CmdLine.


1.31    2015-09-17  Released-By: PERLANCAR

	- No functional changes.

	- [Bugfix] Avoid undef warning (weird, shouldn't the default be
	  computed during object construction?).


1.30    2015-09-15  Released-By: PERLANCAR

	- [ux] Prefix error message with program name.


1.29    2015-09-11  Released-By: PERLANCAR

	- Extract result formatting functionality to
	  Perinci-Result-Format-Lite.


1.28    2015-09-06  Released-By: PERLANCAR

	- No functional changes.

	- [dist] Move spec prereqs from RuntimeRequires to
	  DevelopRecommends to reduce deps but still allow indicating spec
	  requirement.


1.27    2015-08-17  Released-By: PERLANCAR

	- [ux] Since we are moving to Log::Any::IfLOG for most, add note
	  about having to enable logging using env LOG=1 etc.


1.26    2015-08-09  Released-By: PERLANCAR

	- [Bugfix] Add missing newline in error message.


1.25    2015-08-09  Released-By: PERLANCAR

	- [ux] Show error message even under skip_format=>1.


1.24    2015-07-28  Released-By: PERLANCAR

	- No functional changes.

	- Reformat Changes entry and add attribution to Dave Jacoby's blog
	  post.


1.23    2015-07-28  Released-By: PERLANCAR

	- [ux] Give suggestion for similar subcommand/option names in error
	  message when user types unknown subcommand name or common option.
	  Inspired by Dave Jacoby's blog post
	  <http://varlogrant.blogspot.com/2015/07/what-i-learned-from-perlbrew.html>.
	  Code borrowed with some adjustments. Note that we have not done this
	  when user types unknown function option, because
	  Perinci::Sub::GetArgs::Argv (Getopt::Long under the hood) does not
	  return enough detailed information, it only warns to STDERR "Unknown
	  opt: foo" without returning this information. The future planned
	  Perinci::Sub::Getopt that will replace Perinci::Sub::GetArgs will
	  remedy this.

	- [pod] Fix formatting (need whitespace after C<< >>).


1.22    2015-07-15  Released-By: PERLANCAR

	- Show dynamic generator modules' (x.dynamic_generator_modules)
	  version in --version.


1.21    2015-07-08  Released-By: PERLANCAR

	- Add attribute: skip_format.


1.20    2015-07-07  Released-By: PERLANCAR

	- [Bugfix] In help, get meta first so if function has dry_run
	  feature, we can show the option.


1.19    2015-07-06  Released-By: PERLANCAR

	- Fix newlines in -v output.


1.18    2015-07-06  Released-By: PERLANCAR

	- Observe Rinci function metadata attribute cmdline.skip_format (in
	  addition to result metadata attribute).

	- Update Rinci result metadata attributes interpreted by this
	  module: x.perinci.cmdline._skip_format -> cmdline.skip_format.


1.17    2015-06-30  Released-By: PERLANCAR

	- Add extra_urls_for_version attribute.


1.16    2015-06-19  Released-By: PERLANCAR

	- No functional changes.

	- Update prereq name
	  Log::Any::Adapter::{ScreenColoredLevel,Screen}.


1.15    2015-06-19  Released-By: PERLANCAR

	- Add FAQ items about debugging (show log messages, show stack
	  trace).

	- Detect if Devel::Confess is loaded and include the stack trace in
	  error message.


1.14    2015-06-11  Released-By: PERLANCAR

	- Split Test::Perinci::CmdLine to its own dist (to be modified to
          support Perinci::CmdLine::Inline as well).

        - Replace tests with test suite from Test::Perinci::CmdLine.


1.13    2015-05-06  Released-By: PERLANCAR

	- Check args_rels property.


1.12    2015-04-25  Released-By: PERLANCAR

	- [ux] --json will default to json-pretty when in interactive mode,
	  but compact when non-interactive.


1.11    2015-04-25  Released-By: PERLANCAR

	- Add attribute: validate_args to allow disabling args validation.


1.10    2015-04-12  Released-By: PERLANCAR

	- [Bugfix] Respect table_column_orders for table in simple-text
	  format.


1.09    2015-04-12  Released-By: PERLANCAR

	- [Bugfix] Regression since 1.02 (the addition of coercing):
	  required argument was not checked because of variable reuse.


1.08    2015-04-11  Released-By: PERLANCAR

	- Add common option: --no-env to prevent reading env for default
	  options.


1.07    2015-04-11  Released-By: PERLANCAR

	- [Bugfix] regex for checking config section names was too strict.

	- Tweak bench-startup: remove 'run_noop (comp)' because it's not
	  very useful, add bench for measuring startup overhead of
	  producing completion for int arg and str arg + in clause.


1.06    2015-04-09  Released-By: PERLANCAR

        [ENHANCEMENTS]

        - Add new hooks: before_action, after_action.

        - Perinci::CmdLine::Lite now validates arguments (in
          hook_before_action). This closes the gap further between it and
          Perinci::CmdLine::Classic.

        - [Developer] Add devscripts/bench-startup.

        [INCOMPATIBLE CHANGES]

        - [Internal] run_* methods are now renamed action_* to better reflect
          their nature.


1.05    2015-04-07  Released-By: PERLANCAR

        - Configuration can now set some common options like log_level, format,
          and naked_res (any option that is specified as is_settable_via_config
          => 1). If a function argument happens to clash with common option
          name, user can use 'NAME.arg' to refer to function argument
          unambiguously.

        - Tweak configuration parameter reading: GLOBAL section will still be
          read even when subcommand is specified, non-profiled section will
          still be read even when profile name is specified. This means we can
          add common parameters that will be used by any profile, and/or any
          subcommand.

        - Tweak common option's categories. Now most common options have
          category (e.g. logging, output) so list of options in help message (as
          well as POD/manpage) looks nicer and more scannable/skimmable.


1.04    2015-04-02  Released-By: PERLANCAR

	- [Bugfix] Fix/tweak config reading, when running subcommand
	  [profile=PROFILE] section is also read in addition to [SUBCMD
	  profile=PROFILE] section.


1.03    2015-04-01  Released-By: PERLANCAR

	- Add hook: after_read_config_file.

	- Replace File::HomeDir with PERLANCAR::File::HomeDir.

	- New Complete::Bash no longer has 3rd parameter (word_breaks).


1.02    2015-03-30  Released-By: PERLANCAR

	- Add argument coercing (Perinci::Sub::CoerceArgs).


1.01    2015-03-26  Released-By: PERLANCAR

	- Put cleanser as an attribute to allow it be configurable.


1.00    2015-03-24  Released-By: PERLANCAR

        - No functional changes.

        - [opt] Shave +- 2-3ms startup time by avoiding experimental+Carp.


0.99    2015-03-22  Released-By: PERLANCAR

	- No functional changes.

	- [doc] Add more attractive Synopsis, link to tutorial blog series.


0.98    2015-03-20  Released-By: PERLANCAR

	- No functional changes.

	- Update prereq version (Config::IOD::Reader 0.14) to avoid CT
	  failure reports.

	- [opt] Replace Log::Any if Log::Any::IfLOG.


0.97    2015-03-19  Released-By: PERLANCAR

	- Set naked_res & format from common option's default.


0.96    2015-03-18  Released-By: PERLANCAR

        - Support cmdline_src=stdin_or_file (Rinci 1.1.74).

        - [Incompatible changes] When cmdline_src=file, special argument is now
          -cmdline_srcfilenames_ARG (single-element array) like in the case of
          cmdline_src=stdin_or_files, instead of -cmdline_srcfilename_ARG. The
          same for when cmdline_src=stdin_or_file.


0.95    2015-03-18  Released-By: PERLANCAR

	- Provide special arguments -cmdline_srcfilenames_ARG for arguments
	  with cmdline_src=stdin_or_files.


0.94    2015-03-18  Released-By: PERLANCAR

	- Allow --no-naked-res.

	- Pass -cmdline_r special argument so function gets access to 'r'
	  structure.


0.93    2015-03-17  Released-By: PERLANCAR

	- [Bugfix] dry_run hasn't been passed to function yet.


0.92    2015-03-10  Released-By: PERLANCAR

	- [Incompatible change] Rename result metadata key
	  'result_format_options' to 'format_options' (also, try to look
	  for 'cmdline.format_options' first).

	- [Bugfix] Do not set actual result to cmdline.result (but only set
	  it temporarily for formatting purposes).

	- Check invalid result from run_XXX method() (not an array, invalid
	  status).


0.91    2015-03-07  Released-By: PERLANCAR

	- Add option to normalize metadata in get_args_from_config(), for
	  lcpanm.


0.90    2015-03-07  Released-By: PERLANCAR

        - Check dependencies before run ('deps' property).


0.89    2015-03-05  Released-By: PERLANCAR

	- [Bugfix] Environment PROG_OPT should be read and added to ARGV
	  after _parse_argv1 (after we extract subcommand name).


0.88    2015-02-27  Released-By: PERLANCAR

	- Search $HOME/.config before $HOME for config files.


0.87    2015-02-26  Released-By: PERLANCAR

	- [Bugfix] Pass subcommands hash to Perinci::CmdLine::Help even
	  though subcommands list is dynamic (coderef).


0.86    2015-02-24  Released-By: PERLANCAR

        - [ux] Reorder columns in table output according to result metadata's
          result_format_options->table_column_orders, result metadata's
          table.fields, or FORMAT_PRETTY_TABLE_COLUMN_ORDERS.

        - [ux] Tweak formatting of table with header row.


0.85    2015-02-21  Released-By: PERLANCAR

        - [Bugfix] Assume all 2xx (not just 200) as well as 304 as success (exit
          code 0).


0.84    2015-02-06  Released-By: PERLANCAR

        - No functional changes.

        - [doc] Reflect the Perinci::CmdLine -> Perinci::CmdLine::Classic rename
          in the documentation.


0.83    2015-01-28  Released-By: PERLANCAR

	- No functional changes.

	- Move patching of Log::Any::Adapter::ScreenColoredLevel to
	  Progress::Any::Output::Term* so it can be used outside of
	  Perinci::CmdLine.


0.82    2015-01-22  Released-By: PERLANCAR

	- Add progress bar feature to Perinci::CmdLine::Lite, like in
	  Perinci::CmdLine.


0.81    2015-01-20  Released-By: PERLANCAR

        - Add JSON stream (input, output) support. Currently this is only
          minimally documented. Basically, if argument type is non-simple, then
          each input stream line will be assumed to be in JSON (an exception
          will be thrown if it does not parse as valid JSON) and will be decoded
          before fed to function. Likewise, if result type is non-simple, then
          every record will be encoded to JSON to produce JSON stream.


0.80    2015-01-17  Released-By: PERLANCAR

        - Support Rinci 1.1.71, where streaming input & output uses coderef
          only.

        - [Bugfix] Respect 'result/stream' metadata property which provides
          default for whether result is streaming or not (it is overriden by the
          'stream' result metadata property).

        - [doc] Reorganize manual: to avoid confusion, move all examples from
          FAQ to Examples. Add examples for result streaming. Update examples.


0.79    2015-01-15  Released-By: PERLANCAR

	- Fixes in help message (program summary from meta was not
	  displayed, show subcommands, passed wrong variable).


0.78    2015-01-14  Released-By: PERLANCAR

	- Refactor config reading routine to
	  Perinci::CmdLine::Util::Config, change 'read_config_file' request
	  key to 'read_config_files', add request key 'config' containing
	  the whole config.


0.77    2015-01-10  Released-By: PERLANCAR

	- No functional changes.

	- Add logging messages.


0.76    2015-01-09  Released-By: PERLANCAR

	- [Bugfix] Fix completing positional function arguments when there
	  are subcommands.


0.75    2015-01-09  Released-By: PERLANCAR

        - No functional changes.

        - Some fixes.


0.74    2015-01-09  Released-By: PERLANCAR

	[ENHANCEMENTS]

        - Support supplying options from environment variable (like, e.g. cpanm
          with its PERL_CPANM_OPT). By default environment variable named
          '${PROG}_OPT' is used, e.g. if your script is named 'foo-bar' then the
          environment variable FOO_BAR_OPT is consulted. The name is
          configurable.

        - Configuration parameter from outside section is now also used. This
          allows putting common parameters.

        [REMOVED FEATURES]

        - Remove deprecated section naming in configuration variable
          ('[PROFILE]' and '[SUBCOMMAND PROFILE]'). The correct and supported
          naming is now ['profile=PROFILE'] and '[SUBCOMMAND profile=PROFILE]'.
          This is already undocumented and deprecated since several releases
          ago. This release removes the feature.

        [DOCUMENTATION]

        - Add section 'Program Flow' and 'Configuration File'.


0.73    2015-01-04  Released-By: PERLANCAR

	- Re-add support for fish and zsh.


0.72    2014-12-29  Released-By: PERLANCAR

	- Adjust to Complete::Bash 0.14 which contains workaround for the
	  annoyance of completing word containing ':' in bash.


0.71    2014-12-23  Released-By: PERLANCAR

	- Split help message generating functionality to
	  Perinci-CmdLine-Help so it's usable too by App-riap.


0.70    2014-12-20  Released-By: PERLANCAR

	- No functional changes.

	- Adjust to periscomp 0.68+.


0.69    2014-12-19  Released-By: PERLANCAR

        - Add completion for --config-profile.


0.68    2014-12-19  Released-By: PERLANCAR

        - [Bugfix] Assigned to wrong 'args' variable so -cmdline was not passed
          even though user had specified -pass_cmdline_object.

        - [Internal] Refactor: move common bits of default common_opts from
          ::Lite to ::Base to reduce code duplication.


0.67    2014-12-18  Released-By: PERLANCAR

	- Fix proper location of config dir on Windows

        - HOME gets a priority over /etc.


0.66    2014-12-18  Released-By: PERLANCAR

	- Use HOMEPATH instead of HOME on Windows for default config_dirs.


0.65    2014-12-18  Released-By: PERLANCAR

	- No functional changes.

	- [dist] Let's try again adding Complete::Util as prereq on
	  Windows.


0.64    2014-12-18  Released-By: PERLANCAR

	- No functional changes.

	- [dzil] Make Complete::* modules prereq on Unix only for now.


0.63    2014-12-15  Released-By: PERLANCAR

	- [ux] Don't show aos as table, because the border is often
	  annoying, what most people want is a simple 1-element-per-line.


0.62    2014-12-13  Released-By: PERLANCAR

	- Avoid running phase 1 of parse_argv() twice if parse_argv() happens to
          be called after _parse_argv1() (for example, inside custom completion
          which wants to call parse_argv() to get command-line arguments).


0.61    2014-12-13  Released-By: PERLANCAR

	- Pass r and cmdline as extra arguments to completion routine.


0.60    2014-12-13  Released-By: PERLANCAR

        - No functional changes.

        - Tweak/update documentation, including instruction for activating tab
          completion (mention shcompgen), logging.


0.59    2014-12-03  Released-By: PERLANCAR

        - [Experimental] Add --naked-res (this is not yet introduced in
          Perinci::CmdLine) for convenience when piping JSON result to something
          else.


0.58    2014-12-02  Released-By: PERLANCAR

	- Switch Perinci::Sub::To::{CLIOptSpec,CLIDocData}.

        - Render examples in help message.


0.57    2014-11-29  Released-By: PERLANCAR

	- Use zsh-specific module for zsh completion.


0.56    2014-11-29  Released-By: PERLANCAR

        - Support tab completion for fish shell.

        - [ux] Change 'argv' to 'arg' in help message.


0.55    2014-11-23  Released-By: PERLANCAR

	- No functional changes.

	- Mention about zsh support.


0.54    2014-11-23  Released-By: PERLANCAR

        - Add support for tcsh tab completion.


0.53    2014-11-21  Released-By: PERLANCAR

        - Tweak --help output: show cmdline_src, positional arguments.


0.52    2014-11-21  Released-By: PERLANCAR

        [REMOVED FEATURES]

        - Only provide --no-config instead of also --noconfig (to make --help
          message nicer).


0.51    2014-11-20  Released-By: PERLANCAR

        - Tweak --help message (show default value, note about base64/json/yaml
          encoding).


0.50    2014-11-20  Released-By: PERLANCAR

        - Use the new Perinci::Sub::To::CLIOptSpec for nicer display of options
          in --help.


0.49    2014-11-13  Released-By: PERLANCAR

        - Handle arrayifying scalar parameter from config file to array
          arguments [GH#3].

        - A couple of bug fixes.


0.48    2014-11-12  Released-By: PERLANCAR

	- Regard 304 as success aside from 2xx.


0.47    2014-11-12  Released-By: PERLANCAR

	- Pass -cmdline_src_ARGNAME and -cmdline_srcfilename_ARGNAME
	  special hint arguments.


0.46    2014-11-09  Released-By: PERLANCAR

	- Introduce request stash keys:
	  ignore_missing_config_profile_section & read_config_file.


0.45    2014-11-08  Released-By: PERLANCAR

	- [ux] Prefix log messages with program name.


0.44    2014-11-07  Released-By: PERLANCAR

	- No functional changes.

	- [Bugfix] Fix typo in help message.


0.43    2014-11-07  Released-By: PERLANCAR

        [ENHANCEMENTS]

        - Add logging (currently simple using
          Log::Any::Adapter::ScreenColoredLevel, and defaults to off).

        - Show extra result in run_completion for debugging (can be seen in JSON
          format, for example).

        [BUG FIXES]

        - Forgot to use Mo's qw/default/ to make default work.


0.42    2014-10-31  Released-By: PERLANCAR

	- Tweak help message: show --subcommands when program has
	  subcommands and doesn't specify one.


0.41    2014-10-30  Released-By: PERLANCAR

        - Add support for streaming input and output.


0.40    2014-10-28  Released-By: PERLANCAR

        [BUG FIXES]

        - Forgot to return response (when status is not 2xx and format is text).

        - Avoid perl undef warning.

        [ENHANCEMENTS]

        - Skip envelope if status is 2xx, not just 200.

        - [ux] Bail out if specified config profile is not found.

        - Set EOL to empty string when encoding base64, for smaller encoding
          result.


0.39    2014-10-25  Released-By: PERLANCAR

	- Only do converting of ARG -> ARG:base64 when riap_version is 1.2.


0.38    2014-10-24  Released-By: PERLANCAR

	- No functional changes.

	- Add example for dealing with binary data.


0.37    2014-10-24  Released-By: PERLANCAR

	- No functional changes.

	- Avoid perl undef warning.


0.36    2014-10-24  Released-By: PERLANCAR

        - Send as-is (no newline) if result is binary and format is text.

        - Automatically encode binary/buf arguments when sending to server.

        - Allow buf args to have cmdline_src set.


0.35    2014-10-24  Released-By: PERLANCAR

	- Add attribute: riap_version.


0.34    2014-10-23  Released-By: PERLANCAR

	- No functional changes.

	- Typo: unimplemented status is 501, not 502.


0.33    2014-10-16  Released-By: PERLANCAR

        - Add hook: before_read_config_file.


0.32    2014-10-09  Released-By: PERLANCAR

        - Better error message when metadata does not specify argument schema
          (now die with "BUG: Schema not defined for arg $arg").

        - Push the use of Perinci::Sub::Args::Argv 0.52 to test whether support
          for argument submetadata breaks other stuffs.


0.31    2014-09-17  Released-By: PERLANCAR

	- [Bugfix] Didn't set default value of args (from default property
	  of arg spec or schema default).

	- Tweak die string.


0.30    2014-09-16  Released-By: PERLANCAR

	- Handle output paging and streaming output (functionality moved from
          Perinci::CmdLine).


0.29    2014-09-11  Released-By: PERLANCAR

	- Handle arguments with cmdline_src=stdin_line and is_password
	  (Rinci 1.1.53).


0.28     2014-09-05  Released-By: PERLANCAR

         - Fix doc: function metadata is 'cmdline.default_format', not
           'x.perinci.cmdline.default_format'.

         - 'cmdline.default_format' property in result metadata takes precedence
           over function metadata's.


0.27     2014-09-03  Released-By: PERLANCAR

         - Handle the case when we must send ARGV instead of args hash (when
           parse_args_from_argv returns 501).


0.26     2014-09-03  Released-By: PERLANCAR

         - [Bugfix] Ordering.


0.25     2014-09-03  Released-By: PERLANCAR

         - No functional change.

         - Extract some functionality to Perinci-Access-Lite, to make it easier
           to add http support.


0.24     2014-08-29  Released-By: PERLANCAR

         - Avoid failure in 00-compile.t [CT].


0.23     2014-08-27  Released-By: PERLANCAR

         - Handle cmdline_src argument spec property (functionality moved from
           Perinci::CmdLine).


0.22     2014-08-26  Released-By: SHARYANTO

         [INCOMPATIBLE CHANGES]

         - Change configuration profile syntax from '[PROFILENAME]' to
           '[profile=PROFILENAME]' (for use with subcommand: '[SUBCMDNAME
           profile=PROFILENAME]'.


0.21     2014-08-25  Released-By: SHARYANTO

         - No functional changes.

         - Workaround for default for config_filename not being set properly if
           used by Moo subclass (in Perinci::CmdLine).


0.20     2014-08-25  Released-By: SHARYANTO

         [ENHANCEMENTS]

         - Add support for configuration file.


0.19     2014-08-24  Released-By: SHARYANTO

         - Base: Use Mo if used by Perinci::CmdLine::Lite, otherwise use Moo
           when used by Perinci::CmdLine use Moo. This is because there is a
           problem with role attributes not being applied when Moo subclass
           extends Mo class.


0.18     2014-08-24  Released-By: SHARYANTO

         - Fix logic errors.


0.17     2014-08-23  Released-By: SHARYANTO

         - Handle result metadata: cmdline.default_format, cmdline.skip_format,
           cmdline.result.


0.16     2014-08-22  Released-By: SHARYANTO

         - Fixes, mainly to make Perinci::CmdLine work again.


0.15     2014-08-21  Released-By: SHARYANTO

         - Fix passing $r to common option's handler in parse_argv().


0.14     2014-08-16  Released-By: SHARYANTO; Note: Happy 19th CPAN Day!

         - Configure Getopt::Long no_ignore_case.


0.13     2014-08-16  Released-By: SHARYANTO; Note: Happy 19th CPAN Day!

         - A few minor bug fixes.


0.12     2014-08-07  Released-By: SHARYANTO

         - Complete --cmd value.

         - [Bugfix] Fix completion of subcommands ('gu ^').


0.11     2014-07-31  Released-By: SHARYANTO

         - Add usage and argument position information in help.

         - Handle args_as array/arrayref/hashref.

         [INTERNAL]

         - Add more tests.


0.10     2014-07-29  Released-By: SHARYANTO

         - Adjust to Perinci::Sub::Complete 0.60.

         [INCOMPATIBLE CHANGES]

         - Rename attributes 'custom_completer' to 'completion', remove
           'custom_arg_completer'.


0.09     2014-07-25  Released-By: SHARYANTO

         - No functional changes.

         - Adjust to Complete::Bash 0.09 (no more break_cmdline_into_words(),
           parse_cmdline() no longer strips command name).


0.08     2014-07-24  Released-By: SHARYANTO

         - Adjust to Getopt::Long::Util 0.46 (required by
           Perinci::Sub::GetArgs::Argv 0.46) which already sorts options.

         [BUG FIXES]

         - Don't add newline if result is an empty string.

         - Hasn't retrieved meta yet for version action.

         [INTERNAL]

         - Add some tests.


0.07     2014-07-23  Released-By: SHARYANTO

         - [Bugfix] A couple of bug fixes.

         [ENHANCEMENTS]

         - Show previous error in error message.

         - Handle result_naked=1.

         [INTERNAL]

         - Adjust to Perinci::Sub::GetArgs::Argv 0.46.


0.06     2014-07-18  Released-By: SHARYANTO

         - No new features.

         - Organize dist, merge Perinci::CmdLine::Base from Perinci-CmdLine-Base
           (now will be removed) and Perinci::CmdLine::Manual::* from
           Perinci-CmdLine.

         - Add minimal tests.


0.02     2014-07-18  Released-By: SHARYANTO

         - Require Perinci::CmdLine::Base 0.04 (which contains fixes, especially
           completion).

         - Fix and tweak 'subcommands' action.

         - Implement run_help() to display decent help message.


0.01     2014-07-16  Released-By: SHARYANTO

         - First release, early release, completion not yet implemented.