[Lldb-commits] [lldb] r128695 - in /lldb/trunk: include/lldb/API/SBModule.h source/API/SBModule.cpp test/python_api/function_symbol/TestSymbolAPI.py
Johnny Chen
johnny.chen at apple.com
Thu Mar 31 17:35:55 PDT 2011
Author: johnny
Date: Thu Mar 31 19:35:55 2011
New Revision: 128695
URL: http://llvm.org/viewvc/llvm-project?rev=128695&view=rev
Log:
Add TestSymbolAPI.py to test the newly added SBSymbol and SBAddress APIs:
lldb::SymbolType SBSymbol::GetType();
lldb::SectionType SBAddress::GetSectionType ();
lldb::SBModule SBAddress::GetModule ();
Also add an lldb::SBModule::GetUUIDString() API which is easier for Python
to work with in the test script.
Added:
lldb/trunk/test/python_api/function_symbol/TestSymbolAPI.py
Modified:
lldb/trunk/include/lldb/API/SBModule.h
lldb/trunk/source/API/SBModule.cpp
Modified: lldb/trunk/include/lldb/API/SBModule.h
URL: http://llvm.org/viewvc/llvm-project/lldb/trunk/include/lldb/API/SBModule.h?rev=128695&r1=128694&r2=128695&view=diff
==============================================================================
--- lldb/trunk/include/lldb/API/SBModule.h (original)
+++ lldb/trunk/include/lldb/API/SBModule.h Thu Mar 31 19:35:55 2011
@@ -39,6 +39,9 @@
const uint8_t *
GetUUIDBytes () const;
+ const char *
+ GetUUIDString () const;
+
#ifndef SWIG
bool
operator == (const lldb::SBModule &rhs) const;
Modified: lldb/trunk/source/API/SBModule.cpp
URL: http://llvm.org/viewvc/llvm-project/lldb/trunk/source/API/SBModule.cpp?rev=128695&r1=128694&r2=128695&view=diff
==============================================================================
--- lldb/trunk/source/API/SBModule.cpp (original)
+++ lldb/trunk/source/API/SBModule.cpp Thu Mar 31 19:35:55 2011
@@ -95,6 +95,31 @@
}
+const char *
+SBModule::GetUUIDString () const
+{
+ LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
+
+ static char uuid_string[80];
+ const char * uuid_c_string = NULL;
+ if (m_opaque_sp)
+ uuid_c_string = (const char *)m_opaque_sp->GetUUID().GetAsCString(uuid_string, sizeof(uuid_string));
+
+ if (log)
+ {
+ if (uuid_c_string)
+ {
+ StreamString s;
+ m_opaque_sp->GetUUID().Dump (&s);
+ log->Printf ("SBModule(%p)::GetUUIDString () => %s", m_opaque_sp.get(), s.GetData());
+ }
+ else
+ log->Printf ("SBModule(%p)::GetUUIDString () => NULL", m_opaque_sp.get());
+ }
+ return uuid_c_string;
+}
+
+
bool
SBModule::operator == (const SBModule &rhs) const
{
Added: lldb/trunk/test/python_api/function_symbol/TestSymbolAPI.py
URL: http://llvm.org/viewvc/llvm-project/lldb/trunk/test/python_api/function_symbol/TestSymbolAPI.py?rev=128695&view=auto
==============================================================================
--- lldb/trunk/test/python_api/function_symbol/TestSymbolAPI.py (added)
+++ lldb/trunk/test/python_api/function_symbol/TestSymbolAPI.py Thu Mar 31 19:35:55 2011
@@ -0,0 +1,96 @@
+"""
+Test newly added SBSymbol and SBAddress APIs.
+"""
+
+import os, time
+import re
+import unittest2
+import lldb, lldbutil
+from lldbtest import *
+
+class SymbolAPITestCase(TestBase):
+
+ mydir = os.path.join("python_api", "function_symbol")
+
+ @unittest2.skipUnless(sys.platform.startswith("darwin"), "requires Darwin")
+ @python_api_test
+ def test_with_dsym(self):
+ """Exercise some SBSymbol and SBAddress APIs."""
+ self.buildDsym()
+ self.symbol_and_address_api()
+
+ @python_api_test
+ def test_with_dwarf(self):
+ """Exercise some SBSymbol and SBAddress APIs."""
+ self.buildDwarf()
+ self.symbol_and_address_api()
+
+ def setUp(self):
+ # Call super's setUp().
+ TestBase.setUp(self)
+ # Find the line number to of function 'c'.
+ self.line1 = line_number('main.c', '// Find the line number for breakpoint 1 here.')
+ self.line2 = line_number('main.c', '// Find the line number for breakpoint 2 here.')
+
+ def symbol_and_address_api(self):
+ """Exercise some SBSymbol and SBAddress APIs."""
+ exe = os.path.join(os.getcwd(), "a.out")
+
+ # Create a target by the debugger.
+ target = self.dbg.CreateTarget(exe)
+ self.assertTrue(target.IsValid(), VALID_TARGET)
+
+ # Now create the two breakpoints inside function 'a'.
+ breakpoint1 = target.BreakpointCreateByLocation('main.c', self.line1)
+ breakpoint2 = target.BreakpointCreateByLocation('main.c', self.line2)
+ #print "breakpoint1:", breakpoint1
+ #print "breakpoint2:", breakpoint2
+ self.assertTrue(breakpoint1.IsValid() and
+ breakpoint1.GetNumLocations() == 1,
+ VALID_BREAKPOINT)
+ self.assertTrue(breakpoint2.IsValid() and
+ breakpoint2.GetNumLocations() == 1,
+ VALID_BREAKPOINT)
+
+ # Now launch the process, and do not stop at entry point.
+ error = lldb.SBError()
+ self.process = target.LaunchSimple (None, None, os.getcwd())
+
+ self.process = target.GetProcess()
+ self.assertTrue(self.process.IsValid(), PROCESS_IS_VALID)
+
+ # Frame #0 should be on self.line1.
+ self.assertTrue(self.process.GetState() == lldb.eStateStopped)
+ thread = lldbutil.get_stopped_thread(self.process, lldb.eStopReasonBreakpoint)
+ self.assertTrue(thread != None, "There should be a thread stopped due to breakpoint condition")
+ frame0 = thread.GetFrameAtIndex(0)
+ symbol_line1 = frame0.GetSymbol()
+ # We should have a symbol type of code.
+ self.assertTrue(symbol_line1.GetType() == lldb.eSymbolTypeCode)
+ addr_line1 = symbol_line1.GetStartAddress()
+ # And a section type of code, too.
+ self.assertTrue(addr_line1.GetSectionType() == lldb.eSectionTypeCode)
+
+ # Continue the inferior, the breakpoint 2 should be hit.
+ self.process.Continue()
+ self.assertTrue(self.process.GetState() == lldb.eStateStopped)
+ thread = lldbutil.get_stopped_thread(self.process, lldb.eStopReasonBreakpoint)
+ self.assertTrue(thread != None, "There should be a thread stopped due to breakpoint condition")
+ frame0 = thread.GetFrameAtIndex(0)
+ symbol_line2 = frame0.GetSymbol()
+ # We should have a symbol type of code.
+ self.assertTrue(symbol_line2.GetType() == lldb.eSymbolTypeCode)
+ addr_line2 = symbol_line2.GetStartAddress()
+ # And a section type of code, too.
+ self.assertTrue(addr_line2.GetSectionType() == lldb.eSectionTypeCode)
+
+ # Now verify that both addresses point to the same module.
+ print "UUID:", addr_line1.GetModule().GetUUIDString()
+ self.assertTrue(addr_line1.GetModule().GetUUIDString() == addr_line2.GetModule().GetUUIDString())
+
+
+if __name__ == '__main__':
+ import atexit
+ lldb.SBDebugger.Initialize()
+ atexit.register(lambda: lldb.SBDebugger.Terminate())
+ unittest2.main()
More information about the lldb-commits
mailing list