2018-04-06 14:52:10 +00:00
|
|
|
# Nimbus
|
|
|
|
# Copyright (c) 2018 Status Research & Development GmbH
|
|
|
|
# Licensed under either of
|
|
|
|
# * Apache License, version 2.0, ([LICENSE-APACHE](LICENSE-APACHE) or http://www.apache.org/licenses/LICENSE-2.0)
|
|
|
|
# * MIT license ([LICENSE-MIT](LICENSE-MIT) or http://opensource.org/licenses/MIT)
|
|
|
|
# at your option. This file may not be copied, modified, or distributed except according to those terms.
|
|
|
|
|
2018-02-20 17:27:43 +00:00
|
|
|
import strformat, terminal
|
2018-01-15 18:42:40 +00:00
|
|
|
|
|
|
|
type
|
|
|
|
Logger* = object
|
|
|
|
name*: string
|
|
|
|
|
2018-02-26 11:59:56 +00:00
|
|
|
var DEBUG* = defined(nimbusdebug)
|
2018-01-16 17:05:20 +00:00
|
|
|
|
2018-02-20 17:27:43 +00:00
|
|
|
proc log*(l: Logger, msg: string, color: ForegroundColor = fgBlack) =
|
2018-02-07 09:50:15 +00:00
|
|
|
if DEBUG:
|
2018-02-20 17:27:43 +00:00
|
|
|
styledWriteLine(stdout, color, &"#{l.name}: {msg}", resetStyle)
|
2018-01-15 18:42:40 +00:00
|
|
|
|
2018-01-16 17:05:20 +00:00
|
|
|
proc debug*(l: Logger, msg: string) =
|
|
|
|
if DEBUG:
|
|
|
|
l.log(msg)
|
|
|
|
|
2018-01-15 18:42:40 +00:00
|
|
|
proc trace*(l: Logger, msg: string) =
|
2018-02-07 09:50:15 +00:00
|
|
|
if DEBUG:
|
2018-02-20 17:27:43 +00:00
|
|
|
l.log(msg, fgBlue)
|
2018-01-15 18:42:40 +00:00
|
|
|
|
|
|
|
proc getLogger*(name: string): Logger =
|
|
|
|
result = Logger(name: name)
|
2018-02-07 09:50:15 +00:00
|
|
|
|
|
|
|
proc disableLogging* =
|
|
|
|
DEBUG = false
|
|
|
|
|
|
|
|
proc enableLogging* =
|
|
|
|
DEBUG = true
|