Skip to content

Commit

Permalink
remove log package
Browse files Browse the repository at this point in the history
  • Loading branch information
JessonChan committed Feb 3, 2016
1 parent 3602201 commit a1cb000
Show file tree
Hide file tree
Showing 5 changed files with 80 additions and 65 deletions.
17 changes: 7 additions & 10 deletions logs/conn.go
Original file line number Diff line number Diff line change
Expand Up @@ -17,15 +17,14 @@ package logs
import (
"encoding/json"
"io"
"log"
"net"
"time"
)

// connWriter implements LoggerInterface.
// it writes messages in keep-live tcp connection.
type connWriter struct {
lg *log.Logger
lg *logWriter
innerWriter io.WriteCloser
ReconnectOnMsg bool `json:"reconnectOnMsg"`
Reconnect bool `json:"reconnect"`
Expand All @@ -43,8 +42,8 @@ func NewConn() Logger {

// Init init connection writer with json config.
// json config only need key "level".
func (c *connWriter) Init(jsonconfig string) error {
return json.Unmarshal([]byte(jsonconfig), c)
func (c *connWriter) Init(jsonConfig string) error {
return json.Unmarshal([]byte(jsonConfig), c)
}

// WriteMsg write message in connection.
Expand All @@ -53,7 +52,7 @@ func (c *connWriter) WriteMsg(when time.Time, msg string, level int) error {
if level > c.Level {
return nil
}
if c.neddedConnectOnMsg() {
if c.needToConnectOnMsg() {
err := c.connect()
if err != nil {
return err
Expand All @@ -64,9 +63,7 @@ func (c *connWriter) WriteMsg(when time.Time, msg string, level int) error {
defer c.innerWriter.Close()
}

msg = formatLogTime(when) + msg

c.lg.Println(msg)
c.lg.println(when, msg)
return nil
}

Expand Down Expand Up @@ -98,11 +95,11 @@ func (c *connWriter) connect() error {
}

c.innerWriter = conn
c.lg = log.New(conn, "", 0)
c.lg = newLogWriter(conn)
return nil
}

func (c *connWriter) neddedConnectOnMsg() bool {
func (c *connWriter) needToConnectOnMsg() bool {
if c.Reconnect {
c.Reconnect = false
return true
Expand Down
11 changes: 4 additions & 7 deletions logs/console.go
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,6 @@ package logs

import (
"encoding/json"
"log"
"os"
"runtime"
"time"
Expand Down Expand Up @@ -47,15 +46,15 @@ var colors = []brush{

// consoleWriter implements LoggerInterface and writes messages to terminal.
type consoleWriter struct {
lg *log.Logger
lg *logWriter
Level int `json:"level"`
Colorful bool `json:"color"` //this filed is useful only when system's terminal supports color
}

// NewConsole create ConsoleWriter returning as LoggerInterface.
func NewConsole() Logger {
cw := &consoleWriter{
lg: log.New(os.Stdout, "", 0),
lg: newLogWriter(os.Stdout),
Level: LevelDebug,
Colorful: true,
}
Expand All @@ -80,12 +79,10 @@ func (c *consoleWriter) WriteMsg(when time.Time, msg string, level int) error {
if level > c.Level {
return nil
}
msg = formatLogTime(when) + msg
if c.Colorful {
c.lg.Println(colors[level](msg))
} else {
c.lg.Println(msg)
msg = colors[level](msg)
}
c.lg.println(when, msg)
return nil
}

Expand Down
10 changes: 4 additions & 6 deletions logs/file.go
Original file line number Diff line number Diff line change
Expand Up @@ -118,13 +118,11 @@ func (w *fileLogWriter) WriteMsg(when time.Time, msg string, level int) error {
if level > w.Level {
return nil
}
msg = formatLogTime(when) + msg + "\n"

h, d := formatTimeHeader(when)
if w.Rotate {
d := when.Day()
if w.needRotate(len(msg), d) {
if w.needRotate(len(h)+len(msg)+1, d) {
w.Lock()
if w.needRotate(len(msg), d) {
if w.needRotate(len(h)+len(msg)+1, d) {
if err := w.doRotate(when); err != nil {
fmt.Fprintf(os.Stderr, "FileLogWriter(%q): %s\n", w.Filename, err)
}
Expand All @@ -134,7 +132,7 @@ func (w *fileLogWriter) WriteMsg(when time.Time, msg string, level int) error {
}

w.Lock()
_, err := w.fileWriter.Write([]byte(msg))
_, err := w.fileWriter.Write(append(append(h, msg...), '\n'))
if err == nil {
w.maxLinesCurLines++
w.maxSizeCurSize += len(msg)
Expand Down
42 changes: 0 additions & 42 deletions logs/log.go
Original file line number Diff line number Diff line change
Expand Up @@ -367,45 +367,3 @@ func (bl *BeeLogger) Close() {
}
bl.outputs = nil
}

func formatLogTime(when time.Time) string {
y, mo, d := when.Date()
h, mi, s := when.Clock()
//len(2006/01/02 15:03:04)==19
var buf [20]byte
t := 3
for y >= 10 {
p := y / 10
buf[t] = byte('0' + y - p*10)
y = p
t--
}
buf[0] = byte('0' + y)
buf[4] = '/'
if mo > 9 {
buf[5] = '1'
buf[6] = byte('0' + mo - 9)
} else {
buf[5] = '0'
buf[6] = byte('0' + mo)
}
buf[7] = '/'
t = d / 10
buf[8] = byte('0' + t)
buf[9] = byte('0' + d - t*10)
buf[10] = ' '
t = h / 10
buf[11] = byte('0' + t)
buf[12] = byte('0' + h - t*10)
buf[13] = ':'
t = mi / 10
buf[14] = byte('0' + t)
buf[15] = byte('0' + mi - t*10)
buf[16] = ':'
t = s / 10
buf[17] = byte('0' + t)
buf[18] = byte('0' + s - t*10)
buf[19] = ' '

return string(buf[0:])
}
65 changes: 65 additions & 0 deletions logs/logger.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,65 @@
package logs

import (
"io"
"sync"
"time"
)

type logWriter struct {
sync.Mutex
writer io.Writer
}

func newLogWriter(wr io.Writer) *logWriter {
return &logWriter{writer: wr}
}

func (lg *logWriter) println(when time.Time, msg string) {
lg.Lock()
h, _ := formatTimeHeader(when)
lg.writer.Write(append(append(h, msg...), '\n'))
lg.Unlock()
}

func formatTimeHeader(when time.Time) ([]byte, int) {
y, mo, d := when.Date()
h, mi, s := when.Clock()
//len(2006/01/02 15:03:04)==19
var buf [20]byte
t := 3
for y >= 10 {
p := y / 10
buf[t] = byte('0' + y - p*10)
y = p
t--
}
buf[0] = byte('0' + y)
buf[4] = '/'
if mo > 9 {
buf[5] = '1'
buf[6] = byte('0' + mo - 9)
} else {
buf[5] = '0'
buf[6] = byte('0' + mo)
}
buf[7] = '/'
t = d / 10
buf[8] = byte('0' + t)
buf[9] = byte('0' + d - t*10)
buf[10] = ' '
t = h / 10
buf[11] = byte('0' + t)
buf[12] = byte('0' + h - t*10)
buf[13] = ':'
t = mi / 10
buf[14] = byte('0' + t)
buf[15] = byte('0' + mi - t*10)
buf[16] = ':'
t = s / 10
buf[17] = byte('0' + t)
buf[18] = byte('0' + s - t*10)
buf[19] = ' '

return buf[0:], d
}

0 comments on commit a1cb000

Please sign in to comment.