38 lines
552 B
Go
38 lines
552 B
Go
|
package argh
|
||
|
|
||
|
import (
|
||
|
"errors"
|
||
|
"fmt"
|
||
|
"log"
|
||
|
"os"
|
||
|
"path/filepath"
|
||
|
"runtime"
|
||
|
)
|
||
|
|
||
|
var (
|
||
|
tracingEnabled = os.Getenv("ARGH_TRACING") == "enabled"
|
||
|
traceLogger *log.Logger
|
||
|
|
||
|
Error = errors.New("argh error")
|
||
|
)
|
||
|
|
||
|
func init() {
|
||
|
if !tracingEnabled {
|
||
|
return
|
||
|
}
|
||
|
|
||
|
traceLogger = log.New(os.Stderr, "ARGH TRACING: ", 0)
|
||
|
}
|
||
|
|
||
|
func tracef(format string, v ...any) {
|
||
|
if !tracingEnabled {
|
||
|
return
|
||
|
}
|
||
|
|
||
|
if _, file, line, ok := runtime.Caller(1); ok {
|
||
|
format = fmt.Sprintf("%v:%v ", filepath.Base(file), line) + format
|
||
|
}
|
||
|
|
||
|
traceLogger.Printf(format, v...)
|
||
|
}
|