Unverified Commit 3396ec7b authored by Ian Hickson's avatar Ian Hickson Committed by GitHub

Device discovery output cleanup (#131223)

Fixes https://github.com/flutter/flutter/issues/6538
parent 096b7c3c
...@@ -168,48 +168,43 @@ class DevicesCommandOutput { ...@@ -168,48 +168,43 @@ class DevicesCommandOutput {
} }
if (allDevices.isEmpty) { if (allDevices.isEmpty) {
_printNoDevicesDetected(); _logger.printStatus('No authorized devices detected.');
} else { } else {
if (attachedDevices.isNotEmpty) { if (attachedDevices.isNotEmpty) {
_logger.printStatus('${attachedDevices.length} connected ${pluralize('device', attachedDevices.length)}:\n'); _logger.printStatus('Found ${attachedDevices.length} connected ${pluralize('device', attachedDevices.length)}:');
await Device.printDevices(attachedDevices, _logger); await Device.printDevices(attachedDevices, _logger, prefix: ' ');
} }
if (wirelessDevices.isNotEmpty) { if (wirelessDevices.isNotEmpty) {
if (attachedDevices.isNotEmpty) { if (attachedDevices.isNotEmpty) {
_logger.printStatus(''); _logger.printStatus('');
} }
_logger.printStatus('${wirelessDevices.length} wirelessly connected ${pluralize('device', wirelessDevices.length)}:\n'); _logger.printStatus('Found ${wirelessDevices.length} wirelessly connected ${pluralize('device', wirelessDevices.length)}:');
await Device.printDevices(wirelessDevices, _logger); await Device.printDevices(wirelessDevices, _logger, prefix: ' ');
} }
} }
await _printDiagnostics(); await _printDiagnostics(foundAny: allDevices.isNotEmpty);
} }
void _printNoDevicesDetected() { Future<void> _printDiagnostics({ required bool foundAny }) async {
final StringBuffer status = StringBuffer('No devices detected.'); final StringBuffer status = StringBuffer();
status.writeln(); status.writeln();
final List<String> diagnostics = await _deviceManager?.getDeviceDiagnostics() ?? <String>[];
if (diagnostics.isNotEmpty) {
for (final String diagnostic in diagnostics) {
status.writeln(diagnostic);
status.writeln(); status.writeln();
}
}
status.writeln('Run "flutter emulators" to list and start any available device emulators.'); status.writeln('Run "flutter emulators" to list and start any available device emulators.');
status.writeln(); status.writeln();
status.write('If you expected your device to be detected, please run "flutter doctor" to diagnose potential issues. '); status.write('If you expected ${ foundAny ? 'another' : 'a' } device to be detected, please run "flutter doctor" to diagnose potential issues. ');
if (deviceDiscoveryTimeout == null) { if (deviceDiscoveryTimeout == null) {
status.write('You may also try increasing the time to wait for connected devices with the --${FlutterOptions.kDeviceTimeout} flag. '); status.write('You may also try increasing the time to wait for connected devices with the "--${FlutterOptions.kDeviceTimeout}" flag. ');
} }
status.write('Visit https://flutter.dev/setup/ for troubleshooting tips.'); status.write('Visit https://flutter.dev/setup/ for troubleshooting tips.');
_logger.printStatus(status.toString()); _logger.printStatus(status.toString());
} }
Future<void> _printDiagnostics() async {
final List<String> diagnostics = await _deviceManager?.getDeviceDiagnostics() ?? <String>[];
if (diagnostics.isNotEmpty) {
_logger.printStatus('');
for (final String diagnostic in diagnostics) {
_logger.printStatus('• $diagnostic', hangingIndent: 2);
}
}
}
Future<void> printDevicesAsJson(List<Device> devices) async { Future<void> printDevicesAsJson(List<Device> devices) async {
_logger.printStatus( _logger.printStatus(
const JsonEncoder.withIndent(' ').convert( const JsonEncoder.withIndent(' ').convert(
...@@ -266,8 +261,8 @@ class DevicesCommandOutputWithExtendedWirelessDeviceDiscovery extends DevicesCom ...@@ -266,8 +261,8 @@ class DevicesCommandOutputWithExtendedWirelessDeviceDiscovery extends DevicesCom
// Display list of attached devices. // Display list of attached devices.
if (attachedDevices.isNotEmpty) { if (attachedDevices.isNotEmpty) {
_logger.printStatus('${attachedDevices.length} connected ${pluralize('device', attachedDevices.length)}:\n'); _logger.printStatus('Found ${attachedDevices.length} connected ${pluralize('device', attachedDevices.length)}:');
await Device.printDevices(attachedDevices, _logger); await Device.printDevices(attachedDevices, _logger, prefix: ' ');
_logger.printStatus(''); _logger.printStatus('');
numLinesToClear += 1; numLinesToClear += 1;
} }
...@@ -292,8 +287,8 @@ class DevicesCommandOutputWithExtendedWirelessDeviceDiscovery extends DevicesCom ...@@ -292,8 +287,8 @@ class DevicesCommandOutputWithExtendedWirelessDeviceDiscovery extends DevicesCom
if (_logger.isVerbose && _includeAttachedDevices) { if (_logger.isVerbose && _includeAttachedDevices) {
// Reprint the attach devices. // Reprint the attach devices.
if (attachedDevices.isNotEmpty) { if (attachedDevices.isNotEmpty) {
_logger.printStatus('\n${attachedDevices.length} connected ${pluralize('device', attachedDevices.length)}:\n'); _logger.printStatus('\nFound ${attachedDevices.length} connected ${pluralize('device', attachedDevices.length)}:');
await Device.printDevices(attachedDevices, _logger); await Device.printDevices(attachedDevices, _logger, prefix: ' ');
} }
} else if (terminal.supportsColor && terminal is AnsiTerminal) { } else if (terminal.supportsColor && terminal is AnsiTerminal) {
_logger.printStatus( _logger.printStatus(
...@@ -309,16 +304,16 @@ class DevicesCommandOutputWithExtendedWirelessDeviceDiscovery extends DevicesCom ...@@ -309,16 +304,16 @@ class DevicesCommandOutputWithExtendedWirelessDeviceDiscovery extends DevicesCom
if (wirelessDevices.isEmpty) { if (wirelessDevices.isEmpty) {
if (attachedDevices.isEmpty) { if (attachedDevices.isEmpty) {
// No wireless or attached devices were found. // No wireless or attached devices were found.
_printNoDevicesDetected(); _logger.printStatus('No authorized devices detected.');
} else { } else {
// Attached devices found, wireless devices not found. // Attached devices found, wireless devices not found.
_logger.printStatus(_noWirelessDevicesFoundMessage); _logger.printStatus(_noWirelessDevicesFoundMessage);
} }
} else { } else {
// Display list of wireless devices. // Display list of wireless devices.
_logger.printStatus('${wirelessDevices.length} wirelessly connected ${pluralize('device', wirelessDevices.length)}:\n'); _logger.printStatus('Found ${wirelessDevices.length} wirelessly connected ${pluralize('device', wirelessDevices.length)}:');
await Device.printDevices(wirelessDevices, _logger); await Device.printDevices(wirelessDevices, _logger, prefix: ' ');
} }
await _printDiagnostics(); await _printDiagnostics(foundAny: wirelessDevices.isNotEmpty || attachedDevices.isNotEmpty);
} }
} }
...@@ -849,8 +849,10 @@ abstract class Device { ...@@ -849,8 +849,10 @@ abstract class Device {
]; ];
} }
static Future<void> printDevices(List<Device> devices, Logger logger) async { static Future<void> printDevices(List<Device> devices, Logger logger, { String prefix = '' }) async {
(await descriptions(devices)).forEach(logger.printStatus); for (final String line in await descriptions(devices)) {
logger.printStatus('$prefix$line');
}
} }
static List<String> devicesPlatformTypes(List<Device> devices) { static List<String> devicesPlatformTypes(List<Device> devices) {
......
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