Files
clang-p2996/lldb/test/API/commands/target/stop-hooks/stop_hook.py
Jonas Devlieghere 2238dcc393 [NFC][Py Reformat] Reformat python files in lldb
This is an ongoing series of commits that are reformatting our Python
code. Reformatting is done with `black` (23.1.0).

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.

RFC: https://discourse.llvm.org/t/rfc-document-and-standardize-python-code-style

Differential revision: https://reviews.llvm.org/D151460
2023-05-25 12:54:09 -07:00

51 lines
1.6 KiB
Python

import lldb
class stop_handler:
def __init__(self, target, extra_args, dict):
self.extra_args = extra_args
self.target = target
self.counter = 0
ret_val = self.extra_args.GetValueForKey("return_false")
if ret_val:
self.ret_val = False
else:
self.ret_val = True
def handle_stop(self, exe_ctx, stream):
self.counter += 1
stream.Print("I have stopped %d times.\n" % (self.counter))
increment = 1
value = self.extra_args.GetValueForKey("increment")
if value:
increment = value.GetUnsignedIntegerValue()
else:
stream.Print("Could not find increment in extra_args\n")
frame = exe_ctx.GetFrame()
expression = "g_var += %d" % (increment)
expr_result = frame.EvaluateExpression(expression)
if not expr_result.GetError().Success():
stream.Print(
"Error running expression: %s" % (expr_result.GetError().GetCString())
)
value = exe_ctx.target.FindFirstGlobalVariable("g_var")
if not value.IsValid():
stream.Print("Didn't get a valid value for g_var.")
else:
int_val = value.GetValueAsUnsigned()
stream.Print("Returning value: %d from handle_stop.\n" % (self.ret_val))
return self.ret_val
class bad_handle_stop:
def __init__(self, target, extra_args, dict):
print("I am okay")
def handle_stop(self):
print("I am bad")
class no_handle_stop:
def __init__(self, target, extra_args, dict):
print("I am okay")