Source code for campy.util.recursion

"""File:
"""
import traceback as _traceback

# Default indentation is four spaces.
_INDENT = '    '

[docs]def get_indent(indenter=_INDENT): return count_depth() * indenter
[docs]def count_depth(): # NOTE: This doesn't work well with mutual recursion. stack_frames = _traceback.extract_stack() # stack_frames = stack_frames[:-1-parent] # Pop myself off the stack depth_fn = None # stack_frames[-1][2] count = 0 for filename, lineno, fn_name, text in reversed(stack_frames): # 'wrapper' is the default wrapped name for lru_cache, but it doesn't # whitelist student functions named wrapper either. if fn_name in ('get_indent', 'count_depth', 'wrapper'): continue if not depth_fn: depth_fn = fn_name continue elif fn_name == depth_fn: count += 1 else: break return count