blob: 81442a9265fbc0c35d49ff7395ccf353d61e6283 [file] [log] [blame]
// Copyright 2017 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
import 'package:args/args.dart';
import 'context.dart';
/// command-line flags and options that were specified during the invocation of
/// the Flutter tool.
Flags get flags => context[Flags];
/// Encapsulation of the command-line flags and options that were specified
/// during the invocation of the Flutter tool.
///
/// An instance of this class is set into the [AppContext] upon invocation of
/// the Flutter tool (immediately after the arguments have been parsed in
/// [FlutterCommandRunner]) and is available via the [flags] global property.
class Flags {
Flags(this._globalResults)
: assert(_globalResults != null);
final ArgResults _globalResults;
/// Gets the value of the specified command-line flag/option that was set
/// during the invocation of the Flutter tool.
///
/// This will first search for flags that are specific to the command and will
/// fall back to global flags.
///
/// If a flag has a default value and the user did not explicitly specify a
/// value on the command-line, this will return the default value.
///
/// If the specified flag is not defined or was not specified and had no
/// default, then this will return `null`.
dynamic operator [](String key) {
final ArgResults commandResults = _globalResults.command;
final Iterable<String> options = commandResults?.options;
if (options != null && options.contains(key))
return commandResults[key];
else if (_globalResults.options.contains(key))
return _globalResults[key];
return null;
}
/// `true` iff the given flag/option was either explicitly specified by the
/// user at the command-line or it was defined to have a default value.
bool contains(String key) {
final ArgResults commandResults = _globalResults.command;
final Iterable<String> options = commandResults?.options;
return (options != null && options.contains(key)) || _globalResults.options.contains(key);
}
}
class EmptyFlags implements Flags {
const EmptyFlags();
@override
ArgResults get _globalResults => null;
@override
String operator [](String key) => null;
@override
bool contains(String key) => false;
}