This is a fork of the package https://pub.dev/packages/logging.
Redesigned logging level to TDIWEF style - trace, debug, info, warn, error, fatal
By default, the logging package does not do anything useful with the log messages. You must configure the logging level and add a handler for the log messages.
Here is a simple logging configuration that logs all messages via print
.
Logger.root.level = Level.ALL; // defaults to Level.INFO
Logger.root.onRecord.listen((record) {
print('${record.level.name}: ${record.time}: ${record.message}');
});
First, set the root Level
. All messages at or above the current level are sent to the
onRecord
stream. Available levels are:
Level.OFF
Level.FATAL
Level.ERROR
Level.WARNING
Level.INFO
Level.DEBUG
Level.TRACE
Then, listen on the onRecord
stream for LogRecord
events. The LogRecord
class has various properties for the message, error, logger name, and more.
Create a Logger
with a unique name to easily identify the source of the log
messages.
final log = Logger('MyClassName');
Here is an example of logging a debug message and an error:
var future = doSomethingAsync().then((result) {
log.debug('Got the result: $result');
processResult(result);
}).catchError((e, stackTrace) => log.error('Oh noes!', e, stackTrace));
When logging more complex messages, you can pass a closure instead that will be evaluated only if the message is actually logged:
log.trace(() => [1, 2, 3, 4, 5].map((e) => e * 4).join("-"));
Available logging methods are:
log.fatal(logged_content);
orlog.f(logged_content);
log.error(logged_content);
orlog.e(logged_content);
log.warn(logged_content);
orlog.w(logged_content);
log.info(logged_content);
orlog.i(logged_content);
log.denug(logged_content);
orlog.d(logged_content);
log.trace(logged_content);
orlog.t(logged_content);