This is an ongoing series of commits that are reformatting our Python code. This catches the last of the python files to reformat. Since they where so few I bunched them together. Reformatting is done with `black`. If you end up having problems merging this commit because you have made changes to a python file, the best way to handle that is to run git checkout --ours <yourfile> and then reformat it with black. If you run into any problems, post to discourse about it and we will try to help. RFC Thread below: https://discourse.llvm.org/t/rfc-document-and-standardize-python-code-style Reviewed By: jhenderson, #libc, Mordante, sivachandra Differential Revision: https://reviews.llvm.org/D150784
40 lines
1.1 KiB
Python
40 lines
1.1 KiB
Python
# DExTer : Debugging Experience Tester
|
|
# ~~~~~~ ~ ~~ ~ ~~
|
|
#
|
|
# Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
# See https://llvm.org/LICENSE.txt for license information.
|
|
# SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
|
"""Command to instruct the debugger to inspect the value of some set of
|
|
expressions on the current source line.
|
|
"""
|
|
|
|
from dex.command.CommandBase import CommandBase
|
|
|
|
|
|
class DexWatch(CommandBase):
|
|
"""[Deprecated] Evaluate each given `expression` when the debugger steps onto the
|
|
line this command is found on
|
|
|
|
DexWatch(*expressions)
|
|
|
|
See Commands.md for more info.
|
|
"""
|
|
|
|
def __init__(self, *args):
|
|
if not args:
|
|
raise TypeError("expected some arguments")
|
|
|
|
for arg in args:
|
|
if not isinstance(arg, str):
|
|
raise TypeError("invalid argument type")
|
|
|
|
self._args = args
|
|
super(DexWatch, self).__init__()
|
|
|
|
@staticmethod
|
|
def get_name():
|
|
return __class__.__name__
|
|
|
|
def eval(self, debugger):
|
|
return {arg: debugger.evaluate_expression(arg) for arg in self._args}
|