1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
|
# 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
"""A Command that tells dexter to set a breakpoint which, after hitting,
signals that the debugger should 'continue' until another is hit. Continuing
out of a function being stepped through with DexStepFunction is well defined:
stepping will resume in other functions tracked further down the stacktrace.
NOTE: Only supported for DAP-based debuggers.
"""
from dex.command.CommandBase import CommandBase
class DexContinue(CommandBase):
def __init__(self, *args, **kwargs):
# DexContinue(*[expr, *values], **from_line[, **to_line, **hit_count])
# Optional positional args: expr, values.
if len(args) == 0:
self.expression = None
self.values = []
elif len(args) == 1:
raise TypeError("expected 0 or at least 2 positional arguments")
else:
self.expression = args[0]
self.values = [str(arg) for arg in args[1:]]
# Required keyword arg: from_line.
try:
self.from_line = kwargs.pop("from_line")
except:
raise TypeError("Missing from_line argument")
# Optional conditional args: to_line, hit_count.
self.to_line = kwargs.pop("to_line", None)
self.hit_count = kwargs.pop("hit_count", None)
if kwargs:
raise TypeError("unexpected named args: {}".format(", ".join(kwargs)))
super(DexContinue, self).__init__()
def eval(self):
raise NotImplementedError("DexContinue commands cannot be evaled.")
@staticmethod
def get_name():
return __class__.__name__
@staticmethod
def get_subcommands() -> dict:
return None
|