// Copyright 2018 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 'dart:async'; import '../base/common.dart'; import '../build_info.dart'; import '../bundle.dart'; import '../runner/flutter_command.dart' show FlutterOptions, FlutterCommandResult; import 'build.dart'; class BuildBundleCommand extends BuildSubCommand { BuildBundleCommand({bool verboseHelp = false}) { usesTargetOption(); usesFilesystemOptions(hide: !verboseHelp); addBuildModeFlags(); argParser ..addFlag('precompiled', negatable: false) // This option is still referenced by the iOS build scripts. We should // remove it once we've updated those build scripts. ..addOption('asset-base', help: 'Ignored. Will be removed.', hide: !verboseHelp) ..addOption('manifest', defaultsTo: defaultManifestPath) ..addOption('private-key', defaultsTo: defaultPrivateKeyPath) ..addOption('depfile', defaultsTo: defaultDepfilePath) ..addOption('kernel-file', defaultsTo: defaultApplicationKernelPath) ..addOption('target-platform', defaultsTo: 'android-arm', allowed: <String>['android-arm', 'android-arm64', 'ios'] ) ..addFlag('track-widget-creation', hide: !verboseHelp, help: 'Track widget creation locations. Requires Dart 2.0 functionality.', ) ..addOption('precompile', hide: !verboseHelp, help: 'Precompile functions specified in input file. This flag is only ' 'allowed when using --dynamic. It takes a Dart compilation trace ' 'file produced by the training run of the application. With this ' 'flag, instead of using default Dart VM snapshot provided by the ' 'engine, the application will use its own snapshot that includes ' 'additional compiled functions.' ) ..addFlag('hotupdate', hide: !verboseHelp, help: 'Build differential snapshot based on the last state of the build ' 'tree and any changes to the application source code since then. ' 'This flag is only allowed when using --dynamic. With this flag, ' 'a partial VM snapshot is generated that is loaded on top of the ' 'original VM snapshot that contains precompiled code.' ) ..addMultiOption(FlutterOptions.kExtraFrontEndOptions, splitCommas: true, hide: true, ) ..addMultiOption(FlutterOptions.kExtraGenSnapshotOptions, splitCommas: true, hide: true, ) ..addOption('asset-dir', defaultsTo: getAssetBuildDirectory()) ..addFlag('report-licensed-packages', help: 'Whether to report the names of all the packages that are included ' 'in the application\'s LICENSE file.', defaultsTo: false); usesPubOption(); } @override final String name = 'bundle'; @override final String description = 'Build the Flutter assets directory from your app.'; @override final String usageFooter = 'The Flutter assets directory contains your ' 'application code and resources; they are used by some Flutter Android and' ' iOS runtimes.'; @override Future<FlutterCommandResult> runCommand() async { await super.runCommand(); final String targetPlatform = argResults['target-platform']; final TargetPlatform platform = getTargetPlatformForName(targetPlatform); if (platform == null) throwToolExit('Unknown platform: $targetPlatform'); final BuildMode buildMode = getBuildMode(); await build( platform: platform, buildMode: buildMode, mainPath: targetFile, manifestPath: argResults['manifest'], applicationKernelFilePath: argResults['kernel-file'], depfilePath: argResults['depfile'], privateKeyPath: argResults['private-key'], assetDirPath: argResults['asset-dir'], precompiledSnapshot: argResults['precompiled'], reportLicensedPackages: argResults['report-licensed-packages'], trackWidgetCreation: argResults['track-widget-creation'], compilationTraceFilePath: argResults['precompile'], buildHotUpdate: argResults['hotupdate'], extraFrontEndOptions: argResults[FlutterOptions.kExtraFrontEndOptions], extraGenSnapshotOptions: argResults[FlutterOptions.kExtraGenSnapshotOptions], fileSystemScheme: argResults['filesystem-scheme'], fileSystemRoots: argResults['filesystem-root'], ); return null; } }