Pub

A package for logging with more extensive options than the built in logger.

Features

  • Modularized logging
  • Predefined loggers to log to the terminal or a file
  • Custom logger to send log messages to a remote logging server
  • Timestamp formatting

Future plans

  • Threaded logger for performance

Usage

Simply using predefined logger:

logging.start();
...
logging.info("info");
logging.critical("critical");
...
await logging.stop()

Or using a user-configured logger:

final Logger logger = Logger(
    loggerName: "MAIN",
    sink: FileSink(filename: "log.txt", behavior: FileSinkStartBehavior.CLEAR),
    loggerCallback: null
);
logger.setFlushInterval(100);
logger.setDateTimeFMT(DateTimeFMT.DATE);
logger.setLoggerSinkLevel(LogLevel.ERROR);
logger.start();
// ...
logger.info("info");
logger.critical("critical");
// ...
await logger.stop();

Libraries

logging_utils