use Carp ();
sub log_error {
goto(&Carp::carp) if pop(@_) >= THRESHOLD;
}
####
sub DEBUG () { 0 }
sub FATAL () { 4 }
sub THRESHOLD () { 0 }
log_error($msg) if FATAL >= THRESHOLD;
####
use Carp ();
sub WARN () { 1 }
sub ERROR () { 2 }
sub DEBUG () { 0 } # True of false.
sub THRESHOLD () { ERROR } # Or use $THRESHOLD. No real diff.
sub log_error {
my $level = (@_==2 ? pop(@_) : THRESHOLD);
return if $level < THRESHOLD;
goto &Carp::carp;
}
log_error($msg) if DEBUG; # Whole statement removed at compile time.
log_error($msg, WARN); # Calls log_error, but not carp.
log_error($msg, FATAL); # Calls log_error and carp.