2017-02-07 22:33:23 +01:00
|
|
|
package gominlog
|
|
|
|
|
|
|
|
import (
|
|
|
|
"log"
|
|
|
|
"os"
|
2017-04-11 17:10:46 +02:00
|
|
|
"fmt"
|
2017-02-07 22:33:23 +01:00
|
|
|
"runtime"
|
2017-04-11 17:10:46 +02:00
|
|
|
"github.com/fatih/color"
|
|
|
|
"regexp"
|
2017-02-07 22:33:23 +01:00
|
|
|
"strings"
|
2017-04-11 17:10:46 +02:00
|
|
|
"io"
|
2017-02-07 22:33:23 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
type Level int
|
|
|
|
|
|
|
|
const (
|
2017-04-11 17:10:46 +02:00
|
|
|
Loff = Level(^uint(0) >> 1)
|
|
|
|
Lsevere = Level(1000)
|
|
|
|
Lerror = Level(900)
|
2017-02-07 22:33:23 +01:00
|
|
|
Lwarning = Level(800)
|
2017-04-11 17:10:46 +02:00
|
|
|
Linfo = Level(700)
|
|
|
|
Ldebug = Level(600)
|
|
|
|
Lall = Level(-Loff - 1)
|
2017-02-07 22:33:23 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
type MinLog struct {
|
|
|
|
log *log.Logger
|
|
|
|
level Level
|
|
|
|
packageName string
|
|
|
|
isColorized bool
|
|
|
|
}
|
|
|
|
|
|
|
|
func NewClassicMinLog() *MinLog {
|
|
|
|
minLog := &MinLog{}
|
|
|
|
logWriter := os.Stdout
|
|
|
|
flags := log.Lshortfile | log.Ldate | log.Ltime
|
|
|
|
minLog.log = log.New(logWriter, "", flags)
|
|
|
|
minLog.isColorized = true
|
|
|
|
minLog.packageName = ""
|
|
|
|
minLog.level = Lall
|
|
|
|
return minLog
|
|
|
|
}
|
|
|
|
func NewClassicMinLogWithPackageName(packageName string) *MinLog {
|
|
|
|
minLog := NewClassicMinLog()
|
|
|
|
minLog.SetPackageName(packageName)
|
|
|
|
return minLog
|
|
|
|
}
|
|
|
|
func NewMinLog(appName string, level Level, withColor bool, flag int) *MinLog {
|
|
|
|
minLog := &MinLog{}
|
|
|
|
logWriter := os.Stdout
|
|
|
|
minLog.log = log.New(logWriter, "", flag)
|
|
|
|
minLog.isColorized = withColor
|
|
|
|
minLog.packageName = appName
|
|
|
|
minLog.level = level
|
|
|
|
return minLog
|
|
|
|
}
|
2017-04-11 17:10:46 +02:00
|
|
|
func NewMinLogWithWriter(appName string, level Level, withColor bool, flag int, logWriter io.Writer) *MinLog {
|
|
|
|
minLog := &MinLog{}
|
|
|
|
minLog.log = log.New(logWriter, "", flag)
|
|
|
|
minLog.isColorized = withColor
|
|
|
|
minLog.packageName = appName
|
|
|
|
minLog.level = level
|
|
|
|
return minLog
|
|
|
|
}
|
2017-02-07 22:33:23 +01:00
|
|
|
func NewMinLogWithLogger(packageName string, level Level, withColor bool, logger *log.Logger) *MinLog {
|
|
|
|
minLog := &MinLog{}
|
|
|
|
minLog.log = logger
|
|
|
|
minLog.isColorized = withColor
|
|
|
|
minLog.packageName = packageName
|
|
|
|
minLog.level = level
|
|
|
|
return minLog
|
|
|
|
}
|
|
|
|
func (this *MinLog) GetLevel() Level {
|
|
|
|
return Level(this.level)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (this *MinLog) SetWriter(writer io.Writer) {
|
|
|
|
this.log.SetOutput(writer)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (this *MinLog) SetLevel(level Level) {
|
|
|
|
this.level = level
|
|
|
|
}
|
|
|
|
func (this *MinLog) SetPackageName(newPackageName string) {
|
|
|
|
this.packageName = newPackageName
|
|
|
|
}
|
|
|
|
func (this *MinLog) GetPackageName() string {
|
|
|
|
return this.packageName
|
|
|
|
}
|
|
|
|
func (this *MinLog) SetLogger(l *log.Logger) {
|
|
|
|
this.log = l
|
|
|
|
}
|
|
|
|
func (this *MinLog) WithColor(isColorized bool) {
|
|
|
|
this.isColorized = isColorized
|
|
|
|
}
|
|
|
|
func (this *MinLog) IsColorized() bool {
|
|
|
|
return this.isColorized
|
|
|
|
}
|
|
|
|
func (this *MinLog) GetLogger() *log.Logger {
|
2017-04-11 17:10:46 +02:00
|
|
|
|
2017-02-07 22:33:23 +01:00
|
|
|
return this.log
|
|
|
|
}
|
|
|
|
|
2017-04-11 17:10:46 +02:00
|
|
|
func (this *MinLog) logMessage(typeLog string, colorFg color.Attribute, colorBg color.Attribute, args ...interface{}) {
|
2017-02-07 22:33:23 +01:00
|
|
|
var text string
|
|
|
|
msg := ""
|
|
|
|
flags := this.log.Flags()
|
|
|
|
if (log.Lshortfile | flags) == flags {
|
|
|
|
msg += this.trace()
|
|
|
|
this.log.SetFlags(flags - log.Lshortfile)
|
|
|
|
}
|
2017-04-11 17:10:46 +02:00
|
|
|
text, ok := args[0].(string);
|
2017-02-07 22:33:23 +01:00
|
|
|
if !ok {
|
|
|
|
panic("Firt argument should be a string")
|
|
|
|
}
|
|
|
|
if len(args) > 1 {
|
|
|
|
newArgs := args[1:]
|
|
|
|
msg += typeLog + ": " + fmt.Sprintf(text, newArgs...)
|
|
|
|
} else {
|
|
|
|
msg += typeLog + ": " + text
|
|
|
|
}
|
|
|
|
this.writeMsgInLogger(msg, colorFg, colorBg)
|
|
|
|
this.log.SetFlags(flags)
|
|
|
|
}
|
2017-04-11 17:10:46 +02:00
|
|
|
func (this *MinLog) writeMsgInLogger(msg string, colorFg color.Attribute, colorBg color.Attribute) {
|
|
|
|
if this.isColorized && int(colorBg) == 0 {
|
|
|
|
msg = color.New(colorFg).Sprint(msg)
|
|
|
|
} else if this.isColorized {
|
|
|
|
msg = color.New(colorFg, colorBg).Sprint(msg)
|
2017-02-07 22:33:23 +01:00
|
|
|
}
|
|
|
|
this.log.Print(msg)
|
|
|
|
}
|
|
|
|
func (this *MinLog) Error(args ...interface{}) {
|
|
|
|
if this.level > Lerror {
|
|
|
|
return
|
|
|
|
}
|
2017-04-11 17:10:46 +02:00
|
|
|
this.logMessage("ERROR", color.FgRed, 0, args...)
|
2017-02-07 22:33:23 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
func (this *MinLog) Severe(args ...interface{}) {
|
|
|
|
if this.level > Lsevere {
|
|
|
|
return
|
|
|
|
}
|
2017-04-11 17:10:46 +02:00
|
|
|
this.logMessage("SEVERE", color.FgRed, color.BgYellow, args...)
|
2017-02-07 22:33:23 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
func (this *MinLog) Debug(args ...interface{}) {
|
|
|
|
if this.level > Ldebug {
|
|
|
|
return
|
|
|
|
}
|
2017-04-11 17:10:46 +02:00
|
|
|
this.logMessage("DEBUG", color.FgBlue, 0, args...)
|
2017-02-07 22:33:23 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
func (this *MinLog) Info(args ...interface{}) {
|
|
|
|
if this.level > Linfo {
|
|
|
|
return
|
|
|
|
}
|
2017-04-11 17:10:46 +02:00
|
|
|
this.logMessage("INFO", color.FgCyan, 0, args...)
|
2017-02-07 22:33:23 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
func (this *MinLog) Warning(args ...interface{}) {
|
|
|
|
if this.level > Lwarning {
|
|
|
|
return
|
|
|
|
}
|
2017-04-11 17:10:46 +02:00
|
|
|
this.logMessage("WARNING", color.FgYellow, 0, args...)
|
2017-02-07 22:33:23 +01:00
|
|
|
}
|
|
|
|
func (this *MinLog) trace() string {
|
|
|
|
var shortFile string
|
|
|
|
pc := make([]uintptr, 10)
|
|
|
|
runtime.Callers(2, pc)
|
|
|
|
f := runtime.FuncForPC(pc[2])
|
|
|
|
file, line := f.FileLine(pc[2])
|
|
|
|
if this.packageName == "" {
|
|
|
|
execFileSplit := strings.Split(os.Args[0], "/")
|
2017-04-11 17:10:46 +02:00
|
|
|
this.packageName = execFileSplit[len(execFileSplit) - 1]
|
2017-02-07 22:33:23 +01:00
|
|
|
}
|
|
|
|
regex, err := regexp.Compile(regexp.QuoteMeta(this.packageName) + "/(.*)")
|
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
subMatch := regex.FindStringSubmatch(file)
|
|
|
|
if len(subMatch) < 2 {
|
|
|
|
fileSplit := strings.Split(file, "/")
|
2017-04-11 17:10:46 +02:00
|
|
|
shortFile = fileSplit[len(fileSplit) - 1]
|
2017-02-07 22:33:23 +01:00
|
|
|
} else {
|
|
|
|
shortFile = subMatch[1]
|
|
|
|
}
|
|
|
|
|
|
|
|
return fmt.Sprintf("/%s/%s:%d ", this.packageName, shortFile, line)
|
2017-04-11 17:10:46 +02:00
|
|
|
}
|