-
Notifications
You must be signed in to change notification settings - Fork 16
/
Copy pathlogger_unix.go
45 lines (37 loc) · 1.05 KB
/
logger_unix.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
// +build darwin dragonfly freebsd linux nacl netbsd openbsd solaris
/* ipp-usb - HTTP reverse proxy, backed by IPP-over-USB connection to device
*
* Copyright (C) 2020 and up by Alexander Pevzner (pzz@apevzner.com)
* See LICENSE for license terms and conditions
*
* Logging, system-dependent part for UNIX
*/
package main
import (
"io"
"os"
)
// #include <unistd.h>
import "C"
// logIsAtty returns true, if os.File refers to a terminal
func logIsAtty(file *os.File) bool {
fd := file.Fd()
return C.isatty(C.int(fd)) == 1
}
// logColorConsoleWrite writes a colorized line to console
func logColorConsoleWrite(out io.Writer, level LogLevel, line []byte) {
var beg, end string
switch {
case (level & LogError) != 0:
beg, end = "\033[31;1m", "\033[0m" // Red
case (level & LogInfo) != 0:
beg, end = "\033[32;1m", "\033[0m" // Green
case (level & LogDebug) != 0:
beg, end = "\033[37;1m", "\033[0m" // White
case (level & LogTraceAll) != 0:
beg, end = "\033[37m", "\033[0m" // Gray
}
out.Write([]byte(beg))
out.Write(line)
out.Write([]byte(end))
}