|
|
@ -21,6 +21,7 @@ import ( |
|
|
|
"regexp" |
|
|
|
"regexp" |
|
|
|
"runtime" |
|
|
|
"runtime" |
|
|
|
"strings" |
|
|
|
"strings" |
|
|
|
|
|
|
|
"syscall" |
|
|
|
) |
|
|
|
) |
|
|
|
|
|
|
|
|
|
|
|
// IsExist returns if a file or directory exists
|
|
|
|
// IsExist returns if a file or directory exists
|
|
|
@ -29,6 +30,7 @@ func IsExist(path string) bool { |
|
|
|
return err == nil || os.IsExist(err) |
|
|
|
return err == nil || os.IsExist(err) |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Non-Windows.
|
|
|
|
const ( |
|
|
|
const ( |
|
|
|
Gray = uint8(iota + 90) |
|
|
|
Gray = uint8(iota + 90) |
|
|
|
Red |
|
|
|
Red |
|
|
@ -40,6 +42,26 @@ const ( |
|
|
|
EndColor = "\033[0m" |
|
|
|
EndColor = "\033[0m" |
|
|
|
) |
|
|
|
) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Windows.
|
|
|
|
|
|
|
|
const ( |
|
|
|
|
|
|
|
WDefault = uintptr(iota) |
|
|
|
|
|
|
|
WBlue |
|
|
|
|
|
|
|
WGreen |
|
|
|
|
|
|
|
WCyan |
|
|
|
|
|
|
|
WRed |
|
|
|
|
|
|
|
WPurple |
|
|
|
|
|
|
|
WYellow |
|
|
|
|
|
|
|
WGray |
|
|
|
|
|
|
|
WSilver |
|
|
|
|
|
|
|
WLightBlue |
|
|
|
|
|
|
|
WLime |
|
|
|
|
|
|
|
WLightCyan |
|
|
|
|
|
|
|
WLightRed |
|
|
|
|
|
|
|
WLightPurple |
|
|
|
|
|
|
|
WLightYellow |
|
|
|
|
|
|
|
WWhite |
|
|
|
|
|
|
|
) |
|
|
|
|
|
|
|
|
|
|
|
// ColorLog colors log and print to stdout.
|
|
|
|
// ColorLog colors log and print to stdout.
|
|
|
|
// Log format: <level> <content [highlight][path]> [ error ].
|
|
|
|
// Log format: <level> <content [highlight][path]> [ error ].
|
|
|
|
// Level: TRAC -> blue; ERRO -> red; WARN -> Magenta; SUCC -> green; others -> default.
|
|
|
|
// Level: TRAC -> blue; ERRO -> red; WARN -> Magenta; SUCC -> green; others -> default.
|
|
|
@ -74,6 +96,16 @@ func ColorLog(format string, a ...interface{}) { |
|
|
|
log = strings.Replace(log, " #", EndColor, -1) |
|
|
|
log = strings.Replace(log, " #", EndColor, -1) |
|
|
|
|
|
|
|
|
|
|
|
log = clog + log |
|
|
|
log = clog + log |
|
|
|
|
|
|
|
} else { |
|
|
|
|
|
|
|
// Level.
|
|
|
|
|
|
|
|
i := strings.Index(log, "]") |
|
|
|
|
|
|
|
if log[0] == '[' && i > -1 { |
|
|
|
|
|
|
|
fmt.Print("[") |
|
|
|
|
|
|
|
printColorLevel(log[1:i]) |
|
|
|
|
|
|
|
fmt.Print("]") |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
log = log[i+1:] |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
fmt.Print(log) |
|
|
|
fmt.Print(log) |
|
|
@ -96,6 +128,32 @@ func getColorLevel(level string) string { |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// printColorLevel prints color level prompt, this is only for Windows.
|
|
|
|
|
|
|
|
func printColorLevel(level string) { |
|
|
|
|
|
|
|
cc := WDefault |
|
|
|
|
|
|
|
level = strings.ToUpper(level) |
|
|
|
|
|
|
|
switch level { |
|
|
|
|
|
|
|
case "TRAC": |
|
|
|
|
|
|
|
cc = WBlue |
|
|
|
|
|
|
|
case "ERRO": |
|
|
|
|
|
|
|
cc = WRed |
|
|
|
|
|
|
|
case "WARN": |
|
|
|
|
|
|
|
cc = WPurple |
|
|
|
|
|
|
|
case "SUCC": |
|
|
|
|
|
|
|
cc = WGreen |
|
|
|
|
|
|
|
default: |
|
|
|
|
|
|
|
cc = WWhite |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
kernel32 := syscall.NewLazyDLL("kernel32.dll") |
|
|
|
|
|
|
|
proc := kernel32.NewProc("SetConsoleTextAttribute") |
|
|
|
|
|
|
|
handle, _, _ := proc.Call(uintptr(syscall.Stdout), uintptr(cc)) |
|
|
|
|
|
|
|
fmt.Print(level) |
|
|
|
|
|
|
|
handle, _, _ = proc.Call(uintptr(syscall.Stdout), uintptr(WSilver)) |
|
|
|
|
|
|
|
CloseHandle := kernel32.NewProc("CloseHandle") |
|
|
|
|
|
|
|
CloseHandle.Call(handle) |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
// GetGOPATH returns all paths in GOPATH variable.
|
|
|
|
// GetGOPATH returns all paths in GOPATH variable.
|
|
|
|
func GetGOPATH() []string { |
|
|
|
func GetGOPATH() []string { |
|
|
|
gopath := os.Getenv("GOPATH") |
|
|
|
gopath := os.Getenv("GOPATH") |
|
|
|