// 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 'dart:io'; 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:'); Completer<int> exitCompleter = new Completer<int>(); // Start reading. StreamSubscription<String> subscription = logReader.logLines.listen( printStatus, onDone: () { exitCompleter.complete(0); }, onError: (dynamic error) { exitCompleter.complete(error is int ? error : 1); } ); // When terminating, close down the log reader. ProcessSignal.SIGINT.watch().listen((ProcessSignal signal) { subscription.cancel(); printStatus(''); exitCompleter.complete(0); }); ProcessSignal.SIGTERM.watch().listen((ProcessSignal signal) { subscription.cancel(); exitCompleter.complete(0); }); // Wait for the log reader to be finished. int result = await exitCompleter.future; subscription.cancel(); if (result != 0) printError('Error listening to $logReader logs.'); return result; } }