# Log::D The module provides support for logging. There are different type of logging: error, warning, debug, verbose, info and plain. You create a log object, then you call methods e,w,d,v,i or p. Methods accept one argument, the logging message or two , section and message. Sections can be allowed or banned. Logging types can be enebled or disabled. The prefix of the log message can be given by a prefix function. Default output is $*ERR. ## Usage use Log::D; my $f = Log::D.new(:w,:i); # create a new object , enable warning and infos $f.prefix = sub { callframe(2).file~" "~callframe(2).line~" "~$*THREAD.id~" "~DateTime.now~" "; }; #show line number of logging $f.i("reached destructor"); $f.enable(:v); # let us enable verbose error messages too $f.allow("engine func"); # if no allow is given, everything is allowed $f.i("engine func", "engine starting"); $f.remove_allow("engine func"); # it is not longer allowed, if no allow left, all is turned on $f.ban("low level func"); # or use ban, then it is not displayed for sure $f.i("low level func", "print invoice"); $f.remove_ban("low level func"); # need to be able to remove it $f.o = $*OUT; # change output of the log use Log::Empty; my $f = Log::Empty.new(:w,:i); # all logging is off.. useful to replace Log::D with Log::Empty $f.notify = True; # show bans, allows..etc in the log as well to track their usages