summaryrefslogtreecommitdiff
path: root/cross-project-tests/debuginfo-tests/dexter/dex/command/commands/DexContinue.py
blob: 113f34bedd1312c7aaba32e7bf1a933374cd87d2 (plain)
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