forked from simc/logger
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathprefix_printer.dart
43 lines (38 loc) · 1.31 KB
/
prefix_printer.dart
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
import 'package:logger/src/logger.dart';
import 'package:logger/src/log_printer.dart';
/// A decorator for a [LogPrinter] that allows for the prepending of every
/// line in the log output with a string for the level of that log. For
/// example:
///
/// ```
/// PrefixPrinter(PrettyPrinter());
/// ```
///
/// Would prepend "DEBUG" to every line in a debug log. You can supply
/// parameters for a custom message for a specific log level.
class PrefixPrinter extends LogPrinter {
final LogPrinter _realPrinter;
late Map<Level, String> _prefixMap;
PrefixPrinter(this._realPrinter,
{debug, verbose, wtf, info, warning, error}) {
_prefixMap = {
Level.debug: debug ?? 'DEBUG',
Level.verbose: verbose ?? 'VERBOSE',
Level.wtf: wtf ?? 'WTF',
Level.info: info ?? 'INFO',
Level.warning: warning ?? 'WARNING',
Level.error: error ?? 'ERROR',
};
var len = _longestPrefixLength();
_prefixMap.forEach((k, v) => _prefixMap[k] = '${v.padLeft(len)} ');
}
@override
List<String> log(LogEvent event) {
var realLogs = _realPrinter.log(event);
return realLogs.map((s) => '${_prefixMap[event.level]}$s').toList();
}
int _longestPrefixLength() {
var compFunc = (String a, String b) => a.length > b.length ? a : b;
return _prefixMap.values.reduce(compFunc).length;
}
}