stdio.dart 1.77 KB
Newer Older
1 2 3 4
// Copyright 2014 The Flutter Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

5
import 'dart:io' as io;
6 7 8 9

import 'package:meta/meta.dart';

abstract class Stdio {
10 11
  final List<String> logs = <String>[];

12
  /// Error/warning messages printed to STDERR.
13 14 15 16
  @mustCallSuper
  void printError(String message) {
    logs.add('[error] $message');
  }
17 18

  /// Ordinary STDOUT messages.
19 20 21 22
  @mustCallSuper
  void printStatus(String message) {
    logs.add('[status] $message');
  }
23 24

  /// Debug messages that are only printed in verbose mode.
25 26 27 28
  @mustCallSuper
  void printTrace(String message) {
    logs.add('[trace] $message');
  }
29 30

  /// Write string to STDOUT without trailing newline.
31 32 33 34
  @mustCallSuper
  void write(String message) {
    logs.add('[write] $message');
  }
35 36 37 38 39 40 41 42

  /// Read a line of text from STDIN.
  String readLineSync();
}

/// A logger that will print out trace messages.
class VerboseStdio extends Stdio {
  VerboseStdio({
43 44 45 46
    required this.stdout,
    required this.stderr,
    required this.stdin,
  });
47

48 49 50 51 52 53 54 55 56
  factory VerboseStdio.local() => VerboseStdio(
    stdout: io.stdout,
    stderr: io.stderr,
    stdin: io.stdin,
  );

  final io.Stdout stdout;
  final io.Stdout stderr;
  final io.Stdin stdin;
57 58 59

  @override
  void printError(String message) {
60
    super.printError(message);
61 62 63 64 65
    stderr.writeln(message);
  }

  @override
  void printStatus(String message) {
66
    super.printStatus(message);
67 68 69 70 71
    stdout.writeln(message);
  }

  @override
  void printTrace(String message) {
72
    super.printTrace(message);
73 74 75 76 77
    stdout.writeln(message);
  }

  @override
  void write(String message) {
78
    super.write(message);
79 80 81 82 83
    stdout.write(message);
  }

  @override
  String readLineSync() {
84
    return stdin.readLineSync()!;
85 86
  }
}