Commit c98ce024 authored by Devon Carew's avatar Devon Carew

print the dartlang atom plugin version from flutter doctor (#4242)

parent be7e00a8
......@@ -245,38 +245,44 @@ class AtomValidator extends DoctorValidator {
bool atomDirExists = FileSystemEntity.isDirectorySync(_getAtomHomePath());
if (!atomDirExists) {
messages.add(new ValidationMessage.error(
'Atom not installed; download at https://atom.io.'
));
messages.add(new ValidationMessage.error('Atom not installed; download at https://atom.io.'));
} else {
installCount++;
if (!_validateHasPackage(messages, 'flutter', 'Flutter'))
installCount++;
if (!_validateHasPackage(messages, 'dartlang', 'Dart'))
installCount++;
}
if (!hasPackage('flutter')) {
messages.add(new ValidationMessage.error(
'Flutter plugin not installed; this adds Flutter specific functionality to Atom.\n'
'Install the \'flutter\' plugin in Atom or run \'apm install flutter\'.'
return new ValidationResult(
installCount == 3
? ValidationType.installed
: installCount == 1 ? ValidationType.partial : ValidationType.missing,
messages
);
}
bool _validateHasPackage(List<ValidationMessage> messages, String packageName, String description) {
if (!hasPackage(packageName)) {
messages.add(new ValidationMessage(
'$packageName plugin not installed; this adds $description specific functionality to Atom.\n'
'Install the plugin from Atom or run \'apm install $packageName\'.'
));
return true;
} else {
installCount++;
try {
String flutterPluginPath = path.join(_getAtomHomePath(), 'packages', 'flutter');
String flutterPluginPath = path.join(_getAtomHomePath(), 'packages', packageName);
File packageFile = new File(path.join(flutterPluginPath, 'package.json'));
dynamic packageInfo = JSON.decode(packageFile.readAsStringSync());
Map<String, dynamic> packageInfo = JSON.decode(packageFile.readAsStringSync());
String version = packageInfo['version'];
messages.add(new ValidationMessage('Atom installed; Flutter plugin version $version'));
messages.add(new ValidationMessage('$packageName plugin version $version'));
} catch (error) {
printTrace('Unable to read flutter plugin version: $error');
printTrace('Unable to read $packageName plugin version: $error');
}
return false;
}
return new ValidationResult(
installCount == 2
? ValidationType.installed
: installCount == 1 ? ValidationType.partial : ValidationType.missing,
messages
);
}
bool hasPackage(String packageName) {
......
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