// Copyright 2015 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 '../device.dart'; import '../globals.dart'; import '../runner/flutter_command.dart'; class LogsCommand extends FlutterCommand { LogsCommand() { argParser.addFlag('clear', negatable: false, abbr: 'c', help: 'Clear log history before reading from logs.' ); } @override final String name = 'logs'; @override final String description = 'Show log output for running Flutter apps.'; @override bool get requiresProjectRoot => false; @override bool get requiresDevice => true; @override Future<int> runInProject() async { Device device = deviceForCommand; if (argResults['clear']) device.clearLogs(); DeviceLogReader logReader = device.logReader; printStatus('Showing $logReader logs:'); // Start reading. if (!logReader.isReading) await logReader.start(); StreamSubscription<String> subscription = logReader.lines.listen(printStatus); // Wait for the log reader to be finished. int result = await logReader.finished; subscription.cancel(); if (result != 0) printError('Error listening to $logReader logs.'); return result; } }