2019-04-19 22:20:27 +00:00
|
|
|
# Copyright 2019 Ram Rachum.
|
|
|
|
# This program is distributed under the MIT license.
|
|
|
|
|
2019-04-21 17:54:55 +00:00
|
|
|
from future import standard_library
|
|
|
|
standard_library.install_aliases()
|
2019-04-19 22:20:27 +00:00
|
|
|
import sys
|
|
|
|
import os
|
|
|
|
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)
|
2019-04-21 13:53:18 +00:00
|
|
|
elif isinstance(output, (pycompat.PathLike, str)):
|
2019-04-19 22:20:27 +00:00
|
|
|
def write(s):
|
2019-04-21 17:54:55 +00:00
|
|
|
with open(output_path, 'a') as output_file:
|
2019-04-19 22:20:27 +00:00
|
|
|
output_file.write(s)
|
|
|
|
else:
|
|
|
|
assert isinstance(output, utils.WritableStream)
|
|
|
|
def write(s):
|
|
|
|
output.write(s)
|
|
|
|
|
|
|
|
return write
|
|
|
|
|
|
|
|
|
|
|
|
|
2019-04-21 18:35:43 +00:00
|
|
|
def snoop(output=None, variables=(), depth=1, prefix=''):
|
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,
|
2019-04-21 18:35:43 +00:00
|
|
|
depth=depth, prefix=prefix):
|
2019-04-19 22:20:27 +00:00
|
|
|
return function(*args, **kwargs)
|
|
|
|
|
|
|
|
return decorate
|
|
|
|
|
|
|
|
|
|
|
|
|