forked from OSchip/llvm-project
Fix a problem where ValueObjectVariable was not correctly setting its 'has value changed' flag for scalar valued variables. This fixes rdar://17851144
llvm-svn: 221298
This commit is contained in:
parent
0b622f1d64
commit
0eb0ec298c
|
@ -248,6 +248,8 @@ ValueObjectVariable::UpdateValue ()
|
||||||
Value value(m_value);
|
Value value(m_value);
|
||||||
value.SetContext(Value::eContextTypeVariable, variable);
|
value.SetContext(Value::eContextTypeVariable, variable);
|
||||||
m_error = value.GetValueAsData(&exe_ctx, m_data, 0, GetModule().get());
|
m_error = value.GetValueAsData(&exe_ctx, m_data, 0, GetModule().get());
|
||||||
|
|
||||||
|
SetValueDidChange (value_type != old_value.GetValueType() || m_value.GetScalar() != old_value.GetScalar());
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,7 @@
|
||||||
|
LEVEL = ../../make
|
||||||
|
|
||||||
|
C_SOURCES := main.c
|
||||||
|
# See TestHelloWorld.py, which specifies the executable name with a dictionary.
|
||||||
|
EXE := hello_world
|
||||||
|
|
||||||
|
include $(LEVEL)/Makefile.rules
|
|
@ -0,0 +1,68 @@
|
||||||
|
"""Test SBValue::GetValueDidChange"""
|
||||||
|
|
||||||
|
import os, sys, time
|
||||||
|
import unittest2
|
||||||
|
import lldb
|
||||||
|
import time
|
||||||
|
from lldbtest import *
|
||||||
|
|
||||||
|
class HelloWorldTestCase(TestBase):
|
||||||
|
|
||||||
|
mydir = TestBase.compute_mydir(__file__)
|
||||||
|
|
||||||
|
@unittest2.skipUnless(sys.platform.startswith("darwin"), "requires Darwin")
|
||||||
|
@python_api_test
|
||||||
|
@dsym_test
|
||||||
|
def test_with_dsym_and_process_launch_api(self):
|
||||||
|
"""Test SBValue::GetValueDidChange"""
|
||||||
|
self.buildDsym(dictionary=self.d)
|
||||||
|
self.setTearDownCleanup(dictionary=self.d)
|
||||||
|
self.do_test()
|
||||||
|
|
||||||
|
@python_api_test
|
||||||
|
@dwarf_test
|
||||||
|
def test_with_dwarf_and_process_launch_api(self):
|
||||||
|
"""Test SBValue::GetValueDidChange"""
|
||||||
|
self.buildDwarf(dictionary=self.d)
|
||||||
|
self.setTearDownCleanup(dictionary=self.d)
|
||||||
|
self.do_test()
|
||||||
|
|
||||||
|
def setUp(self):
|
||||||
|
# Call super's setUp().
|
||||||
|
TestBase.setUp(self)
|
||||||
|
# Get the full path to our executable to be attached/debugged.
|
||||||
|
self.exe = os.path.join(os.getcwd(), self.testMethodName)
|
||||||
|
self.d = {'EXE': self.testMethodName}
|
||||||
|
|
||||||
|
def do_test(self):
|
||||||
|
"""Create target, breakpoint, launch a process, and then kill it."""
|
||||||
|
|
||||||
|
target = self.dbg.CreateTarget(self.exe)
|
||||||
|
|
||||||
|
breakpoint = target.BreakpointCreateBySourceRegex("break here", lldb.SBFileSpec("main.c"))
|
||||||
|
|
||||||
|
self.runCmd("run", RUN_SUCCEEDED)
|
||||||
|
|
||||||
|
# The stop reason of the thread should be breakpoint.
|
||||||
|
self.expect("thread list", STOPPED_DUE_TO_BREAKPOINT,
|
||||||
|
substrs = ['stopped',
|
||||||
|
'stop reason = breakpoint'])
|
||||||
|
|
||||||
|
i = self.frame().FindVariable("i")
|
||||||
|
i_val = i.GetValueAsUnsigned(0)
|
||||||
|
|
||||||
|
if self.TraceOn(): self.runCmd("frame variable")
|
||||||
|
|
||||||
|
self.runCmd("continue")
|
||||||
|
|
||||||
|
if self.TraceOn(): self.runCmd("frame variable")
|
||||||
|
|
||||||
|
self.assertTrue(i_val != i.GetValueAsUnsigned(0), "GetValue() is saying a lie")
|
||||||
|
self.assertTrue(i.GetValueDidChange(), "GetValueDidChange() is saying a lie")
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
import atexit
|
||||||
|
lldb.SBDebugger.Initialize()
|
||||||
|
atexit.register(lambda: lldb.SBDebugger.Terminate())
|
||||||
|
unittest2.main()
|
|
@ -0,0 +1,9 @@
|
||||||
|
int main() {
|
||||||
|
int i = 0;
|
||||||
|
for (int j = 3; j < 20; j++)
|
||||||
|
{
|
||||||
|
i += j;
|
||||||
|
i = i - 1; // break here
|
||||||
|
}
|
||||||
|
return i;
|
||||||
|
}
|
Loading…
Reference in New Issue