master
Harshad Sharma 7 years ago
parent 7072b4077d
commit 9cb7ac4588

@ -3,16 +3,19 @@
import os import os
import tempfile import tempfile
HTML_TEMPLATE = """\
"""
log_file_path = './qutescript.log' log_file_path = './qutescript.log'
def write_log(message, file_path=None): def write_log(message, file_path=None, console=False):
if console:
print('***', message) print('***', message)
file_path = file_path or log_file_path file_path = file_path or log_file_path
file_path = os.path.abspath(os.path.expanduser(file_path)) file_path = os.path.abspath(os.path.expanduser(file_path))
record = ['***' + message, '\n', '\n']
with open(file_path, 'a') as logfile: with open(file_path, 'a') as logfile:
logfile.writelines(record) logfile.write('*** {}\n\n'.format(message))
def normalize_prefix(prefix): def normalize_prefix(prefix):
@ -23,21 +26,24 @@ def normalize_prefix(prefix):
return prefix return prefix
def log_to_browser(*messages, prefix: str = None): def log_to_browser(*messages, prefix: str = None, console=True):
""" """
Write messages to logs and a temporary file, Write messages to logs and a temporary file,
Attempt to open the file through FIFO in the browser. Attempt to open the file through FIFO in the browser.
""" """
[write_log(msg) for msg in messages] [write_log(msg, console=console) for msg in messages]
send_to_browser('\n'.join(messages), prefix=prefix)
def send_to_browser(text, prefix: str = None):
fifo = os.getenv('QUTE_FIFO') fifo = os.getenv('QUTE_FIFO')
if not fifo: if not fifo:
return return
out_lines = ['<html><body><pre>'] + ['<p>{}</p>'.format(m or '&nbsp;') for m in messages]
prefix = normalize_prefix(prefix) prefix = normalize_prefix(prefix)
prefix = 'qutescript_{}'.format((prefix or '')) prefix = 'qutescript_{}'.format((prefix or ''))
with tempfile.NamedTemporaryFile(mode='w', prefix=prefix, suffix='.html', delete=False) as trace_file: with tempfile.NamedTemporaryFile(mode='w', prefix=prefix, suffix='.html', delete=False) as out_file:
trace_file.writelines(out_lines) out_file.writelines(HTML_TEMPLATE.format(text))
print('***', trace_file.name)
with open(fifo, 'w') as fifo_file: with open(fifo, 'w') as fifo_file:
fifo_file.write('open -t file://{}'.format( fifo_file.write('open -t file://{}'.format(
os.path.abspath(trace_file.name))) os.path.abspath(out_file.name)))

Loading…
Cancel
Save