Skip to content
Merged
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
33 changes: 5 additions & 28 deletions build_runner/lib/src/logging/std_io_logging.dart
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,7 @@ StringBuffer colorLog(LogRecord record, {bool verbose}) {
final level = color.wrap('[${record.level}]');
final eraseLine = ansiOutputEnabled && !verbose ? '\x1b[2K\r' : '';
var lines = <Object>[
'$eraseLine$level ${_loggerName(record, verbose)}${record.message}'
'$eraseLine$level ${_recordHeader(record, verbose)}${record.message}'
];

if (record.error != null) {
Expand Down Expand Up @@ -57,34 +57,11 @@ StringBuffer colorLog(LogRecord record, {bool verbose}) {
void _stdIOLogListener(LogRecord record, {bool verbose}) =>
stdout.write(colorLog(record, verbose: verbose));

/// Filter out the Logger names known to come from `build_runner` and splits the
/// header for levels >= WARNING.
String _loggerName(LogRecord record, bool verbose) {
var knownNames = const [
'ApplyBuilders',
'Bootstrap',
'Build',
'BuildConfigOverrides',
'BuildDefinition',
'BuildOptions',
'BuildScriptUpdates',
'CreateOutputDir',
'Entrypoint',
'Heartbeat',
'IOEnvironment',
'Serve',
'Watch',
'build_runner',
// commands
'build',
'clean',
'doctor',
'serve',
'test',
'watch',
];
/// Filter out the Logger names which aren't coming from specific builders and
/// splits the header for levels >= WARNING.
String _recordHeader(LogRecord record, bool verbose) {
var maybeSplit = record.level >= Level.WARNING ? '\n' : '';
return verbose || !knownNames.contains(record.loggerName)
return verbose || record.loggerName.contains(' ')
? '${record.loggerName}:$maybeSplit'
: '';
}