summaryrefslogtreecommitdiff
path: root/cross-project-tests/debuginfo-tests/dexter/dex/command/commands/DexContinue.py
diff options
context:
space:
mode:
authorMingming Liu <mingmingl@google.com>2025-09-10 15:25:31 -0700
committerGitHub <noreply@github.com>2025-09-10 15:25:31 -0700
commit1417dafa1db9cb1b2b09438aa9f53ea5ab6e36e2 (patch)
tree57f4b1f313c8cf74eed8819870f39c36ea263c68 /cross-project-tests/debuginfo-tests/dexter/dex/command/commands/DexContinue.py
parent898b813bc8a6d0276bf0f4769f5f2f64b34e632d (diff)
parentb8cefcb601ddaa18482555c4ff363c01a270c2fe (diff)
Merge branch 'main' into users/mingmingl-llvm/samplefdo-profile-formatusers/mingmingl-llvm/samplefdo-profile-format
Diffstat (limited to 'cross-project-tests/debuginfo-tests/dexter/dex/command/commands/DexContinue.py')
-rw-r--r--cross-project-tests/debuginfo-tests/dexter/dex/command/commands/DexContinue.py55
1 files changed, 55 insertions, 0 deletions
diff --git a/cross-project-tests/debuginfo-tests/dexter/dex/command/commands/DexContinue.py b/cross-project-tests/debuginfo-tests/dexter/dex/command/commands/DexContinue.py
new file mode 100644
index 000000000000..113f34bedd13
--- /dev/null
+++ b/cross-project-tests/debuginfo-tests/dexter/dex/command/commands/DexContinue.py
@@ -0,0 +1,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