moved a bunch of garbage (things that have nothing to do in root) to _trash

This commit is contained in:
mia 2025-06-15 22:42:02 +02:00
parent d094982b2c
commit 3226ed29ec
2610 changed files with 0 additions and 0 deletions

View file

@ -1,178 +0,0 @@
# Copyright (c) 2010-2024 Emmanuel Blot <emmanuel.blot@free.fr>
# Copyright (c) 2008-2016, Neotion
# All rights reserved.
#
# SPDX-License-Identifier: BSD-3-Clause
# pylint: disable=broad-except
# pylint: disable=invalid-name
# pylint: disable=missing-function-docstring
# pylint: disable=missing-module-docstring
# pylint: disable=no-member
# pylint: disable=super-with-arguments
from sys import stderr
from time import time
from ..misc import hexdump
__all__ = ['SerialLogger']
class SerialLogger:
"""Serial port wrapper to log input/output data to a log file.
"""
def __init__(self, *args, **kwargs):
logpath = kwargs.pop('logfile', None)
if not logpath:
raise ValueError('Missing logfile')
try:
# pylint: disable=consider-using-with
self._logger = open(logpath, "wt")
except IOError as exc:
print(f'Cannot log data to {logpath}: {exc}', file=stderr)
self._last = time()
self._log_init(*args, **kwargs)
super(SerialLogger, self).__init__(*args, **kwargs)
def open(self,):
self._log_open()
super(SerialLogger, self).open()
def close(self):
self._log_close()
self._logger.close()
super(SerialLogger, self).close()
def read(self, size=1):
data = super(SerialLogger, self).read(size)
self._log_read(data)
return data
def write(self, data):
if data:
self._log_write(data)
super(SerialLogger, self).write(data)
def flush(self):
self._log_flush()
super(SerialLogger, self).flush()
def reset_input_buffer(self):
self._log_reset('I')
super(SerialLogger, self).reset_input_buffer()
def reset_output_buffer(self):
self._log_reset('O')
super(SerialLogger, self).reset_output_buffer()
def send_break(self, duration=0.25):
self._log_signal('BREAK', f'for {duration:.3f}')
super(SerialLogger, self).send_break()
def _update_break_state(self):
self._log_signal('BREAK', self._break_state)
super(SerialLogger, self)._update_break_state()
def _update_rts_state(self):
self._log_signal('RTS', self._rts_state)
super(SerialLogger, self)._update_rts_state()
def _update_dtr_state(self):
self._log_signal('DTR', self._dtr_state)
super(SerialLogger, self)._update_dtr_state()
@property
def cts(self):
level = super(SerialLogger, self).cts
self._log_signal('CTS', level)
return level
@property
def dsr(self):
level = super(SerialLogger, self).dsr
self._log_signal('DSR', level)
return level
@property
def ri(self):
level = super(SerialLogger, self).ri
self._log_signal('RI', level)
return level
@property
def cd(self):
level = super(SerialLogger, self).cd
self._log_signal('CD', level)
return level
def in_waiting(self):
count = super(SerialLogger, self).in_waiting()
self._log_waiting(count)
return count
def _print(self, header, string=None):
if self._logger:
now = time()
delta = (now-self._last)*1000
self._last = now
print(f'{header} ({delta:3.3f} ms):\n{string or ""}',
file=self._logger)
self._logger.flush()
def _log_init(self, *args, **kwargs):
try:
sargs = ', '.join(args)
skwargs = ', '.join({f'{it[0]}={it[1]}' for it in kwargs.items()})
self._print('NEW', f' args: {sargs} {skwargs}')
except Exception as exc:
print(f'Cannot log init ({exc})', file=stderr)
def _log_open(self):
try:
self._print('OPEN')
except Exception as exc:
print(f'Cannot log open ({exc})', file=stderr)
def _log_close(self):
try:
self._print('CLOSE')
except Exception as exc:
print(f'Cannot log close ({exc})', file=stderr)
def _log_read(self, data):
try:
self._print('READ', hexdump(data))
except Exception as exc:
print(f'Cannot log input data ({exc})', file=stderr)
def _log_write(self, data):
try:
self._print('WRITE', hexdump(data))
except Exception as exc:
print(f'Cannot log output data ({exc})', data, file=stderr)
def _log_flush(self):
try:
self._print('FLUSH')
except Exception as exc:
print(f'Cannot log flush action ({exc})', file=stderr)
def _log_reset(self, type_):
try:
self._print('RESET BUFFER', type_)
except Exception as exc:
print(f'Cannot log reset buffer ({exc})', file=stderr)
def _log_waiting(self, count):
try:
self._print('INWAITING', f'{count}')
except Exception as exc:
print(f'Cannot log inwaiting ({exc})', file=stderr)
def _log_signal(self, name, value):
try:
self._print(name.upper(), str(value))
except Exception as exc:
print(f'Cannot log {name} ({exc})', file=stderr)