You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
40 lines
1.1 KiB
40 lines
1.1 KiB
# 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}
|