Onionr/src/logger/raw.py

55 lines
1.7 KiB
Python
Raw Normal View History

2020-04-15 03:40:31 +00:00
"""Onionr - Private P2P Communication.
2019-07-14 00:29:33 +00:00
2020-04-15 03:40:31 +00:00
Output raw data to file or terminal
"""
import sys
import os
from . import settings, colors
"""
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
2019-07-14 00:29:33 +00:00
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
2019-07-14 00:29:33 +00:00
You should have received a copy of the GNU General Public License
along with this program. If not, see <https://www.gnu.org/licenses/>.
2020-04-15 03:40:31 +00:00
"""
2019-07-14 00:29:33 +00:00
colors = colors.Colors
2020-04-15 03:40:31 +00:00
2019-07-14 00:29:33 +00:00
def raw(data, fd = sys.stdout, terminal = False):
2020-04-15 03:40:31 +00:00
"""
2019-07-14 00:29:33 +00:00
Outputs raw data to console without formatting
2020-04-15 03:40:31 +00:00
"""
2019-07-14 00:29:33 +00:00
if terminal and (settings.get_settings() & settings.OUTPUT_TO_CONSOLE):
try:
ts = fd.write('%s\n' % data)
except OSError:
pass
if settings.get_settings() & settings.OUTPUT_TO_FILE:
2019-08-07 02:50:15 +00:00
fdata = ''
2019-07-14 00:29:33 +00:00
try:
2020-04-15 03:40:31 +00:00
for _ in range(5):
try:
with open(settings._outputfile, 'r') as file:
fdata = file.read()
except UnicodeDecodeError:
pass
else:
break
2019-08-07 02:50:15 +00:00
except FileNotFoundError:
pass
fdata = fdata + '\n' + data
fdata = fdata.split('\n')
if len(fdata) >= settings.MAX_LOG_FILE_LINES:
fdata.pop(0)
fdata = '\n'.join(fdata)
with open(settings._outputfile, 'w') as file:
2020-04-15 03:40:31 +00:00
file.write(fdata)