forked from shaddi/EE122-Project-2
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathlogviewer.py
executable file
·114 lines (100 loc) · 3 KB
/
logviewer.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
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
#!/usr/bin/env python
from Tkinter import *
from ScrolledText import *
from tkFont import Font
from Queue import Queue, Empty
class LogWindow (Frame):
def __init__ (self, master=None):
Frame.__init__(self, master)
self.master.title("Network Simulator Log")
self.text = ScrolledText(self)
self.text.pack(fill=BOTH,expand=1)
self.pack(fill=BOTH,expand=1)
self.text.config(
background="black",
foreground="white",
font=Font(family="Courier", weight="bold"),
#state=DISABLED,
wrap=NONE,
)
self.text.tag_config("DEBUG", foreground="green")
self.text.tag_config("ERROR", foreground="red")
self.text.tag_config("CRITICAL", foreground="red")
self.text.tag_config("EXCEPTION", foreground="red")
self.text.tag_config("WARNING", foreground="yellow")
self.text.tag_config("INFO", foreground="white")
self.text.bind("<Key>", lambda e: 'break')
self.text.bind("<Return>", self._clear)
self.queue = Queue()
self._update()
def _clear (self, event):
self.text.delete(1.0, END)
return 'break'
def _update (self):
try:
while True:
text,level = self.queue.get(block=False)
at_bottom = self.text.yview()[1] == 1.0
#self.text.config(state=NORMAL)
if len(self.text.get(1.0, END).strip()) != 0:
text = "\n" + text
self.text.insert(END, text, str(level))
#self.text.config(state=DISABLED)
if at_bottom:
self.text.yview_moveto(1.0)
except Empty:
pass
self.after(50, self._update)
def append (self, entry, level="INFO"):
self.queue.put((entry,level))
def prog (logWindow):
import socket
import json
import time
while True:
sock = None
try:
sock = socket.socket()
sock.connect(('127.0.0.1', 4444))
logWindow.append("--- Connected ----------------------")
d = ''
while True:
r = sock.recv(4096)
if len(r) == 0: raise RuntimeError()
d += r
while d.find('\n') != -1:
msg,d = d.split("\n", 1)
msg = json.loads(msg)
if msg.get("type") == "log":
#print msg
r = msg['asctime'].split(',',1)[0].split(' ', 1)[1]
r += " "
r += "%-10s" % (msg['levelname'],)
r += ' '
r += msg['message']
if msg['name'] == 'user':
r = "U " + r
elif msg['name'] == 'simulator':
r = "S " + r
else:
r = msg['name'][0].lower() + " " + r
logWindow.append(r,msg['levelname'])
except:
#import traceback
#traceback.print_exc()
try:
sock.close()
except:
pass
time.sleep(0.25)
import threading
def launch (logWindow):
t = threading.Thread(target = prog, args=(logWindow,))
t.daemon = True
t.start()
if __name__ == '__main__':
def launchLog ():
logWindow = LogWindow()
logWindow.after(100, lambda : launch(logWindow))
logWindow.mainloop()
launchLog()