IOLogging.jl

A simple, thin package providing basic loggers for logging to IO
Author Seelengrab
Popularity
4 Stars
Updated Last
5 Years Ago
Started In
September 2018

IOLogging.jl

Build Status

A simple, thin package providing basic loggers for logging to IO. As the logging functionality from Base might change in the future, so will this package.

Installation

This package is registered with METADATA.jl, so you can just do ]add IOLogging to install the package.

Usage

julia> using Logging, IOLogging

julia> logger = IOLogger()

julia> oldGlobal = global_logger(logger)

julia> @info "Hello World!"

# prints this (with a current timestamp):
# [Info::2018-09-12T10:50:12.884]  Main@REPL[4]:1 - Hello World!

We can also pass our own destinations for Logging:

# default is stdout for everything above Info
julia> logger = IOLogger(Dict(Logging.Info => stderr, Logging.Error => devnull))

The same as above applies to FileLogger() as well, but instead of giving destination IO, we specify a destination file.

# default is default.log for everything above Info
julia> logger = FileLogger(Dict(Logging.Info => "info.log", Logging.Error => "error.log"))

For more information about the individual loggers, make sure to read ?IOLogger and ?FileLogger.

Known ToDo

  • Add custom log message formatting
  • Add more tests
  • Make decision on logging error catching (IOLogging.jl#20)