2019-04-19 22:20:27 +00:00
|
|
|
# Copyright 2019 Ram Rachum.
|
|
|
|
# This program is distributed under the MIT license.
|
|
|
|
|
|
|
|
import sys
|
|
|
|
import os
|
|
|
|
import pathlib
|
|
|
|
import inspect
|
|
|
|
import types
|
|
|
|
import datetime as datetime_module
|
|
|
|
import re
|
|
|
|
import collections
|
|
|
|
|
|
|
|
import decorator
|
|
|
|
|
|
|
|
from . import utils
|
2019-04-21 13:53:18 +00:00
|
|
|
from . import pycompat
|
|
|
|
from .tracer import Tracer
|
2019-04-19 22:20:27 +00:00
|
|
|
|
|
|
|
|
2019-04-21 13:53:18 +00:00
|
|
|
def get_write_function(output):
|
2019-04-19 22:20:27 +00:00
|
|
|
if output is None:
|
|
|
|
def write(s):
|
|
|
|
stderr = sys.stderr
|
|
|
|
stderr.write(s)
|
|
|
|
stderr.write('\n')
|
2019-04-21 13:53:18 +00:00
|
|
|
elif isinstance(output, (pycompat.PathLike, str)):
|
2019-04-19 22:20:27 +00:00
|
|
|
output_path = pathlib.Path(output)
|
|
|
|
def write(s):
|
|
|
|
with output_path.open('a') as output_file:
|
|
|
|
output_file.write(s)
|
|
|
|
output_file.write('\n')
|
|
|
|
else:
|
|
|
|
assert isinstance(output, utils.WritableStream)
|
|
|
|
def write(s):
|
|
|
|
output.write(s)
|
|
|
|
output.write('\n')
|
|
|
|
|
|
|
|
return write
|
|
|
|
|
|
|
|
|
|
|
|
|
2019-04-21 13:53:18 +00:00
|
|
|
def snoop(output=None, *, variables=(), depth=1):
|
2019-04-19 22:20:27 +00:00
|
|
|
write = get_write_function(output)
|
|
|
|
@decorator.decorator
|
2019-04-21 13:53:18 +00:00
|
|
|
def decorate(function, *args, **kwargs):
|
2019-04-19 22:20:27 +00:00
|
|
|
target_code_object = function.__code__
|
2019-04-21 13:53:18 +00:00
|
|
|
with Tracer(target_code_object=target_code_object,
|
|
|
|
write=write, variables=variables,
|
|
|
|
depth=depth):
|
2019-04-19 22:20:27 +00:00
|
|
|
return function(*args, **kwargs)
|
|
|
|
|
|
|
|
return decorate
|
|
|
|
|
|
|
|
|
|
|
|
|