| Index: pkg/args/lib/args.dart
|
| diff --git a/pkg/args/lib/args.dart b/pkg/args/lib/args.dart
|
| index bdd61a58ac782518b1d7a75789b5fea2619c7bde..7ae515d98ee00fe254db4d7ed150862a2544bc7b 100644
|
| --- a/pkg/args/lib/args.dart
|
| +++ b/pkg/args/lib/args.dart
|
| @@ -2,263 +2,6 @@
|
| // for details. All rights reserved. Use of this source code is governed by a
|
| // BSD-style license that can be found in the LICENSE file.
|
|
|
| -/**
|
| - * Parser support for transforming raw command-line arguments into a set
|
| - * of options and values.
|
| - *
|
| - * This library supports [GNU][] and [POSIX][] style options, and it works
|
| - * in both server-side and client-side apps.
|
| - *
|
| - * For information on installing this library, see the
|
| - * [args package on pub.dartlang.org](http://pub.dartlang.org/packages/args).
|
| - * Here's an example of importing this library:
|
| - *
|
| - * import 'package:args/args.dart';
|
| - *
|
| - * ## Defining options
|
| - *
|
| - * To use this library, first create an [ArgParser]:
|
| - *
|
| - * var parser = new ArgParser();
|
| - *
|
| - * Then define a set of options on that parser using [addOption()] and
|
| - * [addFlag()]. Here's the minimal way to create an option named "name":
|
| - *
|
| - * parser.addOption('name');
|
| - *
|
| - * When an option can only be set or unset (as opposed to taking a string
|
| - * value), use a flag:
|
| - *
|
| - * parser.addFlag('name');
|
| - *
|
| - * Flag options, by default, accept a 'no-' prefix to negate the option.
|
| - * You can disable the 'no-' prefix using the `negatable` parameter:
|
| - *
|
| - * parser.addFlag('name', negatable: false);
|
| - *
|
| - * **Terminology note:**
|
| - * From here on out, the term _option_ refers to both regular options and
|
| - * flags. In cases where the distinction matters, this documentation uses
|
| - * the term _non-flag option._
|
| - *
|
| - * Options can have an optional single-character abbreviation, specified
|
| - * with the `abbr` parameter:
|
| - *
|
| - * parser.addOption('mode', abbr: 'm');
|
| - * parser.addFlag('verbose', abbr: 'v');
|
| - *
|
| - * Options can also have a default value, specified with the `defaultsTo`
|
| - * parameter. The default value is used when arguments don't specify the
|
| - * option.
|
| - *
|
| - * parser.addOption('mode', defaultsTo: 'debug');
|
| - * parser.addFlag('verbose', defaultsTo: false);
|
| - *
|
| - * The default value for non-flag options can be any [String]. For flags,
|
| - * it must be a [bool].
|
| - *
|
| - * To validate a non-flag option, you can use the `allowed` parameter to
|
| - * provide an allowed set of values. When you do, the parser throws a
|
| - * [FormatException] if the value for an option is not in the allowed set.
|
| - * Here's an example of specifying allowed values:
|
| - *
|
| - * parser.addOption('mode', allowed: ['debug', 'release']);
|
| - *
|
| - * You can use the `callback` parameter to associate a function with an
|
| - * option. Later, when parsing occurs, the callback function is invoked
|
| - * with the value of the option:
|
| - *
|
| - * parser.addOption('mode', callback: (mode) => print('Got mode $mode));
|
| - * parser.addFlag('verbose', callback: (verbose) {
|
| - * if (verbose) print('Verbose');
|
| - * });
|
| - *
|
| - * The callbacks for all options are called whenever a set of arguments
|
| - * is parsed. If an option isn't provided in the args, its callback is
|
| - * passed the default value, or `null` if no default value is set.
|
| - *
|
| - * ## Parsing arguments
|
| - *
|
| - * Once you have an [ArgParser] set up with some options and flags, you
|
| - * use it by calling [ArgParser.parse()] with a set of arguments:
|
| - *
|
| - * var results = parser.parse(['some', 'command', 'line', 'args']);
|
| - *
|
| - * These arguments usually come from the arguments to main
|
| - * (`main(List<String> arguments`), but you can pass in any list of strings.
|
| - * The parse() method returns an instance of [ArgResults], a map-like
|
| - * object that contains the values of the parsed options.
|
| - *
|
| - * var parser = new ArgParser();
|
| - * parser.addOption('mode');
|
| - * parser.addFlag('verbose', defaultsTo: true);
|
| - * var results = parser.parse(['--mode', 'debug', 'something', 'else']);
|
| - *
|
| - * print(results['mode']); // debug
|
| - * print(results['verbose']); // true
|
| - *
|
| - * By default, the parse() method stops as soon as it reaches `--` by itself
|
| - * or anything that the parser doesn't recognize as an option, flag, or
|
| - * option value. If arguments still remain, they go into [ArgResults.rest].
|
| - *
|
| - * print(results.rest); // ['something', 'else']
|
| - *
|
| - * To continue to parse options found after non-option arguments, call
|
| - * parse() with `allowTrailingOptions: true`.
|
| - *
|
| - * ## Specifying options
|
| - *
|
| - * To actually pass in options and flags on the command line, use GNU or
|
| - * POSIX style. Consider this option:
|
| - *
|
| - * parser.addOption('name', abbr: 'n');
|
| - *
|
| - * You can specify its value on the command line using any of the following:
|
| - *
|
| - * --name=somevalue
|
| - * --name somevalue
|
| - * -nsomevalue
|
| - * -n somevalue
|
| - *
|
| - * Consider this flag:
|
| - *
|
| - * parser.addFlag('name', abbr: 'n');
|
| - *
|
| - * You can set it to true using one of the following:
|
| - *
|
| - * --name
|
| - * -n
|
| - *
|
| - * You can set it to false using the following:
|
| - *
|
| - * --no-name
|
| - *
|
| - * Multiple flag abbreviations can be collapsed into a single argument. Say
|
| - * you define these flags:
|
| - *
|
| - * parser.addFlag('verbose', abbr: 'v');
|
| - * parser.addFlag('french', abbr: 'f');
|
| - * parser.addFlag('iambic-pentameter', abbr: 'i');
|
| - *
|
| - * You can set all three flags at once:
|
| - *
|
| - * -vfi
|
| - *
|
| - * By default, an option has only a single value, with later option values
|
| - * overriding earlier ones; for example:
|
| - *
|
| - * var parser = new ArgParser();
|
| - * parser.addOption('mode');
|
| - * var results = parser.parse(['--mode', 'on', '--mode', 'off']);
|
| - * print(results['mode']); // prints 'off'
|
| - *
|
| - * If you need multiple values, set the `allowMultiple` parameter. In that
|
| - * case the option can occur multiple times, and the parse() method returns
|
| - * a list of values:
|
| - *
|
| - * var parser = new ArgParser();
|
| - * parser.addOption('mode', allowMultiple: true);
|
| - * var results = parser.parse(['--mode', 'on', '--mode', 'off']);
|
| - * print(results['mode']); // prints '[on, off]'
|
| - *
|
| - * ## Defining commands ##
|
| - *
|
| - * In addition to *options*, you can also define *commands*. A command is
|
| - * a named argument that has its own set of options. For example, consider
|
| - * this shell command:
|
| - *
|
| - * $ git commit -a
|
| - *
|
| - * The executable is `git`, the command is `commit`, and the `-a` option is
|
| - * an option passed to the command. You can add a command using the
|
| - * [addCommand] method:
|
| - *
|
| - * var parser = new ArgParser();
|
| - * var command = parser.addCommand('commit');
|
| - *
|
| - * The addCommand() method returns another [ArgParser], which you can then
|
| - * use to define options specific to that command. If you already have an
|
| - * [ArgParser] for the command's options, you can pass it to addCommand:
|
| - *
|
| - * var parser = new ArgParser();
|
| - * var command = new ArgParser();
|
| - * parser.addCommand('commit', command);
|
| - *
|
| - * The [ArgParser] for a command can then define options or flags:
|
| - *
|
| - * command.addFlag('all', abbr: 'a');
|
| - *
|
| - * You can add multiple commands to the same parser so that a user can select
|
| - * one from a range of possible commands. When parsing an argument list,
|
| - * you can then determine which command was entered and what options were
|
| - * provided for it.
|
| - *
|
| - * var results = parser.parse(['commit', '-a']);
|
| - * print(results.command.name); // "commit"
|
| - * print(results.command['all']); // true
|
| - *
|
| - * Options for a command must appear after the command in the argument list.
|
| - * For example, given the above parser, "git -a commit" is *not* valid. The
|
| - * parser tries to find the right-most command that accepts an option. For
|
| - * example:
|
| - *
|
| - * var parser = new ArgParser();
|
| - * parser.addFlag('all', abbr: 'a');
|
| - * var command = parser.addCommand('commit');
|
| - * command.addFlag('all', abbr: 'a');
|
| - *
|
| - * var results = parser.parse(['commit', '-a']);
|
| - * print(results.command['all']); // true
|
| - *
|
| - * Here, both the top-level parser and the "commit" command can accept a
|
| - * "-a" (which is probably a bad command line interface, admittedly). In
|
| - * that case, when "-a" appears after "commit", it is applied to that
|
| - * command. If it appears to the left of "commit", it is given to the
|
| - * top-level parser.
|
| - *
|
| - * ## Displaying usage
|
| - *
|
| - * You can automatically generate nice help text, suitable for use as the
|
| - * output of `--help`. To display good usage information, you should
|
| - * provide some help text when you create your options.
|
| - *
|
| - * To define help text for an entire option, use the `help` parameter:
|
| - *
|
| - * parser.addOption('mode', help: 'The compiler configuration',
|
| - * allowed: ['debug', 'release']);
|
| - * parser.addFlag('verbose', help: 'Show additional diagnostic info');
|
| - *
|
| - * For non-flag options, you can also provide detailed help for each expected
|
| - * value by using the `allowedHelp` parameter:
|
| - *
|
| - * parser.addOption('arch', help: 'The architecture to compile for',
|
| - * allowedHelp: {
|
| - * 'ia32': 'Intel x86',
|
| - * 'arm': 'ARM Holding 32-bit chip'
|
| - * });
|
| - *
|
| - * To display the help, use the ArgParser getUsage() method:
|
| - *
|
| - * print(parser.getUsage());
|
| - *
|
| - * The resulting string looks something like this:
|
| - *
|
| - * --mode The compiler configuration
|
| - * [debug, release]
|
| - *
|
| - * --[no-]verbose Show additional diagnostic info
|
| - * --arch The architecture to compile for
|
| - *
|
| - * [arm] ARM Holding 32-bit chip
|
| - * [ia32] Intel x86
|
| - *
|
| - * To assist the formatting of the usage help, single-line help text is
|
| - * followed by a single new line. Options with multi-line help text are
|
| - * followed by two new lines. This provides spatial diversity between options.
|
| - *
|
| - * [posix]: http://pubs.opengroup.org/onlinepubs/009695399/basedefs/xbd_chap12.html#tag_12_02
|
| - * [gnu]: http://www.gnu.org/prep/standards/standards.html#Command_002dLine-Interfaces
|
| - */
|
| library args;
|
|
|
| import 'package:collection/wrappers.dart';
|
| @@ -268,38 +11,28 @@ import 'src/usage.dart';
|
| import 'src/options.dart';
|
| export 'src/options.dart';
|
|
|
| -/**
|
| - * A class for taking a list of raw command line arguments and parsing out
|
| - * options and flags from them.
|
| - */
|
| +/// A class for taking a list of raw command line arguments and parsing out
|
| +/// options and flags from them.
|
| class ArgParser {
|
| final Map<String, Option> _options;
|
| final Map<String, ArgParser> _commands;
|
|
|
| - /**
|
| - * The options that have been defined for this parser.
|
| - */
|
| + /// The options that have been defined for this parser.
|
| final Map<String, Option> options;
|
|
|
| - /**
|
| - * The commands that have been defined for this parser.
|
| - */
|
| + /// The commands that have been defined for this parser.
|
| final Map<String, ArgParser> commands;
|
|
|
| - /**
|
| - * Whether or not this parser parses options that appear after non-option
|
| - * arguments.
|
| - */
|
| + /// Whether or not this parser parses options that appear after non-option
|
| + /// arguments.
|
| final bool allowTrailingOptions;
|
|
|
| - /**
|
| - * Creates a new ArgParser.
|
| - *
|
| - * If [allowTrailingOptions] is set, the parser will continue parsing even
|
| - * after it finds an argument that is neither an option nor a command.
|
| - * This allows options to be specified after regular arguments. Defaults to
|
| - * `false`.
|
| - */
|
| + /// Creates a new ArgParser.
|
| + ///
|
| + /// If [allowTrailingOptions] is set, the parser will continue parsing even
|
| + /// after it finds an argument that is neither an option nor a command.
|
| + /// This allows options to be specified after regular arguments. Defaults to
|
| + /// `false`.
|
| factory ArgParser({bool allowTrailingOptions}) =>
|
| new ArgParser._(<String, Option>{}, <String, ArgParser>{},
|
| allowTrailingOptions: allowTrailingOptions);
|
| @@ -313,13 +46,11 @@ class ArgParser {
|
| this.allowTrailingOptions = allowTrailingOptions != null ?
|
| allowTrailingOptions : false;
|
|
|
| - /**
|
| - * Defines a command.
|
| - *
|
| - * A command is a named argument which may in turn define its own options and
|
| - * subcommands using the given parser. If [parser] is omitted, implicitly
|
| - * creates a new one. Returns the parser for the command.
|
| - */
|
| + /// Defines a command.
|
| + ///
|
| + /// A command is a named argument which may in turn define its own options and
|
| + /// subcommands using the given parser. If [parser] is omitted, implicitly
|
| + /// creates a new one. Returns the parser for the command.
|
| ArgParser addCommand(String name, [ArgParser parser]) {
|
| // Make sure the name isn't in use.
|
| if (_commands.containsKey(name)) {
|
| @@ -331,24 +62,20 @@ class ArgParser {
|
| return parser;
|
| }
|
|
|
| - /**
|
| - * Defines a flag. Throws an [ArgumentError] if:
|
| - *
|
| - * * There is already an option named [name].
|
| - * * There is already an option using abbreviation [abbr].
|
| - */
|
| + /// Defines a flag. Throws an [ArgumentError] if:
|
| + ///
|
| + /// * There is already an option named [name].
|
| + /// * There is already an option using abbreviation [abbr].
|
| void addFlag(String name, {String abbr, String help, bool defaultsTo: false,
|
| bool negatable: true, void callback(bool value), bool hide: false}) {
|
| _addOption(name, abbr, help, null, null, defaultsTo, callback,
|
| isFlag: true, negatable: negatable, hide: hide);
|
| }
|
|
|
| - /**
|
| - * Defines a value-taking option. Throws an [ArgumentError] if:
|
| - *
|
| - * * There is already an option with name [name].
|
| - * * There is already an option using abbreviation [abbr].
|
| - */
|
| + /// Defines a value-taking option. Throws an [ArgumentError] if:
|
| + ///
|
| + /// * There is already an option with name [name].
|
| + /// * There is already an option using abbreviation [abbr].
|
| void addOption(String name, {String abbr, String help, List<String> allowed,
|
| Map<String, String> allowedHelp, String defaultsTo,
|
| void callback(value), bool allowMultiple: false, bool hide: false}) {
|
| @@ -380,23 +107,17 @@ class ArgParser {
|
| allowMultiple: allowMultiple, hide: hide);
|
| }
|
|
|
| - /**
|
| - * Parses [args], a list of command-line arguments, matches them against the
|
| - * flags and options defined by this parser, and returns the result.
|
| - */
|
| + /// Parses [args], a list of command-line arguments, matches them against the
|
| + /// flags and options defined by this parser, and returns the result.
|
| ArgResults parse(List<String> args) =>
|
| new Parser(null, this, args.toList(), null, null).parse();
|
|
|
| - /**
|
| - * Generates a string displaying usage information for the defined options.
|
| - * This is basically the help text shown on the command line.
|
| - */
|
| + /// Generates a string displaying usage information for the defined options.
|
| + /// This is basically the help text shown on the command line.
|
| String getUsage() => new Usage(this).generate();
|
|
|
| - /**
|
| - * Get the default value for an option. Useful after parsing to test
|
| - * if the user specified something other than the default.
|
| - */
|
| + /// Get the default value for an option. Useful after parsing to test if the
|
| + /// user specified something other than the default.
|
| getDefault(String option) {
|
| if (!options.containsKey(option)) {
|
| throw new ArgumentError('No option named $option');
|
| @@ -404,48 +125,38 @@ class ArgParser {
|
| return options[option].defaultValue;
|
| }
|
|
|
| - /**
|
| - * Finds the option whose abbreviation is [abbr], or `null` if no option has
|
| - * that abbreviation.
|
| - */
|
| + /// Finds the option whose abbreviation is [abbr], or `null` if no option has
|
| + /// that abbreviation.
|
| Option findByAbbreviation(String abbr) {
|
| return options.values.firstWhere((option) => option.abbreviation == abbr,
|
| orElse: () => null);
|
| }
|
| }
|
|
|
| -/**
|
| - * The results of parsing a series of command line arguments using
|
| - * [ArgParser.parse()]. Includes the parsed options and any remaining unparsed
|
| - * command line arguments.
|
| - */
|
| +/// The results of parsing a series of command line arguments using
|
| +/// [ArgParser.parse()]. Includes the parsed options and any remaining unparsed
|
| +/// command line arguments.
|
| class ArgResults {
|
| final Map<String, dynamic> _options;
|
|
|
| - /**
|
| - * If these are the results for parsing a command's options, this will be
|
| - * the name of the command. For top-level results, this returns `null`.
|
| - */
|
| + /// If these are the results for parsing a command's options, this will be the
|
| + /// name of the command. For top-level results, this returns `null`.
|
| final String name;
|
|
|
| - /**
|
| - * The command that was selected, or `null` if none was. This will contain
|
| - * the options that were selected for that command.
|
| - */
|
| + /// The command that was selected, or `null` if none was. This will contain
|
| + /// the options that were selected for that command.
|
| final ArgResults command;
|
|
|
| - /**
|
| - * The remaining command-line arguments that were not parsed as options or
|
| - * flags. If `--` was used to separate the options from the remaining
|
| - * arguments, it will not be included in this list.
|
| - */
|
| + /// The remaining command-line arguments that were not parsed as options or
|
| + /// flags. If `--` was used to separate the options from the remaining
|
| + /// arguments, it will not be included in this list.
|
| final List<String> rest;
|
|
|
| - /** Creates a new [ArgResults]. */
|
| + /// Creates a new [ArgResults].
|
| ArgResults(this._options, this.name, this.command, List<String> rest)
|
| : this.rest = new UnmodifiableListView(rest);
|
|
|
| - /** Gets the parsed command-line option named [name]. */
|
| + /// Gets the parsed command-line option named [name].
|
| operator [](String name) {
|
| if (!_options.containsKey(name)) {
|
| throw new ArgumentError(
|
| @@ -455,7 +166,7 @@ class ArgResults {
|
| return _options[name];
|
| }
|
|
|
| - /** Get the names of the options as an [Iterable]. */
|
| + /// Get the names of the options as an [Iterable].
|
| Iterable<String> get options => _options.keys;
|
| }
|
|
|
|
|