summaryrefslogtreecommitdiffstats
path: root/Godeps/_workspace/src/github.com/alecthomas/log4go/socklog.go
diff options
context:
space:
mode:
author=Corey Hulen <corey@hulen.com>2016-01-11 09:13:38 -0600
committer=Corey Hulen <corey@hulen.com>2016-01-11 09:13:38 -0600
commit30bb530903352039c1b5055a756b7e246e2406b6 (patch)
treefddb6a34fbb67a8748c88ace8d316a6dcac9109a /Godeps/_workspace/src/github.com/alecthomas/log4go/socklog.go
parentb1251b93932adf616a996725448d0b77fad0d3c1 (diff)
downloadchat-30bb530903352039c1b5055a756b7e246e2406b6.tar.gz
chat-30bb530903352039c1b5055a756b7e246e2406b6.tar.bz2
chat-30bb530903352039c1b5055a756b7e246e2406b6.zip
Upgrading logging package
Diffstat (limited to 'Godeps/_workspace/src/github.com/alecthomas/log4go/socklog.go')
-rw-r--r--Godeps/_workspace/src/github.com/alecthomas/log4go/socklog.go57
1 files changed, 57 insertions, 0 deletions
diff --git a/Godeps/_workspace/src/github.com/alecthomas/log4go/socklog.go b/Godeps/_workspace/src/github.com/alecthomas/log4go/socklog.go
new file mode 100644
index 000000000..1d224a99d
--- /dev/null
+++ b/Godeps/_workspace/src/github.com/alecthomas/log4go/socklog.go
@@ -0,0 +1,57 @@
+// Copyright (C) 2010, Kyle Lemons <kyle@kylelemons.net>. All rights reserved.
+
+package log4go
+
+import (
+ "encoding/json"
+ "fmt"
+ "net"
+ "os"
+)
+
+// This log writer sends output to a socket
+type SocketLogWriter chan *LogRecord
+
+// This is the SocketLogWriter's output method
+func (w SocketLogWriter) LogWrite(rec *LogRecord) {
+ w <- rec
+}
+
+func (w SocketLogWriter) Close() {
+ close(w)
+}
+
+func NewSocketLogWriter(proto, hostport string) SocketLogWriter {
+ sock, err := net.Dial(proto, hostport)
+ if err != nil {
+ fmt.Fprintf(os.Stderr, "NewSocketLogWriter(%q): %s\n", hostport, err)
+ return nil
+ }
+
+ w := SocketLogWriter(make(chan *LogRecord, LogBufferLength))
+
+ go func() {
+ defer func() {
+ if sock != nil && proto == "tcp" {
+ sock.Close()
+ }
+ }()
+
+ for rec := range w {
+ // Marshall into JSON
+ js, err := json.Marshal(rec)
+ if err != nil {
+ fmt.Fprint(os.Stderr, "SocketLogWriter(%q): %s", hostport, err)
+ return
+ }
+
+ _, err = sock.Write(js)
+ if err != nil {
+ fmt.Fprint(os.Stderr, "SocketLogWriter(%q): %s", hostport, err)
+ return
+ }
+ }
+ }()
+
+ return w
+}