-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmainLaptop.py
92 lines (70 loc) · 2.83 KB
/
mainLaptop.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
import logging
import sys
import threading
import tkinter as tk
import tkinter.messagebox
import laptop.gui.controlgui as controlgui
import laptop.gui.logginggui as logginggui
from laptop.gui.sensorgui import SensorGUI
from laptop.network.loggingreceiver import logging_receive_forever
from laptop.network.pingchecker import PingChecker
from shared.customlogging.filter import SensorFilter
from shared.customlogging.formatter import CSVFormatter
from shared.customlogging.handler import MakeFileHandler
def create_sensorlog_handler(name):
logging.getLogger(__name__).debug(f"Adding handler {name} for sensor logging")
sensorlogger = logging.getLogger(name)
splitName = name.split('.')
csvHandler = MakeFileHandler('laptop', 'sensor', splitName[1], 'csv')
csvHandler.setFormatter(CSVFormatter())
sensorlogger.addHandler(csvHandler)
sensorlogger.setLevel(logging.INFO)
# Setting up logging to console and file
logger = logging.getLogger()
logger.setLevel(logging.INFO)
loggingFormat = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s')
loggingFormatWindow = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s', '%H:%M:%S')
loggingFilter = SensorFilter()
# Logging to console
consoleHandler = logging.StreamHandler(sys.stdout)
consoleHandler.setFormatter(loggingFormat)
consoleHandler.addFilter(loggingFilter)
logger.addHandler(consoleHandler)
# Logging to file. A new file is created each run, with the name being the current date and time
fileHandler = MakeFileHandler('laptop', 'main')
fileHandler.setFormatter(loggingFormat)
fileHandler.addFilter(loggingFilter)
logger.addHandler(fileHandler)
# Setup sensor logging. Each new sensor need to be added here
create_sensorlog_handler("sensorlog.thermometer")
create_sensorlog_handler("sensorlog.pressure")
create_sensorlog_handler("sensorlog.acceleration")
# Setting up of the GUI
root = tk.Tk()
# Setup the GUI for controlling the experiment
window2 = tk.Toplevel(root)
controlGUI = controlgui.ControlGUI(window2)
# Setup the logging window
logGUI = logginggui.LoggingGUI(root)
guiHandler = logginggui.LoggingGUIHandler(logGUI, controlGUI.status)
guiHandler.setFormatter(loggingFormatWindow)
guiHandler.addFilter(loggingFilter)
logger.addHandler(guiHandler)
# Setup the sensor window
window3 = tk.Toplevel(root)
sensorGUI = SensorGUI(window3)
# Start the log receiver
t = threading.Thread(target=logging_receive_forever)
t.setDaemon(True)
t.start()
# Start the ping daemon
PingChecker().start()
# Add confirmation box on closing
def close_application():
close = tkinter.messagebox.askokcancel("Quit", "Are you sure you want to quit?")
if close:
root.destroy()
root.protocol("WM_DELETE_WINDOW", close_application)
window2.protocol("WM_DELETE_WINDOW", close_application)
window3.protocol("WM_DELETE_WINDOW", close_application)
root.mainloop()