-
Notifications
You must be signed in to change notification settings - Fork 9
/
Copy pathLogger.py
68 lines (56 loc) · 1.57 KB
/
Logger.py
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
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
import sys
import time
try:
import socket
except:
print "No Sockets"
class Logger:
"""
Simple logger.
Tries to use a socket which connects to localhost port 4444 by default.
If that fails then it logs to a file
"""
def __init__(self):
try:
self.socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
except:
print "Couldn't create socket"
self.socket = None
self.connected = 0
if self.socket:
try:
self.socket.connect(("localhost", 4444))
self.connected = 1
self.stderr = sys.stderr
sys.stderr = self
except:
print "Couldn't connect socket"
self.buf = ""
def log(self,msg):
if self.connected:
self.send(msg + '\n')
else:
print(msg)
def send(self,msg):
if self.connected:
self.socket.send(msg)
def close(self):
if self.connected:
self.socket.send("Closing..")
self.socket.close()
def write(self, msg):
self.stderr.write(msg)
self.buf = self.buf + msg
lines = self.buf.split("\n", 2)
if len(lines) == 2:
self.send("STDERR: " + lines[0] + "\n")
self.buf = lines[1]
logger = Logger()
def log(*args):
text = ''
for arg in args:
if text != '':
text = text + ' '
text = text + str(arg)
if logger != None:
logger.log(text)