- Added missing doc, updated a package
- Upgraded packages
- Website changed
- Fixed grammar in the readme file
- Removed
GlobExt
, should usefile_ext
package instead:GlobExt.createGlob()
=>PathExt.toGlob()
- Re-releasing after missing commit done
- New feature:
:?
and::?
allow to pass no value - Added year 2023 to copyright
- Bugfix: prefix should not be passed with the option name to
CliOpt.addValue()
- Breaking: sub-option-first policy. If option
-a
has a sub-option-b
, and there is also another major option-b
, in the following situation-b
will be treated as a sub-option:-a -b -c
. Still-b
will be treated as a major option in-b -a -c
. This allows mixing options with similar sub-options. For instance,|p,plain::>and,not,or,p,plain,r,regex|r,regex::>and,not,or,p,plain,r,regex
allows mixing two kinds of patterns with logical operations
- Bugfix: incorrect parsing of options definition string with spaces
- Added argNo to CliOpt allowing to check the order of options
- Bugfix: '-?' was not recognised as a valid option name
- More docos
- Correction to documentation
- Changed default CliOptCaseMode from lower to smart, added extra documentation and GlobExt extension for Glob
- Removed unused imports
- Complete overhaul (an utterly breaking change): allowing short options bundling and negative options, different case modes, getting values directly (no callbacks), allowing sub-options (treated as plain arguments only, no sub-option values), value separator is built into the option definitions string. Value type was removed from the option definintion, no plus sign in the beginning of the options definition string: no need to perform multiple passes at all.
- Added optional smart bundling (default) - ability to combine short option names
- Breaking: short options are case-sensitive (default), but the long ones are always not
- Moved OptDef's normalize to OptName
- A bugfix for a sub-option of a plain argument
- Added more documentation
- Improved readability of the example
- Breaking: if an option has no value and is followed by a non-option, the latter is treated as a plain argument; if an option has a single value followed by more than one non-options, the first of those is treated as an option value, and the following ones are considered as plain arguments until the next option name comes.
- Added OptPlanArgsException which is thrown when the list of possible options does not admit plain arguments
- Breaking: swapped the meaning of '--' (now: no more option and stop the last option) and '---' (now: no more option, but don't stop the last option). This is much needed for the compatibility with the standard interpretation of '--'
- Fixed minor issues in the example
- Added documentation
- Fixed and enhanced README.md
- Added sub-options (see README.md for more detail)
- Breaking: added ability to append "x3" to the list of values of "-o" in case of -o="x1,x2" "x3" (previously, "x3" was added to the list of plain arguments)
- Upgraded compiler version to 2.17
- Added the project repo to pubspec.yaml
- Changed the project homepage
- The function 'unquote' is moved away from the public access in order to avoid possible clashes with the similar ones in consuming applications.
- New feature: support for -name=value, -name="value", -name='value', -name="value1,value2,...", -name='value1,value2,...'. The next plain argument is not treated as another value of this option in order to avoid the visual confusion.
- Bug fix: not the last option name was passed to the handler.
- A test for the bad value separator usage.
- The ability to pass value separator and to split a single argument coming after the respective option.
- The options definitions string can be multi-line, as all blank characters will get removed.
- Several constants in OptDef made private as being insignificant outside the class.
- Make calls to the user-defined handler in the order of the options appearing in the definitions list.
- Fixed description in pubspec.yaml and README.md.
- Added documentation foer a few constants
- Fixed minor bugs.
- Extended comments and made them uniform (same style)
- Got rid of dart:io dependency in OptException
- Removed unused property OptDef.level
- Fixed minor bugs.
- Made various parts of documentation consistent.
- Renamed OptValueMode to OptValueCountType.
- Added ability to define options to parse as well as to automate options/values validations.
- Added ability to get values pre-converted to one of the known types (binary, decimal, hexadecimal, octal, double-precision float, string).
- Added ability to perform arguments parsing twice (options definition string is parsed once as before). This is useful when you need to know more than one value while parsing. For instance, if the start-in directory and a filename are both options, you can't assign the file path straightaway
- Full compatibility with the older version - just pass the null or empty string.
- Fixed Dart formatting issues.
- Minor fixes in documentation.
- Initial release.