blob: c4fc392b98d45b6c0a2b4f8b36616f2a1ba0dd83 [file] [log] [blame]
Chris Lattner24943d22010-06-08 16:52:24 +00001//===-- SBFrame.cpp ---------------------------------------------*- C++ -*-===//
2//
3// The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9
Eli Friedman7a62c8b2010-06-09 07:44:37 +000010#include "lldb/API/SBFrame.h"
Chris Lattner24943d22010-06-08 16:52:24 +000011
12#include <string>
13#include <algorithm>
14
15#include "lldb/lldb-types.h"
16
Johnny Chen4c24b0a2011-09-24 00:50:33 +000017#include "lldb/Breakpoint/WatchpointLocation.h"
Chris Lattner24943d22010-06-08 16:52:24 +000018#include "lldb/Core/Address.h"
19#include "lldb/Core/ConstString.h"
Caroline Tice7826c882010-10-26 03:11:13 +000020#include "lldb/Core/Log.h"
Chris Lattner24943d22010-06-08 16:52:24 +000021#include "lldb/Core/Stream.h"
22#include "lldb/Core/StreamFile.h"
23#include "lldb/Core/ValueObjectRegister.h"
24#include "lldb/Core/ValueObjectVariable.h"
Greg Claytond1719722010-10-05 03:13:51 +000025#include "lldb/Expression/ClangUserExpression.h"
Greg Clayton87ac9022011-06-25 04:35:01 +000026#include "lldb/Host/Host.h"
Chris Lattner24943d22010-06-08 16:52:24 +000027#include "lldb/Symbol/Block.h"
28#include "lldb/Symbol/SymbolContext.h"
29#include "lldb/Symbol/VariableList.h"
30#include "lldb/Symbol/Variable.h"
31#include "lldb/Target/ExecutionContext.h"
32#include "lldb/Target/Target.h"
33#include "lldb/Target/Process.h"
34#include "lldb/Target/RegisterContext.h"
35#include "lldb/Target/StackFrame.h"
36#include "lldb/Target/Thread.h"
37
Eli Friedman7a62c8b2010-06-09 07:44:37 +000038#include "lldb/API/SBDebugger.h"
39#include "lldb/API/SBValue.h"
40#include "lldb/API/SBAddress.h"
Caroline Tice98f930f2010-09-20 05:20:02 +000041#include "lldb/API/SBStream.h"
Eli Friedman7a62c8b2010-06-09 07:44:37 +000042#include "lldb/API/SBSymbolContext.h"
43#include "lldb/API/SBThread.h"
Chris Lattner24943d22010-06-08 16:52:24 +000044
45using namespace lldb;
46using namespace lldb_private;
47
48SBFrame::SBFrame () :
Greg Clayton63094e02010-06-23 01:19:29 +000049 m_opaque_sp ()
Chris Lattner24943d22010-06-08 16:52:24 +000050{
51}
52
Greg Clayton4e9267d2010-12-14 18:39:31 +000053SBFrame::SBFrame (const StackFrameSP &lldb_object_sp) :
Greg Clayton63094e02010-06-23 01:19:29 +000054 m_opaque_sp (lldb_object_sp)
Chris Lattner24943d22010-06-08 16:52:24 +000055{
Greg Clayton4e9267d2010-12-14 18:39:31 +000056 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +000057
58 if (log)
59 {
60 SBStream sstr;
61 GetDescription (sstr);
Greg Claytona66ba462010-10-30 04:51:46 +000062 log->Printf ("SBFrame::SBFrame (sp=%p) => SBFrame(%p): %s",
63 lldb_object_sp.get(), m_opaque_sp.get(), sstr.GetData());
Caroline Tice61ba7ec2010-10-26 23:49:36 +000064
Caroline Tice7826c882010-10-26 03:11:13 +000065 }
Chris Lattner24943d22010-06-08 16:52:24 +000066}
67
Greg Clayton538eb822010-11-05 23:17:00 +000068SBFrame::SBFrame(const SBFrame &rhs) :
69 m_opaque_sp (rhs.m_opaque_sp)
70{
71}
72
73const SBFrame &
74SBFrame::operator = (const SBFrame &rhs)
75{
76 if (this != &rhs)
77 m_opaque_sp = rhs.m_opaque_sp;
78 return *this;
79}
80
Chris Lattner24943d22010-06-08 16:52:24 +000081SBFrame::~SBFrame()
82{
83}
84
85
86void
Greg Clayton4e9267d2010-12-14 18:39:31 +000087SBFrame::SetFrame (const StackFrameSP &lldb_object_sp)
Chris Lattner24943d22010-06-08 16:52:24 +000088{
Greg Claytona66ba462010-10-30 04:51:46 +000089 void *old_ptr = m_opaque_sp.get();
Greg Clayton63094e02010-06-23 01:19:29 +000090 m_opaque_sp = lldb_object_sp;
Greg Clayton4e9267d2010-12-14 18:39:31 +000091 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +000092
93 if (log)
94 {
95 log->Printf ("SBFrame(%p)::SetFrame(sp=%p) := SBFrame(%p)",
96 old_ptr, lldb_object_sp.get(), m_opaque_sp.get());
97 }
98
Chris Lattner24943d22010-06-08 16:52:24 +000099}
100
101
102bool
103SBFrame::IsValid() const
104{
Greg Clayton63094e02010-06-23 01:19:29 +0000105 return (m_opaque_sp.get() != NULL);
Chris Lattner24943d22010-06-08 16:52:24 +0000106}
107
108SBSymbolContext
109SBFrame::GetSymbolContext (uint32_t resolve_scope) const
110{
Caroline Tice7826c882010-10-26 03:11:13 +0000111
Chris Lattner24943d22010-06-08 16:52:24 +0000112 SBSymbolContext sb_sym_ctx;
Greg Clayton63094e02010-06-23 01:19:29 +0000113 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000114 {
115 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
Greg Clayton63094e02010-06-23 01:19:29 +0000116 sb_sym_ctx.SetSymbolContext(&m_opaque_sp->GetSymbolContext (resolve_scope));
Greg Claytonbdcda462010-12-20 20:49:23 +0000117 }
Caroline Tice7826c882010-10-26 03:11:13 +0000118
Greg Clayton4e9267d2010-12-14 18:39:31 +0000119 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000120 if (log)
Greg Claytona66ba462010-10-30 04:51:46 +0000121 log->Printf ("SBFrame(%p)::GetSymbolContext (resolve_scope=0x%8.8x) => SBSymbolContext(%p)",
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000122 m_opaque_sp.get(), resolve_scope, sb_sym_ctx.get());
Caroline Tice7826c882010-10-26 03:11:13 +0000123
Chris Lattner24943d22010-06-08 16:52:24 +0000124 return sb_sym_ctx;
125}
126
127SBModule
128SBFrame::GetModule () const
129{
Greg Claytondd62d722010-12-14 04:58:53 +0000130 SBModule sb_module;
131 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000132 {
133 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
Greg Claytondd62d722010-12-14 04:58:53 +0000134 *sb_module = m_opaque_sp->GetSymbolContext (eSymbolContextModule).module_sp;
Greg Claytonbdcda462010-12-20 20:49:23 +0000135 }
Greg Claytondd62d722010-12-14 04:58:53 +0000136
Greg Clayton4e9267d2010-12-14 18:39:31 +0000137 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000138 if (log)
139 log->Printf ("SBFrame(%p)::GetModule () => SBModule(%p)",
140 m_opaque_sp.get(), sb_module.get());
141
Chris Lattner24943d22010-06-08 16:52:24 +0000142 return sb_module;
143}
144
145SBCompileUnit
146SBFrame::GetCompileUnit () const
147{
Greg Claytondd62d722010-12-14 04:58:53 +0000148 SBCompileUnit sb_comp_unit;
149 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000150 {
151 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
Greg Claytondd62d722010-12-14 04:58:53 +0000152 sb_comp_unit.reset (m_opaque_sp->GetSymbolContext (eSymbolContextCompUnit).comp_unit);
Greg Claytonbdcda462010-12-20 20:49:23 +0000153 }
Greg Clayton4e9267d2010-12-14 18:39:31 +0000154 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000155 if (log)
Greg Claytona66ba462010-10-30 04:51:46 +0000156 log->Printf ("SBFrame(%p)::GetModule () => SBCompileUnit(%p)",
157 m_opaque_sp.get(), sb_comp_unit.get());
Caroline Tice7826c882010-10-26 03:11:13 +0000158
Chris Lattner24943d22010-06-08 16:52:24 +0000159 return sb_comp_unit;
160}
161
162SBFunction
163SBFrame::GetFunction () const
164{
Greg Claytondd62d722010-12-14 04:58:53 +0000165 SBFunction sb_function;
166 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000167 {
168 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
Greg Claytondd62d722010-12-14 04:58:53 +0000169 sb_function.reset(m_opaque_sp->GetSymbolContext (eSymbolContextFunction).function);
Greg Claytonbdcda462010-12-20 20:49:23 +0000170 }
Greg Clayton4e9267d2010-12-14 18:39:31 +0000171 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000172 if (log)
173 log->Printf ("SBFrame(%p)::GetFunction () => SBFunction(%p)",
174 m_opaque_sp.get(), sb_function.get());
175
Chris Lattner24943d22010-06-08 16:52:24 +0000176 return sb_function;
177}
178
Greg Clayton8f1e08b2010-10-04 18:37:52 +0000179SBSymbol
180SBFrame::GetSymbol () const
181{
Greg Claytondd62d722010-12-14 04:58:53 +0000182 SBSymbol sb_symbol;
183 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000184 {
185 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
Greg Claytondd62d722010-12-14 04:58:53 +0000186 sb_symbol.reset(m_opaque_sp->GetSymbolContext (eSymbolContextSymbol).symbol);
Greg Claytonbdcda462010-12-20 20:49:23 +0000187 }
Greg Clayton4e9267d2010-12-14 18:39:31 +0000188 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000189 if (log)
190 log->Printf ("SBFrame(%p)::GetSymbol () => SBSymbol(%p)",
191 m_opaque_sp.get(), sb_symbol.get());
Greg Clayton8f1e08b2010-10-04 18:37:52 +0000192 return sb_symbol;
193}
194
Chris Lattner24943d22010-06-08 16:52:24 +0000195SBBlock
196SBFrame::GetBlock () const
197{
Greg Claytondd62d722010-12-14 04:58:53 +0000198 SBBlock sb_block;
199 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000200 {
201 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
Greg Claytondd62d722010-12-14 04:58:53 +0000202 sb_block.reset (m_opaque_sp->GetSymbolContext (eSymbolContextBlock).block);
Greg Claytonbdcda462010-12-20 20:49:23 +0000203 }
Greg Clayton4e9267d2010-12-14 18:39:31 +0000204 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000205 if (log)
206 log->Printf ("SBFrame(%p)::GetBlock () => SBBlock(%p)",
207 m_opaque_sp.get(), sb_block.get());
Chris Lattner24943d22010-06-08 16:52:24 +0000208 return sb_block;
209}
210
Greg Clayton69aa5d92010-09-07 04:20:48 +0000211SBBlock
212SBFrame::GetFrameBlock () const
213{
Greg Claytondd62d722010-12-14 04:58:53 +0000214 SBBlock sb_block;
215 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000216 {
217 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
Greg Claytondd62d722010-12-14 04:58:53 +0000218 sb_block.reset(m_opaque_sp->GetFrameBlock ());
Greg Claytonbdcda462010-12-20 20:49:23 +0000219 }
Greg Clayton4e9267d2010-12-14 18:39:31 +0000220 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000221 if (log)
222 log->Printf ("SBFrame(%p)::GetFrameBlock () => SBBlock(%p)",
223 m_opaque_sp.get(), sb_block.get());
Greg Clayton69aa5d92010-09-07 04:20:48 +0000224 return sb_block;
225}
226
Chris Lattner24943d22010-06-08 16:52:24 +0000227SBLineEntry
228SBFrame::GetLineEntry () const
229{
Greg Claytondd62d722010-12-14 04:58:53 +0000230 SBLineEntry sb_line_entry;
231 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000232 {
233 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
Greg Claytondd62d722010-12-14 04:58:53 +0000234 sb_line_entry.SetLineEntry (m_opaque_sp->GetSymbolContext (eSymbolContextLineEntry).line_entry);
Greg Claytonbdcda462010-12-20 20:49:23 +0000235 }
Greg Clayton4e9267d2010-12-14 18:39:31 +0000236 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000237 if (log)
238 log->Printf ("SBFrame(%p)::GetLineEntry () => SBLineEntry(%p)",
239 m_opaque_sp.get(), sb_line_entry.get());
Chris Lattner24943d22010-06-08 16:52:24 +0000240 return sb_line_entry;
241}
242
243uint32_t
244SBFrame::GetFrameID () const
245{
Greg Claytona66ba462010-10-30 04:51:46 +0000246 uint32_t frame_idx = m_opaque_sp ? m_opaque_sp->GetFrameIndex () : UINT32_MAX;
247
Greg Clayton4e9267d2010-12-14 18:39:31 +0000248 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000249 if (log)
250 log->Printf ("SBFrame(%p)::GetFrameID () => %u",
251 m_opaque_sp.get(), frame_idx);
252 return frame_idx;
Chris Lattner24943d22010-06-08 16:52:24 +0000253}
254
Greg Clayton4e9267d2010-12-14 18:39:31 +0000255addr_t
Chris Lattner24943d22010-06-08 16:52:24 +0000256SBFrame::GetPC () const
257{
Greg Clayton4e9267d2010-12-14 18:39:31 +0000258 addr_t addr = LLDB_INVALID_ADDRESS;
Greg Clayton63094e02010-06-23 01:19:29 +0000259 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000260 {
261 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
Greg Clayton107e53d2011-07-06 04:07:21 +0000262 addr = m_opaque_sp->GetFrameCodeAddress().GetOpcodeLoadAddress (&m_opaque_sp->GetThread().GetProcess().GetTarget());
Greg Claytonbdcda462010-12-20 20:49:23 +0000263 }
Caroline Tice7826c882010-10-26 03:11:13 +0000264
Greg Clayton4e9267d2010-12-14 18:39:31 +0000265 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000266 if (log)
Greg Clayton49ce6822010-10-31 03:01:06 +0000267 log->Printf ("SBFrame(%p)::GetPC () => 0x%llx", m_opaque_sp.get(), addr);
Caroline Tice7826c882010-10-26 03:11:13 +0000268
269 return addr;
Chris Lattner24943d22010-06-08 16:52:24 +0000270}
271
272bool
Greg Clayton4e9267d2010-12-14 18:39:31 +0000273SBFrame::SetPC (addr_t new_pc)
Chris Lattner24943d22010-06-08 16:52:24 +0000274{
Caroline Tice7826c882010-10-26 03:11:13 +0000275 bool ret_val = false;
Greg Clayton63094e02010-06-23 01:19:29 +0000276 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000277 {
278 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
Caroline Tice7826c882010-10-26 03:11:13 +0000279 ret_val = m_opaque_sp->GetRegisterContext()->SetPC (new_pc);
Greg Claytonbdcda462010-12-20 20:49:23 +0000280 }
Caroline Tice7826c882010-10-26 03:11:13 +0000281
Greg Clayton4e9267d2010-12-14 18:39:31 +0000282 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000283 if (log)
Greg Claytona66ba462010-10-30 04:51:46 +0000284 log->Printf ("SBFrame(%p)::SetPC (new_pc=0x%llx) => %i",
285 m_opaque_sp.get(), new_pc, ret_val);
Caroline Tice7826c882010-10-26 03:11:13 +0000286
287 return ret_val;
Chris Lattner24943d22010-06-08 16:52:24 +0000288}
289
Greg Clayton4e9267d2010-12-14 18:39:31 +0000290addr_t
Chris Lattner24943d22010-06-08 16:52:24 +0000291SBFrame::GetSP () const
292{
Greg Claytona66ba462010-10-30 04:51:46 +0000293 addr_t addr = LLDB_INVALID_ADDRESS;
Greg Clayton63094e02010-06-23 01:19:29 +0000294 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000295 {
296 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
Greg Claytona66ba462010-10-30 04:51:46 +0000297 addr = m_opaque_sp->GetRegisterContext()->GetSP();
Greg Claytonbdcda462010-12-20 20:49:23 +0000298 }
Greg Clayton4e9267d2010-12-14 18:39:31 +0000299 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000300 if (log)
Greg Clayton49ce6822010-10-31 03:01:06 +0000301 log->Printf ("SBFrame(%p)::GetSP () => 0x%llx", m_opaque_sp.get(), addr);
Greg Claytona66ba462010-10-30 04:51:46 +0000302
303 return addr;
Chris Lattner24943d22010-06-08 16:52:24 +0000304}
305
306
Greg Clayton4e9267d2010-12-14 18:39:31 +0000307addr_t
Chris Lattner24943d22010-06-08 16:52:24 +0000308SBFrame::GetFP () const
309{
Greg Clayton4e9267d2010-12-14 18:39:31 +0000310 addr_t addr = LLDB_INVALID_ADDRESS;
Greg Clayton63094e02010-06-23 01:19:29 +0000311 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000312 {
313 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
Caroline Tice7826c882010-10-26 03:11:13 +0000314 addr = m_opaque_sp->GetRegisterContext()->GetFP();
Greg Claytonbdcda462010-12-20 20:49:23 +0000315 }
Caroline Tice7826c882010-10-26 03:11:13 +0000316
Greg Clayton4e9267d2010-12-14 18:39:31 +0000317 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000318 if (log)
Greg Clayton49ce6822010-10-31 03:01:06 +0000319 log->Printf ("SBFrame(%p)::GetFP () => 0x%llx", m_opaque_sp.get(), addr);
Caroline Tice7826c882010-10-26 03:11:13 +0000320 return addr;
Chris Lattner24943d22010-06-08 16:52:24 +0000321}
322
323
324SBAddress
325SBFrame::GetPCAddress () const
326{
327 SBAddress sb_addr;
Greg Clayton63094e02010-06-23 01:19:29 +0000328 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000329 {
330 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
Greg Claytonb04e7a82010-08-24 21:05:24 +0000331 sb_addr.SetAddress (&m_opaque_sp->GetFrameCodeAddress());
Greg Claytonbdcda462010-12-20 20:49:23 +0000332 }
Greg Clayton4e9267d2010-12-14 18:39:31 +0000333 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000334 if (log)
335 log->Printf ("SBFrame(%p)::GetPCAddress () => SBAddress(%p)", m_opaque_sp.get(), sb_addr.get());
Chris Lattner24943d22010-06-08 16:52:24 +0000336 return sb_addr;
337}
338
339void
340SBFrame::Clear()
341{
Greg Clayton63094e02010-06-23 01:19:29 +0000342 m_opaque_sp.reset();
Chris Lattner24943d22010-06-08 16:52:24 +0000343}
344
345SBValue
Greg Clayton4e9267d2010-12-14 18:39:31 +0000346SBFrame::FindVariable (const char *name)
Chris Lattner24943d22010-06-08 16:52:24 +0000347{
Greg Clayton582ed0e2011-06-18 20:06:08 +0000348 SBValue value;
349 if (m_opaque_sp)
350 {
351 lldb::DynamicValueType use_dynamic = m_opaque_sp->CalculateTarget()->GetPreferDynamicValue();
352 value = FindVariable (name, use_dynamic);
353 }
354 return value;
Jim Inghame41494a2011-04-16 00:01:13 +0000355}
356
357SBValue
Jim Ingham10de7d12011-05-04 03:43:18 +0000358SBFrame::FindVariable (const char *name, lldb::DynamicValueType use_dynamic)
Jim Inghame41494a2011-04-16 00:01:13 +0000359{
Greg Clayton4e9267d2010-12-14 18:39:31 +0000360 VariableSP var_sp;
Jim Ingham47da8102011-04-22 23:53:53 +0000361 SBValue sb_value;
362
Greg Clayton4e9267d2010-12-14 18:39:31 +0000363 if (m_opaque_sp && name && name[0])
Chris Lattner24943d22010-06-08 16:52:24 +0000364 {
Greg Clayton4e9267d2010-12-14 18:39:31 +0000365 VariableList variable_list;
Greg Claytonbdcda462010-12-20 20:49:23 +0000366 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
Greg Claytondd62d722010-12-14 04:58:53 +0000367 SymbolContext sc (m_opaque_sp->GetSymbolContext (eSymbolContextBlock));
Chris Lattner24943d22010-06-08 16:52:24 +0000368
Greg Claytondd62d722010-12-14 04:58:53 +0000369 if (sc.block)
Chris Lattner24943d22010-06-08 16:52:24 +0000370 {
Greg Claytondd62d722010-12-14 04:58:53 +0000371 const bool can_create = true;
372 const bool get_parent_variables = true;
373 const bool stop_if_block_is_inlined_function = true;
374
375 if (sc.block->AppendVariables (can_create,
376 get_parent_variables,
377 stop_if_block_is_inlined_function,
378 &variable_list))
379 {
Greg Clayton4e9267d2010-12-14 18:39:31 +0000380 var_sp = variable_list.FindVariable (ConstString(name));
Greg Claytondd62d722010-12-14 04:58:53 +0000381 }
Chris Lattner24943d22010-06-08 16:52:24 +0000382 }
Greg Clayton582ed0e2011-06-18 20:06:08 +0000383
384 if (var_sp)
385 *sb_value = ValueObjectSP (m_opaque_sp->GetValueObjectForFrameVariable(var_sp, use_dynamic));
386
Chris Lattner24943d22010-06-08 16:52:24 +0000387 }
Caroline Tice98f930f2010-09-20 05:20:02 +0000388
Greg Clayton4e9267d2010-12-14 18:39:31 +0000389 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000390 if (log)
Greg Clayton4e9267d2010-12-14 18:39:31 +0000391 log->Printf ("SBFrame(%p)::FindVariable (name=\"%s\") => SBValue(%p)",
392 m_opaque_sp.get(), name, sb_value.get());
Greg Claytona66ba462010-10-30 04:51:46 +0000393
Chris Lattner24943d22010-06-08 16:52:24 +0000394 return sb_value;
395}
396
397SBValue
Greg Clayton4e9267d2010-12-14 18:39:31 +0000398SBFrame::FindValue (const char *name, ValueType value_type)
Chris Lattner24943d22010-06-08 16:52:24 +0000399{
Greg Clayton582ed0e2011-06-18 20:06:08 +0000400 SBValue value;
401 if (m_opaque_sp)
402 {
403 lldb::DynamicValueType use_dynamic = m_opaque_sp->CalculateTarget()->GetPreferDynamicValue();
404 value = FindValue (name, value_type, use_dynamic);
405 }
406 return value;
Jim Inghame41494a2011-04-16 00:01:13 +0000407}
408
Johnny Chen4c24b0a2011-09-24 00:50:33 +0000409/// Find and watch a variable using the frame as the scope.
410/// You can use LLDB_WATCH_TYPE_READ | LLDB_WATCH_TYPE_WRITE for 'rw' watch.
411SBValue
412SBFrame::WatchValue (const char *name, ValueType value_type, uint32_t watch_type)
413{
414 SBValue sb_value_empty;
415
416 if (!IsValid())
417 return sb_value_empty;
418
419 // Acquire the API locker, to be released at the end of the method call.
420 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
421
422 switch (value_type) {
423 case eValueTypeVariableGlobal: // global variable
424 case eValueTypeVariableStatic: // static variable
425 case eValueTypeVariableArgument: // function argument variables
426 case eValueTypeVariableLocal: // function local variables
427 break;
428 default:
429 return sb_value_empty; // these are not eligible for watching
430 }
431
432 SBValue sb_value = FindValue(name, value_type);
433 // If the SBValue is not valid, there's no point in even trying to watch it.
434 if (!sb_value.IsValid())
435 return sb_value;
436
437 addr_t addr = sb_value.GetLoadAddress();
438 size_t size = sb_value.GetByteSize();
439
440 WatchpointLocationSP wp_loc_sp = m_opaque_sp->GetThread().GetProcess().GetTarget().
441 CreateWatchpointLocation(addr, size, watch_type);
442
443 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
444 if (log)
445 log->Printf ("SBFrame(%p)::WatchValue (name=\"%s\", value_type=%i, watch_type=%i) => SBValue(%p) & wp_loc(%p)",
446 m_opaque_sp.get(), name, value_type, watch_type, sb_value.get(), wp_loc_sp.get());
447
448 return wp_loc_sp ? sb_value : sb_value_empty;
449}
450
Jim Inghame41494a2011-04-16 00:01:13 +0000451SBValue
Jim Ingham10de7d12011-05-04 03:43:18 +0000452SBFrame::FindValue (const char *name, ValueType value_type, lldb::DynamicValueType use_dynamic)
Jim Inghame41494a2011-04-16 00:01:13 +0000453{
Greg Clayton4e9267d2010-12-14 18:39:31 +0000454 SBValue sb_value;
455 if (m_opaque_sp && name && name[0])
Chris Lattner24943d22010-06-08 16:52:24 +0000456 {
Greg Claytonbdcda462010-12-20 20:49:23 +0000457 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
Greg Clayton4e9267d2010-12-14 18:39:31 +0000458
459 switch (value_type)
Chris Lattner24943d22010-06-08 16:52:24 +0000460 {
Greg Clayton4e9267d2010-12-14 18:39:31 +0000461 case eValueTypeVariableGlobal: // global variable
462 case eValueTypeVariableStatic: // static variable
463 case eValueTypeVariableArgument: // function argument variables
464 case eValueTypeVariableLocal: // function local variables
Chris Lattner24943d22010-06-08 16:52:24 +0000465 {
Greg Clayton4e9267d2010-12-14 18:39:31 +0000466 VariableList *variable_list = m_opaque_sp->GetVariableList(true);
467
468 SymbolContext sc (m_opaque_sp->GetSymbolContext (eSymbolContextBlock));
469
470 const bool can_create = true;
471 const bool get_parent_variables = true;
472 const bool stop_if_block_is_inlined_function = true;
473
474 if (sc.block && sc.block->AppendVariables (can_create,
475 get_parent_variables,
476 stop_if_block_is_inlined_function,
477 variable_list))
Johnny Chenc35750a2010-11-19 18:07:14 +0000478 {
Greg Clayton4e9267d2010-12-14 18:39:31 +0000479 ConstString const_name(name);
480 const uint32_t num_variables = variable_list->GetSize();
481 for (uint32_t i = 0; i < num_variables; ++i)
Johnny Chenc35750a2010-11-19 18:07:14 +0000482 {
Greg Clayton4e9267d2010-12-14 18:39:31 +0000483 VariableSP variable_sp (variable_list->GetVariableAtIndex(i));
484 if (variable_sp &&
485 variable_sp->GetScope() == value_type &&
486 variable_sp->GetName() == const_name)
487 {
Jim Inghame41494a2011-04-16 00:01:13 +0000488 *sb_value = ValueObjectSP (m_opaque_sp->GetValueObjectForFrameVariable(variable_sp,
489 use_dynamic));
Greg Clayton4e9267d2010-12-14 18:39:31 +0000490 break;
491 }
Johnny Chenc35750a2010-11-19 18:07:14 +0000492 }
493 }
Chris Lattner24943d22010-06-08 16:52:24 +0000494 }
Greg Clayton4e9267d2010-12-14 18:39:31 +0000495 break;
496
497 case eValueTypeRegister: // stack frame register value
498 {
Greg Clayton08d7d3a2011-01-06 22:15:06 +0000499 RegisterContextSP reg_ctx (m_opaque_sp->GetRegisterContext());
Greg Clayton4e9267d2010-12-14 18:39:31 +0000500 if (reg_ctx)
501 {
502 const uint32_t num_regs = reg_ctx->GetRegisterCount();
503 for (uint32_t reg_idx = 0; reg_idx < num_regs; ++reg_idx)
504 {
505 const RegisterInfo *reg_info = reg_ctx->GetRegisterInfoAtIndex (reg_idx);
506 if (reg_info &&
507 ((reg_info->name && strcasecmp (reg_info->name, name) == 0) ||
508 (reg_info->alt_name && strcasecmp (reg_info->alt_name, name) == 0)))
509 {
Jim Ingham47da8102011-04-22 23:53:53 +0000510 *sb_value = ValueObjectRegister::Create (m_opaque_sp.get(), reg_ctx, reg_idx);
Greg Clayton4e9267d2010-12-14 18:39:31 +0000511 }
512 }
513 }
514 }
515 break;
516
517 case eValueTypeRegisterSet: // A collection of stack frame register values
518 {
Greg Clayton08d7d3a2011-01-06 22:15:06 +0000519 RegisterContextSP reg_ctx (m_opaque_sp->GetRegisterContext());
Greg Clayton4e9267d2010-12-14 18:39:31 +0000520 if (reg_ctx)
521 {
522 const uint32_t num_sets = reg_ctx->GetRegisterSetCount();
523 for (uint32_t set_idx = 0; set_idx < num_sets; ++set_idx)
524 {
525 const RegisterSet *reg_set = reg_ctx->GetRegisterSet (set_idx);
526 if (reg_set &&
527 ((reg_set->name && strcasecmp (reg_set->name, name) == 0) ||
528 (reg_set->short_name && strcasecmp (reg_set->short_name, name) == 0)))
529 {
Jim Ingham47da8102011-04-22 23:53:53 +0000530 *sb_value = ValueObjectRegisterSet::Create (m_opaque_sp.get(), reg_ctx, set_idx);
Greg Clayton4e9267d2010-12-14 18:39:31 +0000531 }
532 }
533 }
534 }
535 break;
536
537 case eValueTypeConstResult: // constant result variables
538 {
539 ConstString const_name(name);
540 ClangExpressionVariableSP expr_var_sp (m_opaque_sp->GetThread().GetProcess().GetTarget().GetPersistentVariables().GetVariable (const_name));
541 if (expr_var_sp)
542 *sb_value = expr_var_sp->GetValueObject();
543 }
544 break;
545
546 default:
547 break;
Chris Lattner24943d22010-06-08 16:52:24 +0000548 }
549 }
Caroline Tice98f930f2010-09-20 05:20:02 +0000550
Greg Clayton4e9267d2010-12-14 18:39:31 +0000551 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000552 if (log)
Greg Clayton4e9267d2010-12-14 18:39:31 +0000553 log->Printf ("SBFrame(%p)::FindVariableInScope (name=\"%s\", value_type=%i) => SBValue(%p)",
554 m_opaque_sp.get(), name, value_type, sb_value.get());
Greg Claytona66ba462010-10-30 04:51:46 +0000555
556
Chris Lattner24943d22010-06-08 16:52:24 +0000557 return sb_value;
558}
559
560bool
561SBFrame::operator == (const SBFrame &rhs) const
562{
Greg Clayton63094e02010-06-23 01:19:29 +0000563 return m_opaque_sp.get() == rhs.m_opaque_sp.get();
Chris Lattner24943d22010-06-08 16:52:24 +0000564}
565
566bool
567SBFrame::operator != (const SBFrame &rhs) const
568{
Greg Clayton63094e02010-06-23 01:19:29 +0000569 return m_opaque_sp.get() != rhs.m_opaque_sp.get();
Chris Lattner24943d22010-06-08 16:52:24 +0000570}
571
572lldb_private::StackFrame *
573SBFrame::operator->() const
574{
Greg Clayton63094e02010-06-23 01:19:29 +0000575 return m_opaque_sp.get();
Chris Lattner24943d22010-06-08 16:52:24 +0000576}
577
578lldb_private::StackFrame *
579SBFrame::get() const
580{
Greg Clayton63094e02010-06-23 01:19:29 +0000581 return m_opaque_sp.get();
Chris Lattner24943d22010-06-08 16:52:24 +0000582}
583
Greg Claytond68e0892011-09-09 23:04:00 +0000584lldb::StackFrameSP &
585SBFrame::get_sp()
Greg Clayton1ebdcc72011-01-21 06:11:58 +0000586{
587 return m_opaque_sp;
588}
Chris Lattner24943d22010-06-08 16:52:24 +0000589
590SBThread
591SBFrame::GetThread () const
592{
Greg Clayton4e9267d2010-12-14 18:39:31 +0000593 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000594
Greg Claytondd62d722010-12-14 04:58:53 +0000595 SBThread sb_thread;
596 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000597 {
598 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
Greg Claytondd62d722010-12-14 04:58:53 +0000599 sb_thread.SetThread (m_opaque_sp->GetThread().GetSP());
Greg Claytonbdcda462010-12-20 20:49:23 +0000600 }
Caroline Tice7826c882010-10-26 03:11:13 +0000601
602 if (log)
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000603 {
604 SBStream sstr;
605 sb_thread.GetDescription (sstr);
Greg Claytona66ba462010-10-30 04:51:46 +0000606 log->Printf ("SBFrame(%p)::GetThread () => SBThread(%p): %s", m_opaque_sp.get(),
607 sb_thread.get(), sstr.GetData());
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000608 }
Caroline Tice7826c882010-10-26 03:11:13 +0000609
Chris Lattner24943d22010-06-08 16:52:24 +0000610 return sb_thread;
611}
612
613const char *
614SBFrame::Disassemble () const
615{
Greg Claytona66ba462010-10-30 04:51:46 +0000616 const char *disassembly = NULL;
Greg Clayton63094e02010-06-23 01:19:29 +0000617 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000618 {
619 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
Greg Claytona66ba462010-10-30 04:51:46 +0000620 disassembly = m_opaque_sp->Disassemble();
Greg Claytonbdcda462010-12-20 20:49:23 +0000621 }
Greg Clayton4e9267d2010-12-14 18:39:31 +0000622 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000623
624 if (log)
625 log->Printf ("SBFrame(%p)::Disassemble () => %s", m_opaque_sp.get(), disassembly);
626
627 return disassembly;
Chris Lattner24943d22010-06-08 16:52:24 +0000628}
629
630
Chris Lattner24943d22010-06-08 16:52:24 +0000631SBValueList
632SBFrame::GetVariables (bool arguments,
633 bool locals,
634 bool statics,
635 bool in_scope_only)
636{
Greg Clayton582ed0e2011-06-18 20:06:08 +0000637 SBValueList value_list;
638 if (m_opaque_sp)
639 {
640 lldb::DynamicValueType use_dynamic = m_opaque_sp->CalculateTarget()->GetPreferDynamicValue();
641 value_list = GetVariables (arguments, locals, statics, in_scope_only, use_dynamic);
642 }
643 return value_list;
Jim Inghame41494a2011-04-16 00:01:13 +0000644}
645
646SBValueList
647SBFrame::GetVariables (bool arguments,
648 bool locals,
649 bool statics,
650 bool in_scope_only,
Jim Ingham10de7d12011-05-04 03:43:18 +0000651 lldb::DynamicValueType use_dynamic)
Jim Inghame41494a2011-04-16 00:01:13 +0000652{
Greg Clayton4e9267d2010-12-14 18:39:31 +0000653 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000654
655 if (log)
Greg Claytona66ba462010-10-30 04:51:46 +0000656 log->Printf ("SBFrame(%p)::GetVariables (arguments=%i, locals=%i, statics=%i, in_scope_only=%i)",
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000657 m_opaque_sp.get(),
Greg Claytona66ba462010-10-30 04:51:46 +0000658 arguments,
659 locals,
660 statics,
661 in_scope_only);
Caroline Tice7826c882010-10-26 03:11:13 +0000662
Chris Lattner24943d22010-06-08 16:52:24 +0000663 SBValueList value_list;
Greg Clayton63094e02010-06-23 01:19:29 +0000664 if (m_opaque_sp)
Chris Lattner24943d22010-06-08 16:52:24 +0000665 {
Greg Claytonbdcda462010-12-20 20:49:23 +0000666
Chris Lattner24943d22010-06-08 16:52:24 +0000667 size_t i;
Greg Claytonbdcda462010-12-20 20:49:23 +0000668 VariableList *variable_list = NULL;
669 // Scope for locker
670 {
671 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
672 variable_list = m_opaque_sp->GetVariableList(true);
673 }
Chris Lattner24943d22010-06-08 16:52:24 +0000674 if (variable_list)
675 {
676 const size_t num_variables = variable_list->GetSize();
677 if (num_variables)
678 {
679 for (i = 0; i < num_variables; ++i)
680 {
681 VariableSP variable_sp (variable_list->GetVariableAtIndex(i));
682 if (variable_sp)
683 {
684 bool add_variable = false;
685 switch (variable_sp->GetScope())
686 {
687 case eValueTypeVariableGlobal:
688 case eValueTypeVariableStatic:
689 add_variable = statics;
690 break;
691
692 case eValueTypeVariableArgument:
693 add_variable = arguments;
694 break;
695
696 case eValueTypeVariableLocal:
697 add_variable = locals;
698 break;
Greg Clayton54e7afa2010-07-09 20:39:50 +0000699
700 default:
701 break;
Chris Lattner24943d22010-06-08 16:52:24 +0000702 }
703 if (add_variable)
704 {
Greg Clayton63094e02010-06-23 01:19:29 +0000705 if (in_scope_only && !variable_sp->IsInScope(m_opaque_sp.get()))
Chris Lattner24943d22010-06-08 16:52:24 +0000706 continue;
707
Jim Inghame41494a2011-04-16 00:01:13 +0000708 value_list.Append(m_opaque_sp->GetValueObjectForFrameVariable (variable_sp, use_dynamic));
Chris Lattner24943d22010-06-08 16:52:24 +0000709 }
710 }
711 }
712 }
Greg Clayton17dae082010-09-02 02:59:18 +0000713 }
Chris Lattner24943d22010-06-08 16:52:24 +0000714 }
Caroline Tice7826c882010-10-26 03:11:13 +0000715
716 if (log)
717 {
Greg Claytona66ba462010-10-30 04:51:46 +0000718 log->Printf ("SBFrame(%p)::GetVariables (...) => SBValueList(%p)", m_opaque_sp.get(),
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000719 value_list.get());
Caroline Tice7826c882010-10-26 03:11:13 +0000720 }
721
Chris Lattner24943d22010-06-08 16:52:24 +0000722 return value_list;
723}
724
Greg Clayton4e9267d2010-12-14 18:39:31 +0000725SBValueList
Chris Lattner24943d22010-06-08 16:52:24 +0000726SBFrame::GetRegisters ()
727{
Greg Clayton4e9267d2010-12-14 18:39:31 +0000728 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000729
Chris Lattner24943d22010-06-08 16:52:24 +0000730 SBValueList value_list;
Greg Clayton63094e02010-06-23 01:19:29 +0000731 if (m_opaque_sp)
Chris Lattner24943d22010-06-08 16:52:24 +0000732 {
Greg Claytonbdcda462010-12-20 20:49:23 +0000733 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
Greg Clayton08d7d3a2011-01-06 22:15:06 +0000734 RegisterContextSP reg_ctx (m_opaque_sp->GetRegisterContext());
Chris Lattner24943d22010-06-08 16:52:24 +0000735 if (reg_ctx)
736 {
737 const uint32_t num_sets = reg_ctx->GetRegisterSetCount();
738 for (uint32_t set_idx = 0; set_idx < num_sets; ++set_idx)
739 {
Jim Ingham47da8102011-04-22 23:53:53 +0000740 value_list.Append(ValueObjectRegisterSet::Create (m_opaque_sp.get(), reg_ctx, set_idx));
Chris Lattner24943d22010-06-08 16:52:24 +0000741 }
742 }
743 }
Caroline Tice7826c882010-10-26 03:11:13 +0000744
745 if (log)
Greg Claytona66ba462010-10-30 04:51:46 +0000746 log->Printf ("SBFrame(%p)::Registers () => SBValueList(%p)", m_opaque_sp.get(), value_list.get());
Caroline Tice7826c882010-10-26 03:11:13 +0000747
Chris Lattner24943d22010-06-08 16:52:24 +0000748 return value_list;
749}
750
Caroline Tice98f930f2010-09-20 05:20:02 +0000751bool
752SBFrame::GetDescription (SBStream &description)
753{
754 if (m_opaque_sp)
755 {
Greg Claytonbdcda462010-12-20 20:49:23 +0000756 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
Greg Clayton49ce6822010-10-31 03:01:06 +0000757 Stream &s = description.ref();
758 m_opaque_sp->DumpUsingSettingsFormat (&s);
Caroline Tice98f930f2010-09-20 05:20:02 +0000759 }
760 else
761 description.Printf ("No value");
762
763 return true;
764}
Greg Clayton66ed2fb2010-10-05 00:00:42 +0000765
Greg Clayton4e9267d2010-12-14 18:39:31 +0000766SBValue
Greg Clayton66ed2fb2010-10-05 00:00:42 +0000767SBFrame::EvaluateExpression (const char *expr)
768{
Greg Clayton582ed0e2011-06-18 20:06:08 +0000769 SBValue result;
770 if (m_opaque_sp)
771 {
772 lldb::DynamicValueType use_dynamic = m_opaque_sp->CalculateTarget()->GetPreferDynamicValue();
773 result = EvaluateExpression (expr, use_dynamic);
774 }
775 return result;
Jim Inghame41494a2011-04-16 00:01:13 +0000776}
777
778SBValue
Jim Ingham10de7d12011-05-04 03:43:18 +0000779SBFrame::EvaluateExpression (const char *expr, lldb::DynamicValueType fetch_dynamic_value)
Jim Inghame41494a2011-04-16 00:01:13 +0000780{
Greg Clayton4e9267d2010-12-14 18:39:31 +0000781 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Sean Callanan94d255f2010-12-07 22:55:01 +0000782
Greg Clayton4e9267d2010-12-14 18:39:31 +0000783 LogSP expr_log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_EXPRESSIONS));
Greg Claytona66ba462010-10-30 04:51:46 +0000784
Johnny Chenee6e7902011-08-10 22:06:24 +0000785 ExecutionResults exe_results;
Greg Clayton4e9267d2010-12-14 18:39:31 +0000786 SBValue expr_result;
Greg Claytona66ba462010-10-30 04:51:46 +0000787 if (log)
788 log->Printf ("SBFrame(%p)::EvaluateExpression (expr=\"%s\")...", m_opaque_sp.get(), expr);
789
Greg Clayton66ed2fb2010-10-05 00:00:42 +0000790 if (m_opaque_sp)
791 {
Greg Clayton582ed0e2011-06-18 20:06:08 +0000792 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
793
Greg Clayton87ac9022011-06-25 04:35:01 +0000794
795 StreamString frame_description;
796 m_opaque_sp->DumpUsingSettingsFormat (&frame_description);
797
798 Host::SetCrashDescriptionWithFormat ("SBFrame::EvaluateExpression (expr = \"%s\", fetch_dynamic_value = %u) %s",
799 expr, fetch_dynamic_value, frame_description.GetString().c_str());
800
Greg Clayton427f2902010-12-14 02:59:59 +0000801 const bool unwind_on_error = true;
Sean Callanan6a925532011-01-13 08:53:35 +0000802 const bool keep_in_memory = false;
Greg Clayton427f2902010-12-14 02:59:59 +0000803
Jim Inghame41494a2011-04-16 00:01:13 +0000804 exe_results = m_opaque_sp->GetThread().GetProcess().GetTarget().EvaluateExpression(expr,
Sean Callanan47dc4572011-09-15 02:13:07 +0000805 m_opaque_sp.get(),
806 eExecutionPolicyOnlyWhenNeeded,
Jim Inghame41494a2011-04-16 00:01:13 +0000807 unwind_on_error,
Jim Inghame41494a2011-04-16 00:01:13 +0000808 keep_in_memory,
Jim Ingham10de7d12011-05-04 03:43:18 +0000809 fetch_dynamic_value,
Jim Inghame41494a2011-04-16 00:01:13 +0000810 *expr_result);
Greg Clayton66ed2fb2010-10-05 00:00:42 +0000811 }
Greg Claytona66ba462010-10-30 04:51:46 +0000812
Sean Callanan94d255f2010-12-07 22:55:01 +0000813 if (expr_log)
Jim Inghame41494a2011-04-16 00:01:13 +0000814 expr_log->Printf("** [SBFrame::EvaluateExpression] Expression result is %s, summary %s **",
Greg Clayton0fb0bcc2011-08-03 22:57:10 +0000815 expr_result.GetValue(),
816 expr_result.GetSummary());
Sean Callanan94d255f2010-12-07 22:55:01 +0000817
Greg Claytona66ba462010-10-30 04:51:46 +0000818 if (log)
Johnny Chenee6e7902011-08-10 22:06:24 +0000819 log->Printf ("SBFrame(%p)::EvaluateExpression (expr=\"%s\") => SBValue(%p) (execution result=%d)", m_opaque_sp.get(),
Jim Inghame41494a2011-04-16 00:01:13 +0000820 expr,
Johnny Chenee6e7902011-08-10 22:06:24 +0000821 expr_result.get(),
822 exe_results);
Greg Claytona66ba462010-10-30 04:51:46 +0000823
Greg Clayton49ce6822010-10-31 03:01:06 +0000824 return expr_result;
Greg Clayton66ed2fb2010-10-05 00:00:42 +0000825}
Greg Clayton582ed0e2011-06-18 20:06:08 +0000826
827bool
828SBFrame::IsInlined()
829{
830 if (m_opaque_sp)
831 {
832 Block *block = m_opaque_sp->GetSymbolContext(eSymbolContextBlock).block;
833 if (block)
834 return block->GetContainingInlinedBlock () != NULL;
835 }
836 return false;
837}
838
839const char *
840SBFrame::GetFunctionName()
841{
842 const char *name = NULL;
843 if (m_opaque_sp)
844 {
845 SymbolContext sc (m_opaque_sp->GetSymbolContext(eSymbolContextFunction | eSymbolContextBlock | eSymbolContextSymbol));
846 if (sc.block)
847 {
848 Block *inlined_block = sc.block->GetContainingInlinedBlock ();
849 if (inlined_block)
850 {
851 const InlineFunctionInfo* inlined_info = inlined_block->GetInlinedFunctionInfo();
852 name = inlined_info->GetName().AsCString();
853 }
854 }
855
856 if (name == NULL)
857 {
858 if (sc.function)
859 name = sc.function->GetName().GetCString();
860 }
861
862 if (name == NULL)
863 {
864 if (sc.symbol)
865 name = sc.symbol->GetName().GetCString();
866 }
867 }
868 return name;
869}
870