File: machine_log.py

package info (click to toggle)
linuxcnc 1%3A2.9.4-2
  • links: PTS, VCS
  • area: main
  • in suites: trixie
  • size: 282,780 kB
  • sloc: python: 201,110; ansic: 106,370; cpp: 99,219; tcl: 16,054; xml: 10,617; sh: 10,258; makefile: 1,251; javascript: 138; sql: 72; asm: 15
file content (100 lines) | stat: -rw-r--r-- 3,460 bytes parent folder | download | duplicates (2)
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
from qtvcp.core import Status, Info

import os
import time

# Set up logging
from qtvcp import logger

log = logger.getLogger(__name__)
# Set the log level for this module
# log.setLevel(logger.INFO) # One of DEBUG, INFO, WARNING, ERROR, CRITICAL

STATUS = Status()
INFO = Info()


class MachineLogger():
    def __init__(self):
        STATUS.connect('update-machine-log', self.log_it)
        self.mlp = os.path.expanduser(INFO.MACHINE_LOG_HISTORY_PATH)

    def log_it(self, w, message, option=None):
        if option == 'DELETE':
            self.delete_log()
            return
        try:
            message = message.rstrip('\n')
            if option == 'TIME':
                self.log_message_time(message)
            elif option == 'DATE':
                self.log_message_date(message)
            elif option == 'INITIAL':
                self.initial_greeting()
            else:
                self.log_message(message)
        except Exception as e:
            log.exception('log_it function: {}'.format(e))

    def initial_greeting(self):
        try:
            timestamp = time.strftime("%a, %b %d %Y %X ---")
            fp = open(self.mlp, 'a')

            # fp.write(""" $$$$$$\  $$$$$$$$\ """)
            # fp.write('\n')
            # fp.write('''$$  __$$\ \__$$  __|''')
            # fp.write('\n')
            # fp.write('$$ /  $$ |   $$ |  $$$$$$$\  $$$$$$$\  $$$$$$\   $$$$$$\   $$$$$$\  $$$$$$$\  ')
            # fp.write('\n')
            # fp.write('$$ |  $$ |   $$ | $$  _____|$$  _____|$$  __$$\ $$  __$$\ $$  __$$\ $$  __$$\ ')
            # fp.write('\n')
            # fp.write('$$ |  $$ |   $$ | \$$$$$$\  $$ /      $$ |  \__|$$$$$$$$ |$$$$$$$$ |$$ |  $$ |')
            # fp.write('\n')
            # fp.write('$$ $$\$$ |   $$ |  \____$$\ $$ |      $$ |      $$   ____|$$   ____|$$ |  $$ |')
            # fp.write('\n')
            # fp.write('\$$$$$$ /    $$ | $$$$$$$  |\$$$$$$$\ $$ |      \$$$$$$$\ \$$$$$$$\ $$ |  $$ |')
            # fp.write('\n')
            # fp.write(' \___$$$\    \__| \_______/  \_______|\__|       \_______| \_______|\__|  \__|')
            # fp.write('\n')
            # fp.write('     \___|        ')

            fp.write('--- QtVCP Screen Started on: ' + timestamp + "\n")
            fp.close()
        except:
            log.warning('machine log history: path valid?')

    def log_message_time(self, message):
        try:
            timestamp = time.strftime("%a%d %H:%M: ")
            fp = open(self.mlp, 'a')
            fp.write(timestamp + message + "\n")
            fp.close()
        except:
            log.warning('machine log history: path valid?: {}'.format(fp))
        STATUS.emit('machine-log-changed')

    def log_message_date(self, message):
        try:
            timestamp = time.strftime("%a, %b %d %Y %X: ")
            fp = open(self.mlp, 'a')
            fp.write(timestamp + message + "\n")
            fp.close()
        except:
            log.warning('machine log history: path valid?')
        STATUS.emit('machine-log-changed')

    def log_message(self, message):
        try:
            fp = open(self.mlp, 'a')
            fp.write(message + "\n")
            fp.close()
        except:
            log.warning('machine log history: path valid?')
        STATUS.emit('machine-log-changed')

    def delete_log(self):
        fp = open(self.mlp, 'w')
        fp.write('')
        fp.close()
        STATUS.emit('machine-log-changed')