Index: packages/Python/lldbsuite/test/functionalities/stop-hooks/Makefile =================================================================== --- packages/Python/lldbsuite/test/functionalities/stop-hooks/Makefile +++ packages/Python/lldbsuite/test/functionalities/stop-hooks/Makefile @@ -0,0 +1,6 @@ +LEVEL = ../../make + +C_SOURCES := main.c +CFLAGS_EXTRAS += -std=c99 + +include $(LEVEL)/Makefile.rules Index: packages/Python/lldbsuite/test/functionalities/stop-hooks/TestStopHooks.py =================================================================== --- packages/Python/lldbsuite/test/functionalities/stop-hooks/TestStopHooks.py +++ packages/Python/lldbsuite/test/functionalities/stop-hooks/TestStopHooks.py @@ -0,0 +1,45 @@ +""" +Test that stop hooks trigger on "step-out" +""" + +from __future__ import print_function + + +import lldb +import lldbsuite.test.lldbutil as lldbutil +from lldbsuite.test.lldbtest import * + + +class TestStopHooks(TestBase): + + mydir = TestBase.compute_mydir(__file__) + + # If your test case doesn't stress debug info, the + # set this to true. That way it won't be run once for + # each debug info format. + NO_DEBUG_INFO_TESTCASE = True + + def test_stop_hooks_step_out(self): + """Test that stop hooks fire on step-out.""" + self.build() + self.main_source_file = lldb.SBFileSpec("main.c") + self.step_out_test() + + def setUp(self): + # Call super's setUp(). + TestBase.setUp(self) + + def step_out_test(self): + (target, process, thread, bkpt) = lldbutil.run_to_source_breakpoint(self, + "Set a breakpoint here", self.main_source_file) + + interp = self.dbg.GetCommandInterpreter() + result = lldb.SBCommandReturnObject() + interp.HandleCommand("target stop-hook add -o 'expr g_var++'", result) + self.assertTrue(result.Succeeded, "Set the target stop hook") + thread.StepOut() + var = target.FindFirstGlobalVariable("g_var") + self.assertTrue(var.IsValid()) + self.assertEqual(var.GetValueAsUnsigned(), 1, "Updated g_var") + + Index: packages/Python/lldbsuite/test/functionalities/stop-hooks/main.c =================================================================== --- packages/Python/lldbsuite/test/functionalities/stop-hooks/main.c +++ packages/Python/lldbsuite/test/functionalities/stop-hooks/main.c @@ -0,0 +1,14 @@ +#include + +static int g_var = 0; + +int step_out_of_me() +{ + return g_var; // Set a breakpoint here and step out. +} + +int +main() +{ + return step_out_of_me(); +} Index: source/Target/StopInfo.cpp =================================================================== --- source/Target/StopInfo.cpp +++ source/Target/StopInfo.cpp @@ -547,6 +547,7 @@ // find the appropriate stop info, which should be the stop info // related to the completed plan thread_sp->ResetStopInfo(); + thread_sp->SetStopInfo(thread_sp->GetStopInfo()); } LLDB_LOGF(log,