veilidchat/lib/log/loggy.dart

105 lines
2.2 KiB
Dart
Raw Normal View History

2023-07-26 14:20:29 -04:00
import 'dart:io' show Platform;
import 'package:ansicolor/ansicolor.dart';
2023-01-08 22:27:33 -05:00
import 'package:flutter/foundation.dart';
import 'package:loggy/loggy.dart';
2023-09-26 18:46:02 -04:00
import '../veilid_support/veilid_support.dart';
2023-01-08 22:27:33 -05:00
String wrapWithLogColor(LogLevel? level, String text) {
2023-01-11 19:17:04 -05:00
// XXX: https://github.com/flutter/flutter/issues/64491
if (!kIsWeb && Platform.isIOS) {
return text;
}
2023-01-08 22:27:33 -05:00
if (level == null) {
return text;
}
final pen = AnsiPen();
ansiColorDisabled = false;
switch (level) {
case LogLevel.error:
pen
..reset()
..red(bold: true);
return pen(text);
case LogLevel.warning:
pen
..reset()
..yellow(bold: true);
return pen(text);
case LogLevel.info:
pen
..reset()
..white(bold: true);
return pen(text);
case LogLevel.debug:
pen
..reset()
..green(bold: true);
return pen(text);
case traceLevel:
pen
..reset()
..blue(bold: true);
return pen(text);
}
return text;
}
extension PrettyPrintLogRecord on LogRecord {
String pretty() {
final lstr =
wrapWithLogColor(level, '[${level.toString().substring(0, 1)}]');
return '$lstr $message';
}
}
class CallbackPrinter extends LoggyPrinter {
CallbackPrinter() : super();
void Function(LogRecord)? callback;
@override
void onLog(LogRecord record) {
debugPrint(record.pretty());
callback?.call(record);
}
2023-07-26 15:58:38 -04:00
void setCallback(void Function(LogRecord)? cb) {
2023-01-08 22:27:33 -05:00
callback = cb;
}
}
2023-07-26 14:20:29 -04:00
CallbackPrinter globalTerminalPrinter = CallbackPrinter();
2023-01-08 22:27:33 -05:00
2023-07-26 14:20:29 -04:00
LogOptions getLogOptions(LogLevel? level) => LogOptions(
2023-07-26 15:58:38 -04:00
level ?? LogLevel.all,
stackTraceLevel: LogLevel.error,
);
2023-01-08 22:27:33 -05:00
class RootLoggy implements LoggyType {
@override
Loggy<RootLoggy> get loggy => Loggy<RootLoggy>('');
}
2023-01-11 19:17:04 -05:00
Loggy get log => Loggy<RootLoggy>('veilidchat');
2023-01-08 22:27:33 -05:00
void initLoggy() {
Loggy.initLoggy(
logPrinter: globalTerminalPrinter,
logOptions: getLogOptions(null),
);
2023-07-26 17:42:11 -04:00
// ignore: do_not_use_environment
const isTrace = String.fromEnvironment('LOG_TRACE') != '';
2023-01-08 22:27:33 -05:00
LogLevel logLevel;
if (isTrace) {
logLevel = traceLevel;
} else {
logLevel = kDebugMode ? LogLevel.debug : LogLevel.info;
}
Loggy('').level = getLogOptions(logLevel);
}