blob: 55e4b77a39fb7a31db5c849ec6d76a8b90a70c0b [file] [log] [blame]
Ian Hickson449f4a62019-11-27 15:04:02 -08001// Copyright 2014 The Flutter Authors. All rights reserved.
Jonah Williamsac36e442019-04-18 18:05:04 -07002// Use of this source code is governed by a BSD-style license that can be
Ian Hickson449f4a62019-11-27 15:04:02 -08003// found in the LICENSE file.
Jonah Williamsac36e442019-04-18 18:05:04 -07004
stuartmorgan5f6f70e2019-05-30 12:45:33 -07005import '../artifacts.dart';
Jonah Williamsac36e442019-04-18 18:05:04 -07006import '../base/common.dart';
Jonah Williamsac36e442019-04-18 18:05:04 -07007import '../base/logger.dart';
Jonah Williams48034282019-10-09 18:58:27 -07008import '../base/process.dart';
Jonah Williamsac36e442019-04-18 18:05:04 -07009import '../build_info.dart';
10import '../cache.dart';
Jonah Williamsee7a37f2020-01-06 11:04:20 -080011import '../globals.dart' as globals;
Jonah Williamsac36e442019-04-18 18:05:04 -070012import '../project.dart';
Zachary Andersonef146f62019-07-29 07:24:02 -070013import '../reporting/reporting.dart';
stuartmorgan6722fb42019-05-14 19:24:40 -040014import 'msbuild_utils.dart';
stuartmorganfb8df822019-06-06 14:02:27 -070015import 'visual_studio.dart';
Jonah Williamsac36e442019-04-18 18:05:04 -070016
stuartmorgan6722fb42019-05-14 19:24:40 -040017/// Builds the Windows project using msbuild.
stuartmorgand6bd1c02019-07-01 14:49:34 -070018Future<void> buildWindows(WindowsProject windowsProject, BuildInfo buildInfo, {String target}) async {
stuartmorgan6722fb42019-05-14 19:24:40 -040019 final Map<String, String> environment = <String, String>{
20 'FLUTTER_ROOT': Cache.flutterRoot,
stuartmorgane6ae95c2019-09-11 07:46:57 -070021 'FLUTTER_EPHEMERAL_DIR': windowsProject.ephemeralDirectory.path,
stuartmorgan4e1bfca2019-05-15 19:32:47 -040022 'PROJECT_DIR': windowsProject.project.directory.path,
23 'TRACK_WIDGET_CREATION': (buildInfo?.trackWidgetCreation == true).toString(),
stuartmorgan6722fb42019-05-14 19:24:40 -040024 };
stuartmorgand6bd1c02019-07-01 14:49:34 -070025 if (target != null) {
26 environment['FLUTTER_TARGET'] = target;
27 }
Jonah Williamsee7a37f2020-01-06 11:04:20 -080028 if (globals.artifacts is LocalEngineArtifacts) {
29 final LocalEngineArtifacts localEngineArtifacts = globals.artifacts as LocalEngineArtifacts;
stuartmorgan5f6f70e2019-05-30 12:45:33 -070030 final String engineOutPath = localEngineArtifacts.engineOutPath;
Jonah Williamsee7a37f2020-01-06 11:04:20 -080031 environment['FLUTTER_ENGINE'] = globals.fs.path.dirname(globals.fs.path.dirname(engineOutPath));
32 environment['LOCAL_ENGINE'] = globals.fs.path.basename(engineOutPath);
stuartmorgan5f6f70e2019-05-30 12:45:33 -070033 }
stuartmorgan6722fb42019-05-14 19:24:40 -040034 writePropertySheet(windowsProject.generatedPropertySheetFile, environment);
35
stuartmorganfb8df822019-06-06 14:02:27 -070036 final String vcvarsScript = visualStudio.vcvarsPath;
stuartmorgan6722fb42019-05-14 19:24:40 -040037 if (vcvarsScript == null) {
stuartmorganfb8df822019-06-06 14:02:27 -070038 throwToolExit('Unable to find suitable Visual Studio toolchain. '
39 'Please run `flutter doctor` for more details.');
stuartmorgan6722fb42019-05-14 19:24:40 -040040 }
41
stuartmorgan01530922019-08-20 20:16:29 -070042 if (!buildInfo.isDebug) {
43 const String warning = '🚧 ';
Jonah Williamsee7a37f2020-01-06 11:04:20 -080044 globals.printStatus(warning * 20);
45 globals.printStatus('Warning: Only debug is currently implemented for Windows. This is effectively a debug build.');
46 globals.printStatus('See https://github.com/flutter/flutter/issues/38477 for details and updates.');
47 globals.printStatus(warning * 20);
48 globals.printStatus('');
stuartmorgan01530922019-08-20 20:16:29 -070049 }
50
Jonah Williamsee7a37f2020-01-06 11:04:20 -080051 final String buildScript = globals.fs.path.join(
stuartmorgane1a784a2019-05-28 21:53:03 -070052 Cache.flutterRoot,
53 'packages',
54 'flutter_tools',
55 'bin',
56 'vs_build.bat',
57 );
58
stuartmorgan6722fb42019-05-14 19:24:40 -040059 final String configuration = buildInfo.isDebug ? 'Debug' : 'Release';
stuartmorgan79ae04d2019-05-29 13:17:23 -070060 final String solutionPath = windowsProject.solutionFile.path;
Zachary Andersonb847ba52019-06-07 13:50:45 -070061 final Stopwatch sw = Stopwatch()..start();
Jonah Williamsee7a37f2020-01-06 11:04:20 -080062 final Status status = globals.logger.startProgress(
Jonah Williamsac36e442019-04-18 18:05:04 -070063 'Building Windows application...',
64 timeout: null,
65 );
66 int result;
67 try {
Jonah Williams48034282019-10-09 18:58:27 -070068 // Run the script with a relative path to the project using the enclosing
69 // directory as the workingDirectory, to avoid hitting the limit on command
70 // lengths in batch scripts if the absolute path to the project is long.
71 result = await processUtils.stream(<String>[
72 buildScript,
73 vcvarsScript,
Jonah Williamsee7a37f2020-01-06 11:04:20 -080074 globals.fs.path.basename(solutionPath),
Jonah Williams48034282019-10-09 18:58:27 -070075 configuration,
Jonah Williamsee7a37f2020-01-06 11:04:20 -080076 ], workingDirectory: globals.fs.path.dirname(solutionPath), trace: true);
Jonah Williamsac36e442019-04-18 18:05:04 -070077 } finally {
78 status.cancel();
79 }
80 if (result != 0) {
GroovinChipced20782019-08-01 13:32:38 -040081 throwToolExit('Build process failed. To view the stack trace, please run `flutter run -d windows -v`.');
Jonah Williamsac36e442019-04-18 18:05:04 -070082 }
Zachary Andersonb847ba52019-06-07 13:50:45 -070083 flutterUsage.sendTiming('build', 'vs_build', Duration(milliseconds: sw.elapsedMilliseconds));
Jonah Williamsac36e442019-04-18 18:05:04 -070084}