blob: 38fcc4eb88a3fad85378551dbef4bdc96530b294 [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
17#include "lldb/Core/Address.h"
18#include "lldb/Core/ConstString.h"
Caroline Tice7826c882010-10-26 03:11:13 +000019#include "lldb/Core/Log.h"
Chris Lattner24943d22010-06-08 16:52:24 +000020#include "lldb/Core/Stream.h"
21#include "lldb/Core/StreamFile.h"
22#include "lldb/Core/ValueObjectRegister.h"
23#include "lldb/Core/ValueObjectVariable.h"
Greg Claytond1719722010-10-05 03:13:51 +000024#include "lldb/Expression/ClangUserExpression.h"
Greg Clayton87ac9022011-06-25 04:35:01 +000025#include "lldb/Host/Host.h"
Chris Lattner24943d22010-06-08 16:52:24 +000026#include "lldb/Symbol/Block.h"
27#include "lldb/Symbol/SymbolContext.h"
28#include "lldb/Symbol/VariableList.h"
29#include "lldb/Symbol/Variable.h"
30#include "lldb/Target/ExecutionContext.h"
31#include "lldb/Target/Target.h"
32#include "lldb/Target/Process.h"
33#include "lldb/Target/RegisterContext.h"
34#include "lldb/Target/StackFrame.h"
35#include "lldb/Target/Thread.h"
36
Eli Friedman7a62c8b2010-06-09 07:44:37 +000037#include "lldb/API/SBDebugger.h"
38#include "lldb/API/SBValue.h"
39#include "lldb/API/SBAddress.h"
Caroline Tice98f930f2010-09-20 05:20:02 +000040#include "lldb/API/SBStream.h"
Eli Friedman7a62c8b2010-06-09 07:44:37 +000041#include "lldb/API/SBSymbolContext.h"
42#include "lldb/API/SBThread.h"
Chris Lattner24943d22010-06-08 16:52:24 +000043
44using namespace lldb;
45using namespace lldb_private;
46
47SBFrame::SBFrame () :
Greg Clayton63094e02010-06-23 01:19:29 +000048 m_opaque_sp ()
Chris Lattner24943d22010-06-08 16:52:24 +000049{
50}
51
Greg Clayton4e9267d2010-12-14 18:39:31 +000052SBFrame::SBFrame (const StackFrameSP &lldb_object_sp) :
Greg Clayton63094e02010-06-23 01:19:29 +000053 m_opaque_sp (lldb_object_sp)
Chris Lattner24943d22010-06-08 16:52:24 +000054{
Greg Clayton4e9267d2010-12-14 18:39:31 +000055 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +000056
57 if (log)
58 {
59 SBStream sstr;
60 GetDescription (sstr);
Greg Claytona66ba462010-10-30 04:51:46 +000061 log->Printf ("SBFrame::SBFrame (sp=%p) => SBFrame(%p): %s",
62 lldb_object_sp.get(), m_opaque_sp.get(), sstr.GetData());
Caroline Tice61ba7ec2010-10-26 23:49:36 +000063
Caroline Tice7826c882010-10-26 03:11:13 +000064 }
Chris Lattner24943d22010-06-08 16:52:24 +000065}
66
Greg Clayton538eb822010-11-05 23:17:00 +000067SBFrame::SBFrame(const SBFrame &rhs) :
68 m_opaque_sp (rhs.m_opaque_sp)
69{
70}
71
72const SBFrame &
73SBFrame::operator = (const SBFrame &rhs)
74{
75 if (this != &rhs)
76 m_opaque_sp = rhs.m_opaque_sp;
77 return *this;
78}
79
Chris Lattner24943d22010-06-08 16:52:24 +000080SBFrame::~SBFrame()
81{
82}
83
84
85void
Greg Clayton4e9267d2010-12-14 18:39:31 +000086SBFrame::SetFrame (const StackFrameSP &lldb_object_sp)
Chris Lattner24943d22010-06-08 16:52:24 +000087{
Greg Claytona66ba462010-10-30 04:51:46 +000088 void *old_ptr = m_opaque_sp.get();
Greg Clayton63094e02010-06-23 01:19:29 +000089 m_opaque_sp = lldb_object_sp;
Greg Clayton4e9267d2010-12-14 18:39:31 +000090 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +000091
92 if (log)
93 {
94 log->Printf ("SBFrame(%p)::SetFrame(sp=%p) := SBFrame(%p)",
95 old_ptr, lldb_object_sp.get(), m_opaque_sp.get());
96 }
97
Chris Lattner24943d22010-06-08 16:52:24 +000098}
99
100
101bool
102SBFrame::IsValid() const
103{
Greg Clayton63094e02010-06-23 01:19:29 +0000104 return (m_opaque_sp.get() != NULL);
Chris Lattner24943d22010-06-08 16:52:24 +0000105}
106
107SBSymbolContext
108SBFrame::GetSymbolContext (uint32_t resolve_scope) const
109{
Caroline Tice7826c882010-10-26 03:11:13 +0000110
Chris Lattner24943d22010-06-08 16:52:24 +0000111 SBSymbolContext sb_sym_ctx;
Greg Clayton63094e02010-06-23 01:19:29 +0000112 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000113 {
114 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
Greg Clayton63094e02010-06-23 01:19:29 +0000115 sb_sym_ctx.SetSymbolContext(&m_opaque_sp->GetSymbolContext (resolve_scope));
Greg Claytonbdcda462010-12-20 20:49:23 +0000116 }
Caroline Tice7826c882010-10-26 03:11:13 +0000117
Greg Clayton4e9267d2010-12-14 18:39:31 +0000118 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000119 if (log)
Greg Claytona66ba462010-10-30 04:51:46 +0000120 log->Printf ("SBFrame(%p)::GetSymbolContext (resolve_scope=0x%8.8x) => SBSymbolContext(%p)",
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000121 m_opaque_sp.get(), resolve_scope, sb_sym_ctx.get());
Caroline Tice7826c882010-10-26 03:11:13 +0000122
Chris Lattner24943d22010-06-08 16:52:24 +0000123 return sb_sym_ctx;
124}
125
126SBModule
127SBFrame::GetModule () const
128{
Greg Claytondd62d722010-12-14 04:58:53 +0000129 SBModule sb_module;
130 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000131 {
132 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
Greg Claytondd62d722010-12-14 04:58:53 +0000133 *sb_module = m_opaque_sp->GetSymbolContext (eSymbolContextModule).module_sp;
Greg Claytonbdcda462010-12-20 20:49:23 +0000134 }
Greg Claytondd62d722010-12-14 04:58:53 +0000135
Greg Clayton4e9267d2010-12-14 18:39:31 +0000136 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000137 if (log)
138 log->Printf ("SBFrame(%p)::GetModule () => SBModule(%p)",
139 m_opaque_sp.get(), sb_module.get());
140
Chris Lattner24943d22010-06-08 16:52:24 +0000141 return sb_module;
142}
143
144SBCompileUnit
145SBFrame::GetCompileUnit () const
146{
Greg Claytondd62d722010-12-14 04:58:53 +0000147 SBCompileUnit sb_comp_unit;
148 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000149 {
150 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
Greg Claytondd62d722010-12-14 04:58:53 +0000151 sb_comp_unit.reset (m_opaque_sp->GetSymbolContext (eSymbolContextCompUnit).comp_unit);
Greg Claytonbdcda462010-12-20 20:49:23 +0000152 }
Greg Clayton4e9267d2010-12-14 18:39:31 +0000153 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000154 if (log)
Greg Claytona66ba462010-10-30 04:51:46 +0000155 log->Printf ("SBFrame(%p)::GetModule () => SBCompileUnit(%p)",
156 m_opaque_sp.get(), sb_comp_unit.get());
Caroline Tice7826c882010-10-26 03:11:13 +0000157
Chris Lattner24943d22010-06-08 16:52:24 +0000158 return sb_comp_unit;
159}
160
161SBFunction
162SBFrame::GetFunction () const
163{
Greg Claytondd62d722010-12-14 04:58:53 +0000164 SBFunction sb_function;
165 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000166 {
167 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
Greg Claytondd62d722010-12-14 04:58:53 +0000168 sb_function.reset(m_opaque_sp->GetSymbolContext (eSymbolContextFunction).function);
Greg Claytonbdcda462010-12-20 20:49:23 +0000169 }
Greg Clayton4e9267d2010-12-14 18:39:31 +0000170 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000171 if (log)
172 log->Printf ("SBFrame(%p)::GetFunction () => SBFunction(%p)",
173 m_opaque_sp.get(), sb_function.get());
174
Chris Lattner24943d22010-06-08 16:52:24 +0000175 return sb_function;
176}
177
Greg Clayton8f1e08b2010-10-04 18:37:52 +0000178SBSymbol
179SBFrame::GetSymbol () const
180{
Greg Claytondd62d722010-12-14 04:58:53 +0000181 SBSymbol sb_symbol;
182 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000183 {
184 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
Greg Claytondd62d722010-12-14 04:58:53 +0000185 sb_symbol.reset(m_opaque_sp->GetSymbolContext (eSymbolContextSymbol).symbol);
Greg Claytonbdcda462010-12-20 20:49:23 +0000186 }
Greg Clayton4e9267d2010-12-14 18:39:31 +0000187 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000188 if (log)
189 log->Printf ("SBFrame(%p)::GetSymbol () => SBSymbol(%p)",
190 m_opaque_sp.get(), sb_symbol.get());
Greg Clayton8f1e08b2010-10-04 18:37:52 +0000191 return sb_symbol;
192}
193
Chris Lattner24943d22010-06-08 16:52:24 +0000194SBBlock
195SBFrame::GetBlock () const
196{
Greg Claytondd62d722010-12-14 04:58:53 +0000197 SBBlock sb_block;
198 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000199 {
200 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
Greg Claytondd62d722010-12-14 04:58:53 +0000201 sb_block.reset (m_opaque_sp->GetSymbolContext (eSymbolContextBlock).block);
Greg Claytonbdcda462010-12-20 20:49:23 +0000202 }
Greg Clayton4e9267d2010-12-14 18:39:31 +0000203 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000204 if (log)
205 log->Printf ("SBFrame(%p)::GetBlock () => SBBlock(%p)",
206 m_opaque_sp.get(), sb_block.get());
Chris Lattner24943d22010-06-08 16:52:24 +0000207 return sb_block;
208}
209
Greg Clayton69aa5d92010-09-07 04:20:48 +0000210SBBlock
211SBFrame::GetFrameBlock () const
212{
Greg Claytondd62d722010-12-14 04:58:53 +0000213 SBBlock sb_block;
214 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000215 {
216 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
Greg Claytondd62d722010-12-14 04:58:53 +0000217 sb_block.reset(m_opaque_sp->GetFrameBlock ());
Greg Claytonbdcda462010-12-20 20:49:23 +0000218 }
Greg Clayton4e9267d2010-12-14 18:39:31 +0000219 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000220 if (log)
221 log->Printf ("SBFrame(%p)::GetFrameBlock () => SBBlock(%p)",
222 m_opaque_sp.get(), sb_block.get());
Greg Clayton69aa5d92010-09-07 04:20:48 +0000223 return sb_block;
224}
225
Chris Lattner24943d22010-06-08 16:52:24 +0000226SBLineEntry
227SBFrame::GetLineEntry () const
228{
Greg Claytondd62d722010-12-14 04:58:53 +0000229 SBLineEntry sb_line_entry;
230 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000231 {
232 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
Greg Claytondd62d722010-12-14 04:58:53 +0000233 sb_line_entry.SetLineEntry (m_opaque_sp->GetSymbolContext (eSymbolContextLineEntry).line_entry);
Greg Claytonbdcda462010-12-20 20:49:23 +0000234 }
Greg Clayton4e9267d2010-12-14 18:39:31 +0000235 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000236 if (log)
237 log->Printf ("SBFrame(%p)::GetLineEntry () => SBLineEntry(%p)",
238 m_opaque_sp.get(), sb_line_entry.get());
Chris Lattner24943d22010-06-08 16:52:24 +0000239 return sb_line_entry;
240}
241
242uint32_t
243SBFrame::GetFrameID () const
244{
Greg Claytona66ba462010-10-30 04:51:46 +0000245 uint32_t frame_idx = m_opaque_sp ? m_opaque_sp->GetFrameIndex () : UINT32_MAX;
246
Greg Clayton4e9267d2010-12-14 18:39:31 +0000247 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000248 if (log)
249 log->Printf ("SBFrame(%p)::GetFrameID () => %u",
250 m_opaque_sp.get(), frame_idx);
251 return frame_idx;
Chris Lattner24943d22010-06-08 16:52:24 +0000252}
253
Greg Clayton4e9267d2010-12-14 18:39:31 +0000254addr_t
Chris Lattner24943d22010-06-08 16:52:24 +0000255SBFrame::GetPC () const
256{
Greg Clayton4e9267d2010-12-14 18:39:31 +0000257 addr_t addr = LLDB_INVALID_ADDRESS;
Greg Clayton63094e02010-06-23 01:19:29 +0000258 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000259 {
260 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
Greg Clayton107e53d2011-07-06 04:07:21 +0000261 addr = m_opaque_sp->GetFrameCodeAddress().GetOpcodeLoadAddress (&m_opaque_sp->GetThread().GetProcess().GetTarget());
Greg Claytonbdcda462010-12-20 20:49:23 +0000262 }
Caroline Tice7826c882010-10-26 03:11:13 +0000263
Greg Clayton4e9267d2010-12-14 18:39:31 +0000264 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000265 if (log)
Greg Clayton49ce6822010-10-31 03:01:06 +0000266 log->Printf ("SBFrame(%p)::GetPC () => 0x%llx", m_opaque_sp.get(), addr);
Caroline Tice7826c882010-10-26 03:11:13 +0000267
268 return addr;
Chris Lattner24943d22010-06-08 16:52:24 +0000269}
270
271bool
Greg Clayton4e9267d2010-12-14 18:39:31 +0000272SBFrame::SetPC (addr_t new_pc)
Chris Lattner24943d22010-06-08 16:52:24 +0000273{
Caroline Tice7826c882010-10-26 03:11:13 +0000274 bool ret_val = false;
Greg Clayton63094e02010-06-23 01:19:29 +0000275 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000276 {
277 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
Caroline Tice7826c882010-10-26 03:11:13 +0000278 ret_val = m_opaque_sp->GetRegisterContext()->SetPC (new_pc);
Greg Claytonbdcda462010-12-20 20:49:23 +0000279 }
Caroline Tice7826c882010-10-26 03:11:13 +0000280
Greg Clayton4e9267d2010-12-14 18:39:31 +0000281 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000282 if (log)
Greg Claytona66ba462010-10-30 04:51:46 +0000283 log->Printf ("SBFrame(%p)::SetPC (new_pc=0x%llx) => %i",
284 m_opaque_sp.get(), new_pc, ret_val);
Caroline Tice7826c882010-10-26 03:11:13 +0000285
286 return ret_val;
Chris Lattner24943d22010-06-08 16:52:24 +0000287}
288
Greg Clayton4e9267d2010-12-14 18:39:31 +0000289addr_t
Chris Lattner24943d22010-06-08 16:52:24 +0000290SBFrame::GetSP () const
291{
Greg Claytona66ba462010-10-30 04:51:46 +0000292 addr_t addr = LLDB_INVALID_ADDRESS;
Greg Clayton63094e02010-06-23 01:19:29 +0000293 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000294 {
295 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
Greg Claytona66ba462010-10-30 04:51:46 +0000296 addr = m_opaque_sp->GetRegisterContext()->GetSP();
Greg Claytonbdcda462010-12-20 20:49:23 +0000297 }
Greg Clayton4e9267d2010-12-14 18:39:31 +0000298 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000299 if (log)
Greg Clayton49ce6822010-10-31 03:01:06 +0000300 log->Printf ("SBFrame(%p)::GetSP () => 0x%llx", m_opaque_sp.get(), addr);
Greg Claytona66ba462010-10-30 04:51:46 +0000301
302 return addr;
Chris Lattner24943d22010-06-08 16:52:24 +0000303}
304
305
Greg Clayton4e9267d2010-12-14 18:39:31 +0000306addr_t
Chris Lattner24943d22010-06-08 16:52:24 +0000307SBFrame::GetFP () const
308{
Greg Clayton4e9267d2010-12-14 18:39:31 +0000309 addr_t addr = LLDB_INVALID_ADDRESS;
Greg Clayton63094e02010-06-23 01:19:29 +0000310 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000311 {
312 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
Caroline Tice7826c882010-10-26 03:11:13 +0000313 addr = m_opaque_sp->GetRegisterContext()->GetFP();
Greg Claytonbdcda462010-12-20 20:49:23 +0000314 }
Caroline Tice7826c882010-10-26 03:11:13 +0000315
Greg Clayton4e9267d2010-12-14 18:39:31 +0000316 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000317 if (log)
Greg Clayton49ce6822010-10-31 03:01:06 +0000318 log->Printf ("SBFrame(%p)::GetFP () => 0x%llx", m_opaque_sp.get(), addr);
Caroline Tice7826c882010-10-26 03:11:13 +0000319 return addr;
Chris Lattner24943d22010-06-08 16:52:24 +0000320}
321
322
323SBAddress
324SBFrame::GetPCAddress () const
325{
326 SBAddress sb_addr;
Greg Clayton63094e02010-06-23 01:19:29 +0000327 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000328 {
329 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
Greg Claytonb04e7a82010-08-24 21:05:24 +0000330 sb_addr.SetAddress (&m_opaque_sp->GetFrameCodeAddress());
Greg Claytonbdcda462010-12-20 20:49:23 +0000331 }
Greg Clayton4e9267d2010-12-14 18:39:31 +0000332 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000333 if (log)
334 log->Printf ("SBFrame(%p)::GetPCAddress () => SBAddress(%p)", m_opaque_sp.get(), sb_addr.get());
Chris Lattner24943d22010-06-08 16:52:24 +0000335 return sb_addr;
336}
337
338void
339SBFrame::Clear()
340{
Greg Clayton63094e02010-06-23 01:19:29 +0000341 m_opaque_sp.reset();
Chris Lattner24943d22010-06-08 16:52:24 +0000342}
343
344SBValue
Greg Clayton4e9267d2010-12-14 18:39:31 +0000345SBFrame::FindVariable (const char *name)
Chris Lattner24943d22010-06-08 16:52:24 +0000346{
Greg Clayton582ed0e2011-06-18 20:06:08 +0000347 SBValue value;
348 if (m_opaque_sp)
349 {
350 lldb::DynamicValueType use_dynamic = m_opaque_sp->CalculateTarget()->GetPreferDynamicValue();
351 value = FindVariable (name, use_dynamic);
352 }
353 return value;
Jim Inghame41494a2011-04-16 00:01:13 +0000354}
355
356SBValue
Jim Ingham10de7d12011-05-04 03:43:18 +0000357SBFrame::FindVariable (const char *name, lldb::DynamicValueType use_dynamic)
Jim Inghame41494a2011-04-16 00:01:13 +0000358{
Greg Clayton4e9267d2010-12-14 18:39:31 +0000359 VariableSP var_sp;
Jim Ingham47da8102011-04-22 23:53:53 +0000360 SBValue sb_value;
361
Greg Clayton4e9267d2010-12-14 18:39:31 +0000362 if (m_opaque_sp && name && name[0])
Chris Lattner24943d22010-06-08 16:52:24 +0000363 {
Greg Clayton4e9267d2010-12-14 18:39:31 +0000364 VariableList variable_list;
Greg Claytonbdcda462010-12-20 20:49:23 +0000365 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
Greg Claytondd62d722010-12-14 04:58:53 +0000366 SymbolContext sc (m_opaque_sp->GetSymbolContext (eSymbolContextBlock));
Chris Lattner24943d22010-06-08 16:52:24 +0000367
Greg Claytondd62d722010-12-14 04:58:53 +0000368 if (sc.block)
Chris Lattner24943d22010-06-08 16:52:24 +0000369 {
Greg Claytondd62d722010-12-14 04:58:53 +0000370 const bool can_create = true;
371 const bool get_parent_variables = true;
372 const bool stop_if_block_is_inlined_function = true;
373
374 if (sc.block->AppendVariables (can_create,
375 get_parent_variables,
376 stop_if_block_is_inlined_function,
377 &variable_list))
378 {
Greg Clayton4e9267d2010-12-14 18:39:31 +0000379 var_sp = variable_list.FindVariable (ConstString(name));
Greg Claytondd62d722010-12-14 04:58:53 +0000380 }
Chris Lattner24943d22010-06-08 16:52:24 +0000381 }
Greg Clayton582ed0e2011-06-18 20:06:08 +0000382
383 if (var_sp)
384 *sb_value = ValueObjectSP (m_opaque_sp->GetValueObjectForFrameVariable(var_sp, use_dynamic));
385
Chris Lattner24943d22010-06-08 16:52:24 +0000386 }
Caroline Tice98f930f2010-09-20 05:20:02 +0000387
Greg Clayton4e9267d2010-12-14 18:39:31 +0000388 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000389 if (log)
Greg Clayton4e9267d2010-12-14 18:39:31 +0000390 log->Printf ("SBFrame(%p)::FindVariable (name=\"%s\") => SBValue(%p)",
391 m_opaque_sp.get(), name, sb_value.get());
Greg Claytona66ba462010-10-30 04:51:46 +0000392
Chris Lattner24943d22010-06-08 16:52:24 +0000393 return sb_value;
394}
395
396SBValue
Greg Clayton4e9267d2010-12-14 18:39:31 +0000397SBFrame::FindValue (const char *name, ValueType value_type)
Chris Lattner24943d22010-06-08 16:52:24 +0000398{
Greg Clayton582ed0e2011-06-18 20:06:08 +0000399 SBValue value;
400 if (m_opaque_sp)
401 {
402 lldb::DynamicValueType use_dynamic = m_opaque_sp->CalculateTarget()->GetPreferDynamicValue();
403 value = FindValue (name, value_type, use_dynamic);
404 }
405 return value;
Jim Inghame41494a2011-04-16 00:01:13 +0000406}
407
408SBValue
Jim Ingham10de7d12011-05-04 03:43:18 +0000409SBFrame::FindValue (const char *name, ValueType value_type, lldb::DynamicValueType use_dynamic)
Jim Inghame41494a2011-04-16 00:01:13 +0000410{
Greg Clayton4e9267d2010-12-14 18:39:31 +0000411 SBValue sb_value;
412 if (m_opaque_sp && name && name[0])
Chris Lattner24943d22010-06-08 16:52:24 +0000413 {
Greg Claytonbdcda462010-12-20 20:49:23 +0000414 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
Greg Clayton4e9267d2010-12-14 18:39:31 +0000415
416 switch (value_type)
Chris Lattner24943d22010-06-08 16:52:24 +0000417 {
Greg Clayton4e9267d2010-12-14 18:39:31 +0000418 case eValueTypeVariableGlobal: // global variable
419 case eValueTypeVariableStatic: // static variable
420 case eValueTypeVariableArgument: // function argument variables
421 case eValueTypeVariableLocal: // function local variables
Chris Lattner24943d22010-06-08 16:52:24 +0000422 {
Greg Clayton4e9267d2010-12-14 18:39:31 +0000423 VariableList *variable_list = m_opaque_sp->GetVariableList(true);
424
425 SymbolContext sc (m_opaque_sp->GetSymbolContext (eSymbolContextBlock));
426
427 const bool can_create = true;
428 const bool get_parent_variables = true;
429 const bool stop_if_block_is_inlined_function = true;
430
431 if (sc.block && sc.block->AppendVariables (can_create,
432 get_parent_variables,
433 stop_if_block_is_inlined_function,
434 variable_list))
Johnny Chenc35750a2010-11-19 18:07:14 +0000435 {
Greg Clayton4e9267d2010-12-14 18:39:31 +0000436 ConstString const_name(name);
437 const uint32_t num_variables = variable_list->GetSize();
438 for (uint32_t i = 0; i < num_variables; ++i)
Johnny Chenc35750a2010-11-19 18:07:14 +0000439 {
Greg Clayton4e9267d2010-12-14 18:39:31 +0000440 VariableSP variable_sp (variable_list->GetVariableAtIndex(i));
441 if (variable_sp &&
442 variable_sp->GetScope() == value_type &&
443 variable_sp->GetName() == const_name)
444 {
Jim Inghame41494a2011-04-16 00:01:13 +0000445 *sb_value = ValueObjectSP (m_opaque_sp->GetValueObjectForFrameVariable(variable_sp,
446 use_dynamic));
Greg Clayton4e9267d2010-12-14 18:39:31 +0000447 break;
448 }
Johnny Chenc35750a2010-11-19 18:07:14 +0000449 }
450 }
Chris Lattner24943d22010-06-08 16:52:24 +0000451 }
Greg Clayton4e9267d2010-12-14 18:39:31 +0000452 break;
453
454 case eValueTypeRegister: // stack frame register value
455 {
Greg Clayton08d7d3a2011-01-06 22:15:06 +0000456 RegisterContextSP reg_ctx (m_opaque_sp->GetRegisterContext());
Greg Clayton4e9267d2010-12-14 18:39:31 +0000457 if (reg_ctx)
458 {
459 const uint32_t num_regs = reg_ctx->GetRegisterCount();
460 for (uint32_t reg_idx = 0; reg_idx < num_regs; ++reg_idx)
461 {
462 const RegisterInfo *reg_info = reg_ctx->GetRegisterInfoAtIndex (reg_idx);
463 if (reg_info &&
464 ((reg_info->name && strcasecmp (reg_info->name, name) == 0) ||
465 (reg_info->alt_name && strcasecmp (reg_info->alt_name, name) == 0)))
466 {
Jim Ingham47da8102011-04-22 23:53:53 +0000467 *sb_value = ValueObjectRegister::Create (m_opaque_sp.get(), reg_ctx, reg_idx);
Greg Clayton4e9267d2010-12-14 18:39:31 +0000468 }
469 }
470 }
471 }
472 break;
473
474 case eValueTypeRegisterSet: // A collection of stack frame register values
475 {
Greg Clayton08d7d3a2011-01-06 22:15:06 +0000476 RegisterContextSP reg_ctx (m_opaque_sp->GetRegisterContext());
Greg Clayton4e9267d2010-12-14 18:39:31 +0000477 if (reg_ctx)
478 {
479 const uint32_t num_sets = reg_ctx->GetRegisterSetCount();
480 for (uint32_t set_idx = 0; set_idx < num_sets; ++set_idx)
481 {
482 const RegisterSet *reg_set = reg_ctx->GetRegisterSet (set_idx);
483 if (reg_set &&
484 ((reg_set->name && strcasecmp (reg_set->name, name) == 0) ||
485 (reg_set->short_name && strcasecmp (reg_set->short_name, name) == 0)))
486 {
Jim Ingham47da8102011-04-22 23:53:53 +0000487 *sb_value = ValueObjectRegisterSet::Create (m_opaque_sp.get(), reg_ctx, set_idx);
Greg Clayton4e9267d2010-12-14 18:39:31 +0000488 }
489 }
490 }
491 }
492 break;
493
494 case eValueTypeConstResult: // constant result variables
495 {
496 ConstString const_name(name);
497 ClangExpressionVariableSP expr_var_sp (m_opaque_sp->GetThread().GetProcess().GetTarget().GetPersistentVariables().GetVariable (const_name));
498 if (expr_var_sp)
499 *sb_value = expr_var_sp->GetValueObject();
500 }
501 break;
502
503 default:
504 break;
Chris Lattner24943d22010-06-08 16:52:24 +0000505 }
506 }
Caroline Tice98f930f2010-09-20 05:20:02 +0000507
Greg Clayton4e9267d2010-12-14 18:39:31 +0000508 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000509 if (log)
Greg Clayton4e9267d2010-12-14 18:39:31 +0000510 log->Printf ("SBFrame(%p)::FindVariableInScope (name=\"%s\", value_type=%i) => SBValue(%p)",
511 m_opaque_sp.get(), name, value_type, sb_value.get());
Greg Claytona66ba462010-10-30 04:51:46 +0000512
513
Chris Lattner24943d22010-06-08 16:52:24 +0000514 return sb_value;
515}
516
517bool
518SBFrame::operator == (const SBFrame &rhs) const
519{
Greg Clayton63094e02010-06-23 01:19:29 +0000520 return m_opaque_sp.get() == rhs.m_opaque_sp.get();
Chris Lattner24943d22010-06-08 16:52:24 +0000521}
522
523bool
524SBFrame::operator != (const SBFrame &rhs) const
525{
Greg Clayton63094e02010-06-23 01:19:29 +0000526 return m_opaque_sp.get() != rhs.m_opaque_sp.get();
Chris Lattner24943d22010-06-08 16:52:24 +0000527}
528
529lldb_private::StackFrame *
530SBFrame::operator->() const
531{
Greg Clayton63094e02010-06-23 01:19:29 +0000532 return m_opaque_sp.get();
Chris Lattner24943d22010-06-08 16:52:24 +0000533}
534
535lldb_private::StackFrame *
536SBFrame::get() const
537{
Greg Clayton63094e02010-06-23 01:19:29 +0000538 return m_opaque_sp.get();
Chris Lattner24943d22010-06-08 16:52:24 +0000539}
540
Greg Claytond68e0892011-09-09 23:04:00 +0000541lldb::StackFrameSP &
542SBFrame::get_sp()
Greg Clayton1ebdcc72011-01-21 06:11:58 +0000543{
544 return m_opaque_sp;
545}
Chris Lattner24943d22010-06-08 16:52:24 +0000546
547SBThread
548SBFrame::GetThread () const
549{
Greg Clayton4e9267d2010-12-14 18:39:31 +0000550 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000551
Greg Claytondd62d722010-12-14 04:58:53 +0000552 SBThread sb_thread;
Greg Clayton90c52142012-01-30 02:53:15 +0000553 ThreadSP thread_sp;
Greg Claytondd62d722010-12-14 04:58:53 +0000554 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000555 {
556 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
Greg Clayton90c52142012-01-30 02:53:15 +0000557 thread_sp = m_opaque_sp->GetThread().shared_from_this();
558 sb_thread.SetThread (thread_sp);
Greg Claytonbdcda462010-12-20 20:49:23 +0000559 }
Caroline Tice7826c882010-10-26 03:11:13 +0000560
561 if (log)
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000562 {
563 SBStream sstr;
564 sb_thread.GetDescription (sstr);
Greg Claytona66ba462010-10-30 04:51:46 +0000565 log->Printf ("SBFrame(%p)::GetThread () => SBThread(%p): %s", m_opaque_sp.get(),
Greg Clayton90c52142012-01-30 02:53:15 +0000566 thread_sp.get(), sstr.GetData());
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000567 }
Caroline Tice7826c882010-10-26 03:11:13 +0000568
Chris Lattner24943d22010-06-08 16:52:24 +0000569 return sb_thread;
570}
571
572const char *
573SBFrame::Disassemble () const
574{
Greg Claytona66ba462010-10-30 04:51:46 +0000575 const char *disassembly = NULL;
Greg Clayton63094e02010-06-23 01:19:29 +0000576 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000577 {
578 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
Greg Claytona66ba462010-10-30 04:51:46 +0000579 disassembly = m_opaque_sp->Disassemble();
Greg Claytonbdcda462010-12-20 20:49:23 +0000580 }
Greg Clayton4e9267d2010-12-14 18:39:31 +0000581 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000582
583 if (log)
584 log->Printf ("SBFrame(%p)::Disassemble () => %s", m_opaque_sp.get(), disassembly);
585
586 return disassembly;
Chris Lattner24943d22010-06-08 16:52:24 +0000587}
588
589
Chris Lattner24943d22010-06-08 16:52:24 +0000590SBValueList
591SBFrame::GetVariables (bool arguments,
592 bool locals,
593 bool statics,
594 bool in_scope_only)
595{
Greg Clayton582ed0e2011-06-18 20:06:08 +0000596 SBValueList value_list;
597 if (m_opaque_sp)
598 {
599 lldb::DynamicValueType use_dynamic = m_opaque_sp->CalculateTarget()->GetPreferDynamicValue();
600 value_list = GetVariables (arguments, locals, statics, in_scope_only, use_dynamic);
601 }
602 return value_list;
Jim Inghame41494a2011-04-16 00:01:13 +0000603}
604
605SBValueList
606SBFrame::GetVariables (bool arguments,
607 bool locals,
608 bool statics,
609 bool in_scope_only,
Jim Ingham10de7d12011-05-04 03:43:18 +0000610 lldb::DynamicValueType use_dynamic)
Jim Inghame41494a2011-04-16 00:01:13 +0000611{
Greg Clayton4e9267d2010-12-14 18:39:31 +0000612 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000613
614 if (log)
Greg Claytona66ba462010-10-30 04:51:46 +0000615 log->Printf ("SBFrame(%p)::GetVariables (arguments=%i, locals=%i, statics=%i, in_scope_only=%i)",
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000616 m_opaque_sp.get(),
Greg Claytona66ba462010-10-30 04:51:46 +0000617 arguments,
618 locals,
619 statics,
620 in_scope_only);
Caroline Tice7826c882010-10-26 03:11:13 +0000621
Chris Lattner24943d22010-06-08 16:52:24 +0000622 SBValueList value_list;
Greg Clayton63094e02010-06-23 01:19:29 +0000623 if (m_opaque_sp)
Chris Lattner24943d22010-06-08 16:52:24 +0000624 {
Greg Claytonbdcda462010-12-20 20:49:23 +0000625
Chris Lattner24943d22010-06-08 16:52:24 +0000626 size_t i;
Greg Claytonbdcda462010-12-20 20:49:23 +0000627 VariableList *variable_list = NULL;
628 // Scope for locker
629 {
630 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
631 variable_list = m_opaque_sp->GetVariableList(true);
632 }
Chris Lattner24943d22010-06-08 16:52:24 +0000633 if (variable_list)
634 {
635 const size_t num_variables = variable_list->GetSize();
636 if (num_variables)
637 {
638 for (i = 0; i < num_variables; ++i)
639 {
640 VariableSP variable_sp (variable_list->GetVariableAtIndex(i));
641 if (variable_sp)
642 {
643 bool add_variable = false;
644 switch (variable_sp->GetScope())
645 {
646 case eValueTypeVariableGlobal:
647 case eValueTypeVariableStatic:
648 add_variable = statics;
649 break;
650
651 case eValueTypeVariableArgument:
652 add_variable = arguments;
653 break;
654
655 case eValueTypeVariableLocal:
656 add_variable = locals;
657 break;
Greg Clayton54e7afa2010-07-09 20:39:50 +0000658
659 default:
660 break;
Chris Lattner24943d22010-06-08 16:52:24 +0000661 }
662 if (add_variable)
663 {
Greg Clayton63094e02010-06-23 01:19:29 +0000664 if (in_scope_only && !variable_sp->IsInScope(m_opaque_sp.get()))
Chris Lattner24943d22010-06-08 16:52:24 +0000665 continue;
666
Jim Inghame41494a2011-04-16 00:01:13 +0000667 value_list.Append(m_opaque_sp->GetValueObjectForFrameVariable (variable_sp, use_dynamic));
Chris Lattner24943d22010-06-08 16:52:24 +0000668 }
669 }
670 }
671 }
Greg Clayton17dae082010-09-02 02:59:18 +0000672 }
Chris Lattner24943d22010-06-08 16:52:24 +0000673 }
Caroline Tice7826c882010-10-26 03:11:13 +0000674
675 if (log)
676 {
Greg Claytona66ba462010-10-30 04:51:46 +0000677 log->Printf ("SBFrame(%p)::GetVariables (...) => SBValueList(%p)", m_opaque_sp.get(),
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000678 value_list.get());
Caroline Tice7826c882010-10-26 03:11:13 +0000679 }
680
Chris Lattner24943d22010-06-08 16:52:24 +0000681 return value_list;
682}
683
Greg Clayton4e9267d2010-12-14 18:39:31 +0000684SBValueList
Chris Lattner24943d22010-06-08 16:52:24 +0000685SBFrame::GetRegisters ()
686{
Greg Clayton4e9267d2010-12-14 18:39:31 +0000687 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000688
Chris Lattner24943d22010-06-08 16:52:24 +0000689 SBValueList value_list;
Greg Clayton63094e02010-06-23 01:19:29 +0000690 if (m_opaque_sp)
Chris Lattner24943d22010-06-08 16:52:24 +0000691 {
Greg Claytonbdcda462010-12-20 20:49:23 +0000692 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
Greg Clayton08d7d3a2011-01-06 22:15:06 +0000693 RegisterContextSP reg_ctx (m_opaque_sp->GetRegisterContext());
Chris Lattner24943d22010-06-08 16:52:24 +0000694 if (reg_ctx)
695 {
696 const uint32_t num_sets = reg_ctx->GetRegisterSetCount();
697 for (uint32_t set_idx = 0; set_idx < num_sets; ++set_idx)
698 {
Jim Ingham47da8102011-04-22 23:53:53 +0000699 value_list.Append(ValueObjectRegisterSet::Create (m_opaque_sp.get(), reg_ctx, set_idx));
Chris Lattner24943d22010-06-08 16:52:24 +0000700 }
701 }
702 }
Caroline Tice7826c882010-10-26 03:11:13 +0000703
704 if (log)
Greg Claytona66ba462010-10-30 04:51:46 +0000705 log->Printf ("SBFrame(%p)::Registers () => SBValueList(%p)", m_opaque_sp.get(), value_list.get());
Caroline Tice7826c882010-10-26 03:11:13 +0000706
Chris Lattner24943d22010-06-08 16:52:24 +0000707 return value_list;
708}
709
Caroline Tice98f930f2010-09-20 05:20:02 +0000710bool
711SBFrame::GetDescription (SBStream &description)
712{
Greg Clayton96154be2011-11-13 06:57:31 +0000713 Stream &strm = description.ref();
714
Caroline Tice98f930f2010-09-20 05:20:02 +0000715 if (m_opaque_sp)
716 {
Greg Claytonbdcda462010-12-20 20:49:23 +0000717 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
Greg Clayton96154be2011-11-13 06:57:31 +0000718 m_opaque_sp->DumpUsingSettingsFormat (&strm);
Caroline Tice98f930f2010-09-20 05:20:02 +0000719 }
720 else
Greg Clayton96154be2011-11-13 06:57:31 +0000721 strm.PutCString ("No value");
Caroline Tice98f930f2010-09-20 05:20:02 +0000722
723 return true;
724}
Greg Clayton66ed2fb2010-10-05 00:00:42 +0000725
Greg Clayton4e9267d2010-12-14 18:39:31 +0000726SBValue
Greg Clayton66ed2fb2010-10-05 00:00:42 +0000727SBFrame::EvaluateExpression (const char *expr)
728{
Greg Clayton582ed0e2011-06-18 20:06:08 +0000729 SBValue result;
730 if (m_opaque_sp)
731 {
732 lldb::DynamicValueType use_dynamic = m_opaque_sp->CalculateTarget()->GetPreferDynamicValue();
733 result = EvaluateExpression (expr, use_dynamic);
734 }
735 return result;
Jim Inghame41494a2011-04-16 00:01:13 +0000736}
737
738SBValue
Jim Ingham10de7d12011-05-04 03:43:18 +0000739SBFrame::EvaluateExpression (const char *expr, lldb::DynamicValueType fetch_dynamic_value)
Jim Inghame41494a2011-04-16 00:01:13 +0000740{
Greg Clayton4e9267d2010-12-14 18:39:31 +0000741 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Sean Callanan94d255f2010-12-07 22:55:01 +0000742
Greg Clayton4e9267d2010-12-14 18:39:31 +0000743 LogSP expr_log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_EXPRESSIONS));
Greg Claytona66ba462010-10-30 04:51:46 +0000744
Johnny Chenee6e7902011-08-10 22:06:24 +0000745 ExecutionResults exe_results;
Greg Clayton4e9267d2010-12-14 18:39:31 +0000746 SBValue expr_result;
Greg Claytona66ba462010-10-30 04:51:46 +0000747 if (log)
748 log->Printf ("SBFrame(%p)::EvaluateExpression (expr=\"%s\")...", m_opaque_sp.get(), expr);
749
Greg Clayton66ed2fb2010-10-05 00:00:42 +0000750 if (m_opaque_sp)
751 {
Greg Clayton582ed0e2011-06-18 20:06:08 +0000752 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
753
Greg Clayton87ac9022011-06-25 04:35:01 +0000754
755 StreamString frame_description;
756 m_opaque_sp->DumpUsingSettingsFormat (&frame_description);
757
758 Host::SetCrashDescriptionWithFormat ("SBFrame::EvaluateExpression (expr = \"%s\", fetch_dynamic_value = %u) %s",
759 expr, fetch_dynamic_value, frame_description.GetString().c_str());
760
Sean Callanandaa6efe2011-12-21 22:22:58 +0000761 const bool coerce_to_id = false;
Greg Clayton427f2902010-12-14 02:59:59 +0000762 const bool unwind_on_error = true;
Sean Callanan6a925532011-01-13 08:53:35 +0000763 const bool keep_in_memory = false;
Greg Clayton427f2902010-12-14 02:59:59 +0000764
Jim Inghame41494a2011-04-16 00:01:13 +0000765 exe_results = m_opaque_sp->GetThread().GetProcess().GetTarget().EvaluateExpression(expr,
Sean Callanan47dc4572011-09-15 02:13:07 +0000766 m_opaque_sp.get(),
767 eExecutionPolicyOnlyWhenNeeded,
Sean Callanandaa6efe2011-12-21 22:22:58 +0000768 coerce_to_id,
Jim Inghame41494a2011-04-16 00:01:13 +0000769 unwind_on_error,
Jim Inghame41494a2011-04-16 00:01:13 +0000770 keep_in_memory,
Jim Ingham10de7d12011-05-04 03:43:18 +0000771 fetch_dynamic_value,
Jim Inghame41494a2011-04-16 00:01:13 +0000772 *expr_result);
Greg Clayton668a6c72011-11-10 18:31:53 +0000773
774 Host::SetCrashDescription (NULL);
Greg Clayton66ed2fb2010-10-05 00:00:42 +0000775 }
Greg Claytona66ba462010-10-30 04:51:46 +0000776
Sean Callanan94d255f2010-12-07 22:55:01 +0000777 if (expr_log)
Jim Inghame41494a2011-04-16 00:01:13 +0000778 expr_log->Printf("** [SBFrame::EvaluateExpression] Expression result is %s, summary %s **",
Greg Clayton0fb0bcc2011-08-03 22:57:10 +0000779 expr_result.GetValue(),
780 expr_result.GetSummary());
Sean Callanan94d255f2010-12-07 22:55:01 +0000781
Greg Claytona66ba462010-10-30 04:51:46 +0000782 if (log)
Johnny Chenee6e7902011-08-10 22:06:24 +0000783 log->Printf ("SBFrame(%p)::EvaluateExpression (expr=\"%s\") => SBValue(%p) (execution result=%d)", m_opaque_sp.get(),
Jim Inghame41494a2011-04-16 00:01:13 +0000784 expr,
Johnny Chenee6e7902011-08-10 22:06:24 +0000785 expr_result.get(),
786 exe_results);
Greg Claytona66ba462010-10-30 04:51:46 +0000787
Greg Clayton49ce6822010-10-31 03:01:06 +0000788 return expr_result;
Greg Clayton66ed2fb2010-10-05 00:00:42 +0000789}
Greg Clayton582ed0e2011-06-18 20:06:08 +0000790
791bool
792SBFrame::IsInlined()
793{
794 if (m_opaque_sp)
795 {
796 Block *block = m_opaque_sp->GetSymbolContext(eSymbolContextBlock).block;
797 if (block)
798 return block->GetContainingInlinedBlock () != NULL;
799 }
800 return false;
801}
802
803const char *
804SBFrame::GetFunctionName()
805{
806 const char *name = NULL;
807 if (m_opaque_sp)
808 {
809 SymbolContext sc (m_opaque_sp->GetSymbolContext(eSymbolContextFunction | eSymbolContextBlock | eSymbolContextSymbol));
810 if (sc.block)
811 {
812 Block *inlined_block = sc.block->GetContainingInlinedBlock ();
813 if (inlined_block)
814 {
815 const InlineFunctionInfo* inlined_info = inlined_block->GetInlinedFunctionInfo();
816 name = inlined_info->GetName().AsCString();
817 }
818 }
819
820 if (name == NULL)
821 {
822 if (sc.function)
823 name = sc.function->GetName().GetCString();
824 }
825
826 if (name == NULL)
827 {
828 if (sc.symbol)
829 name = sc.symbol->GetName().GetCString();
830 }
831 }
832 return name;
833}
834