mirror of
https://gitlab.com/veilid/veilidchat.git
synced 2025-05-14 20:22:15 -04:00
cleanup
This commit is contained in:
parent
9dd17cb077
commit
a551791f97
4 changed files with 39 additions and 7 deletions
|
@ -1,33 +1,60 @@
|
|||
import 'package:bloc/bloc.dart';
|
||||
import 'package:loggy/loggy.dart';
|
||||
import 'loggy.dart';
|
||||
|
||||
const Map<String, LogLevel> _blocChangeLogLevels = {
|
||||
'ConnectionStateCubit': LogLevel.off
|
||||
};
|
||||
const Map<String, LogLevel> _blocCreateCloseLogLevels = {};
|
||||
const Map<String, LogLevel> _blocErrorLogLevels = {};
|
||||
|
||||
/// [BlocObserver] for the VeilidChat application that
|
||||
/// observes all state changes.
|
||||
class StateLogger extends BlocObserver {
|
||||
/// {@macro counter_observer}
|
||||
const StateLogger();
|
||||
|
||||
void _checkLogLevel(
|
||||
Map<String, LogLevel> blocLogLevels,
|
||||
LogLevel defaultLogLevel,
|
||||
BlocBase<dynamic> bloc,
|
||||
void Function(LogLevel) closure) {
|
||||
final logLevel =
|
||||
blocLogLevels[bloc.runtimeType.toString()] ?? defaultLogLevel;
|
||||
if (logLevel != LogLevel.off) {
|
||||
closure(logLevel);
|
||||
}
|
||||
}
|
||||
|
||||
@override
|
||||
void onChange(BlocBase<dynamic> bloc, Change<dynamic> change) {
|
||||
super.onChange(bloc, change);
|
||||
log.debug('Change: ${bloc.runtimeType} $change');
|
||||
_checkLogLevel(_blocChangeLogLevels, LogLevel.debug, bloc, (logLevel) {
|
||||
log.log(logLevel, 'Change: ${bloc.runtimeType} $change');
|
||||
});
|
||||
}
|
||||
|
||||
@override
|
||||
void onCreate(BlocBase<dynamic> bloc) {
|
||||
super.onCreate(bloc);
|
||||
log.debug('Create: ${bloc.runtimeType}');
|
||||
_checkLogLevel(_blocCreateCloseLogLevels, LogLevel.debug, bloc, (logLevel) {
|
||||
log.log(logLevel, 'Create: ${bloc.runtimeType}');
|
||||
});
|
||||
}
|
||||
|
||||
@override
|
||||
void onClose(BlocBase<dynamic> bloc) {
|
||||
super.onClose(bloc);
|
||||
log.debug('Close: ${bloc.runtimeType}');
|
||||
_checkLogLevel(_blocCreateCloseLogLevels, LogLevel.debug, bloc, (logLevel) {
|
||||
log.log(logLevel, 'Close: ${bloc.runtimeType}');
|
||||
});
|
||||
}
|
||||
|
||||
@override
|
||||
void onError(BlocBase<dynamic> bloc, Object error, StackTrace stackTrace) {
|
||||
super.onError(bloc, error, stackTrace);
|
||||
log.error('Error: ${bloc.runtimeType} $error\n$stackTrace');
|
||||
_checkLogLevel(_blocErrorLogLevels, LogLevel.error, bloc, (logLevel) {
|
||||
log.log(logLevel, 'Error: ${bloc.runtimeType} $error\n$stackTrace');
|
||||
});
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue