IMPORTANT The Arg.converter
type is deprecated in favor of the
Arg.conv
type. For this release both types are equal but the next
major release will drop the former and make the latter abstract. All
users are kindly requested to migrate to use the new type and only
via the new Arg.[p]conv
and Arg.conv_{parser,printer}
functions.
- Allow terms to be used more than once in terms without tripping out documentation generation (#77). Thanks to François Bobot and Gabriel Radanne.
- Disallow defining the same option (resp. command) name twice via two different arguments (resp. terms). Raises Invalid_argument, used to be undefined behaviour (in practice, an arbitrary one would be ignored).
- Improve converter API (see important message above).
- Add
Term.exit[_status]
andTerm.exit_status_of[_status]_result
. improves composition withPervasives.exit
. - Add
Term.term_result
andTerm.cli_parse_result
improves composition with terms evaluating toresult
types. - Add
Arg.parser_of_kind_of_string
. - Change semantics of
Arg.pos_left
(see #76 for details). - Deprecate
Term.man_format
in favor ofArg.man_format
. - Reserve the
--cmdliner
option for library use. This is unused for now but will be in the future. - Relicense from BSD3 to ISC.
- Safe-string support.
- Build depend on topkg.
The following changes affect the end-user behaviour of all binaries using cmdliner.
- Required positional arguments. All missing required position arguments are now reported to the end-user, in the correct order (#39). Thanks to Dmitrii Kashin for the report.
- Optional arguments. All unknown and ambiguous optional argument arguments are now reported to the end-user (instead of only the first one).
- Change default behaviour of
--help[=FMT]
option.FMT
no longer defaults topager
if unspecified. It defaults to the new valueauto
which prints the help aspager
orplain
whenever theTERM
environment variable isdumb
or undefined (#43). At the API level this changes the signature of the typeTerm.ret
and valuesTerm.ret
,Term.man_format
(deprecated) andManpage.print
to add the new`Auto
case to manual formats. These are now represented by theManpage.format
type rather than inlined polyvars.
- Add
?envs
optional argument toTerm.info
. Documents environment variables that influence a term's evaluation and automatically integrate them in the manual. - Add
?exits
optional argument toTerm.info
. Documents exit statuses of the program. UseTerm.default_exits
if you are using the newTerm.exit
functions. - Add
?man_xrefs
optional argument toTerm.info
. Documents references to other manpages. Automatically formats aSEE ALSO
section in the manual. - Add
Manpage.escape
to escape a string from the documentation markup language. - Add
Manpage.s_*
constants for standard man page section names. - Add a
`Blocks
case toManpage.blocks
to allow block splicing (#69). This avoids having to concatenate block lists at the toplevel of your program. Arg.env_var
, change default environment variable section to the standardENVIRONMENT
manual section rather thanENVIRONMENT VARIABLES
. If you previously manually positioned that section in your man page you will have to change the name. See also next point.- Fix automatic placement of default environment variable section (#44) whenever unspecified in the man page.
- Better automatic insertions of man page sections (#73). See the API
docs about manual specification. As a side effect the
NAME
section can now also be overriden manually. - Fix repeated environment variable printing for flags (#64). Thanks to Thomas Gazagnaire for the report.
- Fix rendering of env vars in man pages, bold is standard (#71).
- Fix plain help formatting for commands with empty description. Thanks to Maciek Starzyk for the patch.
- Fix (implement really) groff man page escaping (#48).
- Request
an
macros directly in the man page via.mso
this makes man pages self-describing and avoids having to callgroff
with the-man
option. - Document required optional arguments as such (#82). Thanks to Isaac Hodes for the report.
This release tries to bring sanity to the doc language. This may break the rendering of some of your man pages. Thanks to Gabriel Scherer, Ivan Gotovchits and Nicolás Ojeda Bär for the feedback.
- It is only allowed to use the variables
$(var)
that are mentioned in the docs ($(docv)
,$(opt)
, etc.) and the markup directives$({i,b},text)
. Any other unknown$(var)
will generate errors on standard error during documentation generation. - Markup directives
$({i,b},text)
treattext
as is, modulo escapes; see next point. - Characters
$
,(
,)
and\
can respectively be escaped by\$
,\(
,\)
and\\
. Escaping$
and\
is mandatory everywhere. Escaping)
is mandatory only in markup directives. Escaping(
is only here for your symmetric pleasure. Any other sequence of character starting with a\
is an illegal sequence. - Variables
$(mname)
and$(tname)
are now marked up with bold when substituted. If you used to write$(b,$(tname))
this will generate an error on standard output, since$
is not escaped in the markup directive. Simply replace these by$(tname)
.
- Bring back support for OCaml 3.12.0
- Support for pre-formatted paragraphs in man pages. This adds a
```Pre`` case to the
Manpage.block
type which can break existing programs. Thanks to Guillaume Bury for suggesting and help. - Support for environment variables. If an argument is absent from the
command line, its value can be read and parsed from an environment
variable. This adds an
env
optional argument to theArg.info
function which can break existing programs. - Support for new variables in option documentation strings.
$(opt)
can be used to refer to the name of the option being documented and$(env)
for the name of the option's the environment variable. - Deprecate
Term.pure
in favor ofTerm.const
. - Man page generation. Keep undefined variables untouched. Previously
a
$(undef)
would be turned intoundef
. - Turn a few misterious and spurious
Not_found
exceptions intoInvalid_arg
. These can be triggered by client programming errors (e.g. an unclosed variable in a documentation string). - Positional arguments. Invoke the printer on the default (absent) value only if needed. See Optional arguments in the release notes of v0.9.6.
- Build system, don't depend on
ocamlfind
. The package no longer depends on ocamlfind. Thanks to Louis Gesbert for the patch.
- Optional arguments. Invoke the printer on the default (absent) value only if needed, i.e. if help is shown. Strictly speaking an interface breaking change – for example if the absent value was lazy it would be forced on each run. This is no longer the case.
- Parsed command line syntax: allow short flags to be specified
together under a single dash, possibly ending with a short option.
This allows to specify e.g.
tar -xvzf archive.tgz
ortar -xvzfarchive.tgz
. Previously this resulted in an error, all the short flags had to be specified separately. Backward compatible in the sense that only more command lines are parsed. Thanks to Hugo Heuzard for the patch. - End user error message improvements using heuristics and edit distance search in the optional argument and sub command name spaces. Thanks to Hugo Heuzard for the patch.
- Adds
Arg.doc_{quote,alts,alts_enum}
, documentation string helpers. - Adds the
Term.eval_peek_opts
function for advanced usage scenarios. - The function
Arg.enum
now raisesInvalid_argument
if the enumeration is empty. - Improves help paging behaviour on Windows. Thanks to Romain Bardou for the help.
- Add variance annotation to Term.t. Thanks to Peter Zotov for suggesting.
- Fix section name formatting in plain text output. Thanks to Mikhail Sobolev for reporting.
- Remove temporary files created for paged help. Thanks to Kaustuv Chaudhuri for the suggestion.
- Avoid linking against
Oo
(was used to get program uuid). - Check the environment for
$MANPAGER
aswell. Thanks to Raphaël Proust for the patch. - OPAM friendly workflow and drop OASIS support.
- Allow user specified
SYNOPSIS
sections.
- OASIS 0.3.0 support.
- OASIS support.
- Fixed broken
Arg.pos_right
. - Variables
$(tname)
and$(mname)
can be used in a term's man page to respectively refer to the term's name and the main term name. - Support for custom variable substitution in
Manpage.print
. - Adds
Term.man_format
, to facilitate the definition of help commands. - Rewrote the examples with a better and consistent style.
Incompatible API changes:
- The signature of
Term.eval
andTerm.eval_choice
changed to make it more regular: the given term and its info must be tupled together even for the main term and the tuple order was swapped to make it consistent with the one used for arguments.
- First release.