2023-01-08 22:27:33 -05:00
|
|
|
import 'package:flutter/foundation.dart';
|
|
|
|
import 'package:loggy/loggy.dart';
|
2023-07-26 14:20:29 -04:00
|
|
|
import 'package:veilid/veilid.dart';
|
|
|
|
|
2023-09-26 18:46:02 -04:00
|
|
|
// Loggy tools
|
|
|
|
const LogLevel traceLevel = LogLevel('Trace', 1);
|
|
|
|
|
|
|
|
extension TraceLoggy on Loggy {
|
|
|
|
void trace(dynamic message, [Object? error, StackTrace? stackTrace]) =>
|
|
|
|
log(traceLevel, message, error, stackTrace);
|
|
|
|
}
|
2023-01-08 22:27:33 -05:00
|
|
|
|
|
|
|
VeilidConfigLogLevel convertToVeilidConfigLogLevel(LogLevel? level) {
|
|
|
|
if (level == null) {
|
|
|
|
return VeilidConfigLogLevel.off;
|
|
|
|
}
|
|
|
|
switch (level) {
|
|
|
|
case LogLevel.error:
|
|
|
|
return VeilidConfigLogLevel.error;
|
|
|
|
case LogLevel.warning:
|
|
|
|
return VeilidConfigLogLevel.warn;
|
|
|
|
case LogLevel.info:
|
|
|
|
return VeilidConfigLogLevel.info;
|
|
|
|
case LogLevel.debug:
|
|
|
|
return VeilidConfigLogLevel.debug;
|
|
|
|
case traceLevel:
|
|
|
|
return VeilidConfigLogLevel.trace;
|
|
|
|
}
|
|
|
|
return VeilidConfigLogLevel.off;
|
|
|
|
}
|
|
|
|
|
|
|
|
void setVeilidLogLevel(LogLevel? level) {
|
2023-07-26 14:20:29 -04:00
|
|
|
Veilid.instance.changeLogLevel('all', convertToVeilidConfigLogLevel(level));
|
2023-01-08 22:27:33 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
class VeilidLoggy implements LoggyType {
|
|
|
|
@override
|
|
|
|
Loggy<VeilidLoggy> get loggy => Loggy<VeilidLoggy>('Veilid');
|
|
|
|
}
|
|
|
|
|
|
|
|
Loggy get _veilidLoggy => Loggy<VeilidLoggy>('Veilid');
|
|
|
|
|
|
|
|
Future<void> processLog(VeilidLog log) async {
|
|
|
|
StackTrace? stackTrace;
|
|
|
|
Object? error;
|
|
|
|
final backtrace = log.backtrace;
|
|
|
|
if (backtrace != null) {
|
2023-07-26 17:42:11 -04:00
|
|
|
stackTrace = StackTrace.fromString('$backtrace\n${StackTrace.current}');
|
2023-01-08 22:27:33 -05:00
|
|
|
error = 'embedded stack trace for ${log.logLevel} ${log.message}';
|
|
|
|
}
|
|
|
|
|
|
|
|
switch (log.logLevel) {
|
|
|
|
case VeilidLogLevel.error:
|
|
|
|
_veilidLoggy.error(log.message, error, stackTrace);
|
|
|
|
break;
|
|
|
|
case VeilidLogLevel.warn:
|
|
|
|
_veilidLoggy.warning(log.message, error, stackTrace);
|
|
|
|
break;
|
|
|
|
case VeilidLogLevel.info:
|
|
|
|
_veilidLoggy.info(log.message, error, stackTrace);
|
|
|
|
break;
|
|
|
|
case VeilidLogLevel.debug:
|
|
|
|
_veilidLoggy.debug(log.message, error, stackTrace);
|
|
|
|
break;
|
|
|
|
case VeilidLogLevel.trace:
|
|
|
|
_veilidLoggy.trace(log.message, error, stackTrace);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void initVeilidLog() {
|
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;
|
|
|
|
}
|
|
|
|
setVeilidLogLevel(logLevel);
|
|
|
|
}
|