Commit aaaf0dac authored by Michael Goderbauer's avatar Michael Goderbauer Committed by GitHub

Teach Flutter Tools about IntelliJ and Android SDK on Windows. (#7622)

Required for https://github.com/flutter/flutter/issues/138
parent e14925d3
...@@ -68,10 +68,13 @@ class AndroidSdk { ...@@ -68,10 +68,13 @@ class AndroidSdk {
androidHomeDir = Platform.environment[kAndroidHome]; androidHomeDir = Platform.environment[kAndroidHome];
} else if (Platform.isLinux) { } else if (Platform.isLinux) {
if (homeDirPath != null) if (homeDirPath != null)
androidHomeDir = '$homeDirPath/Android/Sdk'; androidHomeDir = path.join(homeDirPath, 'Android', 'Sdk');
} else if (Platform.isMacOS) { } else if (Platform.isMacOS) {
if (homeDirPath != null) if (homeDirPath != null)
androidHomeDir = '$homeDirPath/Library/Android/sdk'; androidHomeDir = path.join(homeDirPath, 'Library', 'Android', 'sdk');
} else if (Platform.isWindows) {
if (homeDirPath != null)
androidHomeDir = path.join(homeDirPath, 'AppData', 'Local', 'Android', 'sdk');
} }
if (androidHomeDir != null) { if (androidHomeDir != null) {
...@@ -127,7 +130,7 @@ class AndroidSdk { ...@@ -127,7 +130,7 @@ class AndroidSdk {
} }
String getPlatformToolsPath(String binaryName) { String getPlatformToolsPath(String binaryName) {
return path.join(directory, 'platform-tools', binaryName); return path.join(directory, 'platform-tools', os.getExecutableName(binaryName));
} }
void _init() { void _init() {
...@@ -218,7 +221,7 @@ class AndroidSdkVersion implements Comparable<AndroidSdkVersion> { ...@@ -218,7 +221,7 @@ class AndroidSdkVersion implements Comparable<AndroidSdkVersion> {
String get aaptPath => getBuildToolsPath('aapt'); String get aaptPath => getBuildToolsPath('aapt');
String get dxPath => getBuildToolsPath('dx'); String get dxPath => getBuildToolsPath('dx', winExtension: 'bat');
String get zipalignPath => getBuildToolsPath('zipalign'); String get zipalignPath => getBuildToolsPath('zipalign');
...@@ -239,11 +242,11 @@ class AndroidSdkVersion implements Comparable<AndroidSdkVersion> { ...@@ -239,11 +242,11 @@ class AndroidSdkVersion implements Comparable<AndroidSdkVersion> {
} }
String getPlatformsPath(String itemName) { String getPlatformsPath(String itemName) {
return path.join(sdk.directory, 'platforms', platformVersionName, itemName); return path.join(sdk.directory, 'platforms', platformVersionName, os.getExecutableName(itemName));
} }
String getBuildToolsPath(String binaryName) { String getBuildToolsPath(String binaryName, { String winExtension }) {
return path.join(sdk.directory, 'build-tools', buildToolsVersionName, binaryName); return path.join(sdk.directory, 'build-tools', buildToolsVersionName, os.getExecutableName(binaryName, winExtension: winExtension));
} }
@override @override
......
...@@ -62,6 +62,7 @@ class AndroidWorkflow extends DoctorValidator implements Workflow { ...@@ -62,6 +62,7 @@ class AndroidWorkflow extends DoctorValidator implements Workflow {
} }
List<String> validationResult = androidSdk.validateSdkWellFormed(); List<String> validationResult = androidSdk.validateSdkWellFormed();
// Empty result means SDK is well formated.
if (validationResult.isEmpty) { if (validationResult.isEmpty) {
const String _kJdkDownload = 'https://www.oracle.com/technetwork/java/javase/downloads/'; const String _kJdkDownload = 'https://www.oracle.com/technetwork/java/javase/downloads/';
...@@ -93,7 +94,7 @@ class AndroidWorkflow extends DoctorValidator implements Workflow { ...@@ -93,7 +94,7 @@ class AndroidWorkflow extends DoctorValidator implements Workflow {
} }
} else { } else {
messages.add(new ValidationMessage.error( messages.add(new ValidationMessage.error(
'No Java SDK found; you can download Java from $_kJdkDownload.' 'No Java Development Kit (JDK) found; you can download the JDK from $_kJdkDownload.'
)); ));
} }
} else { } else {
......
...@@ -44,6 +44,13 @@ abstract class OperatingSystemUtils { ...@@ -44,6 +44,13 @@ abstract class OperatingSystemUtils {
File makePipe(String path); File makePipe(String path);
void unzip(File file, Directory targetDirectory); void unzip(File file, Directory targetDirectory);
/// Returns the name of the [binaryName] executable.
///
/// No-op on most OS.
/// On Windows it returns [binaryName].[winExtension], if [winExtension] is
/// specified, or [binaryName].exe otherwise.
String getExecutableName(String binaryName, { String winExtension });
} }
class _PosixUtils extends OperatingSystemUtils { class _PosixUtils extends OperatingSystemUtils {
...@@ -76,6 +83,9 @@ class _PosixUtils extends OperatingSystemUtils { ...@@ -76,6 +83,9 @@ class _PosixUtils extends OperatingSystemUtils {
runSync(<String>['mkfifo', path]); runSync(<String>['mkfifo', path]);
return fs.file(path); return fs.file(path);
} }
@override
String getExecutableName(String binaryName, { String winExtension }) => binaryName;
} }
class _WindowsUtils extends OperatingSystemUtils { class _WindowsUtils extends OperatingSystemUtils {
...@@ -115,6 +125,14 @@ class _WindowsUtils extends OperatingSystemUtils { ...@@ -115,6 +125,14 @@ class _WindowsUtils extends OperatingSystemUtils {
File makePipe(String path) { File makePipe(String path) {
throw new UnsupportedError('makePipe is not implemented on Windows.'); throw new UnsupportedError('makePipe is not implemented on Windows.');
} }
@override
String getExecutableName(String binaryName, { String winExtension }) {
winExtension ??= 'exe';
if (path.extension(binaryName).isEmpty && winExtension.isNotEmpty)
return '$binaryName.$winExtension';
return binaryName;
}
} }
Future<int> findAvailablePort() async { Future<int> findAvailablePort() async {
......
...@@ -254,11 +254,10 @@ abstract class IntelliJValidator extends DoctorValidator { ...@@ -254,11 +254,10 @@ abstract class IntelliJValidator extends DoctorValidator {
}; };
static Iterable<DoctorValidator> get installedValidators { static Iterable<DoctorValidator> get installedValidators {
if (Platform.isLinux) if (Platform.isLinux || Platform.isWindows)
return IntelliJValidatorOnLinux.installed; return IntelliJValidatorOnLinuxAndWindows.installed;
if (Platform.isMacOS) if (Platform.isMacOS)
return IntelliJValidatorOnMac.installed; return IntelliJValidatorOnMac.installed;
// TODO(danrubel): add support for Windows
return <DoctorValidator>[]; return <DoctorValidator>[];
} }
...@@ -328,8 +327,8 @@ abstract class IntelliJValidator extends DoctorValidator { ...@@ -328,8 +327,8 @@ abstract class IntelliJValidator extends DoctorValidator {
} }
} }
class IntelliJValidatorOnLinux extends IntelliJValidator { class IntelliJValidatorOnLinuxAndWindows extends IntelliJValidator {
IntelliJValidatorOnLinux(String title, this.version, this.installPath, this.pluginsPath) : super(title); IntelliJValidatorOnLinuxAndWindows(String title, this.version, this.installPath, this.pluginsPath) : super(title);
@override @override
String version; String version;
...@@ -344,11 +343,11 @@ class IntelliJValidatorOnLinux extends IntelliJValidator { ...@@ -344,11 +343,11 @@ class IntelliJValidatorOnLinux extends IntelliJValidator {
if (homeDirPath == null) return validators; if (homeDirPath == null) return validators;
void addValidator(String title, String version, String installPath, String pluginsPath) { void addValidator(String title, String version, String installPath, String pluginsPath) {
IntelliJValidatorOnLinux validator = IntelliJValidatorOnLinuxAndWindows validator =
new IntelliJValidatorOnLinux(title, version, installPath, pluginsPath); new IntelliJValidatorOnLinuxAndWindows(title, version, installPath, pluginsPath);
for (int index = 0; index < validators.length; ++index) { for (int index = 0; index < validators.length; ++index) {
DoctorValidator other = validators[index]; DoctorValidator other = validators[index];
if (other is IntelliJValidatorOnLinux && validator.installPath == other.installPath) { if (other is IntelliJValidatorOnLinuxAndWindows && validator.installPath == other.installPath) {
if (validator.version.compareTo(other.version) > 0) if (validator.version.compareTo(other.version) > 0)
validators[index] = validator; validators[index] = validator;
return; return;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment