blob: 93c54108ce72684ffef4be306a57b8eb6091687a [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"
Chris Lattner24943d22010-06-08 16:52:24 +000025#include "lldb/Symbol/Block.h"
26#include "lldb/Symbol/SymbolContext.h"
27#include "lldb/Symbol/VariableList.h"
28#include "lldb/Symbol/Variable.h"
29#include "lldb/Target/ExecutionContext.h"
30#include "lldb/Target/Target.h"
31#include "lldb/Target/Process.h"
32#include "lldb/Target/RegisterContext.h"
33#include "lldb/Target/StackFrame.h"
34#include "lldb/Target/Thread.h"
35
Eli Friedman7a62c8b2010-06-09 07:44:37 +000036#include "lldb/API/SBDebugger.h"
37#include "lldb/API/SBValue.h"
38#include "lldb/API/SBAddress.h"
Caroline Tice98f930f2010-09-20 05:20:02 +000039#include "lldb/API/SBStream.h"
Eli Friedman7a62c8b2010-06-09 07:44:37 +000040#include "lldb/API/SBSymbolContext.h"
41#include "lldb/API/SBThread.h"
Chris Lattner24943d22010-06-08 16:52:24 +000042
43using namespace lldb;
44using namespace lldb_private;
45
46SBFrame::SBFrame () :
Greg Clayton63094e02010-06-23 01:19:29 +000047 m_opaque_sp ()
Chris Lattner24943d22010-06-08 16:52:24 +000048{
49}
50
Greg Clayton4e9267d2010-12-14 18:39:31 +000051SBFrame::SBFrame (const StackFrameSP &lldb_object_sp) :
Greg Clayton63094e02010-06-23 01:19:29 +000052 m_opaque_sp (lldb_object_sp)
Chris Lattner24943d22010-06-08 16:52:24 +000053{
Greg Clayton4e9267d2010-12-14 18:39:31 +000054 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +000055
56 if (log)
57 {
58 SBStream sstr;
59 GetDescription (sstr);
Greg Claytona66ba462010-10-30 04:51:46 +000060 log->Printf ("SBFrame::SBFrame (sp=%p) => SBFrame(%p): %s",
61 lldb_object_sp.get(), m_opaque_sp.get(), sstr.GetData());
Caroline Tice61ba7ec2010-10-26 23:49:36 +000062
Caroline Tice7826c882010-10-26 03:11:13 +000063 }
Chris Lattner24943d22010-06-08 16:52:24 +000064}
65
Greg Clayton538eb822010-11-05 23:17:00 +000066SBFrame::SBFrame(const SBFrame &rhs) :
67 m_opaque_sp (rhs.m_opaque_sp)
68{
69}
70
71const SBFrame &
72SBFrame::operator = (const SBFrame &rhs)
73{
74 if (this != &rhs)
75 m_opaque_sp = rhs.m_opaque_sp;
76 return *this;
77}
78
Chris Lattner24943d22010-06-08 16:52:24 +000079SBFrame::~SBFrame()
80{
81}
82
83
84void
Greg Clayton4e9267d2010-12-14 18:39:31 +000085SBFrame::SetFrame (const StackFrameSP &lldb_object_sp)
Chris Lattner24943d22010-06-08 16:52:24 +000086{
Greg Claytona66ba462010-10-30 04:51:46 +000087 void *old_ptr = m_opaque_sp.get();
Greg Clayton63094e02010-06-23 01:19:29 +000088 m_opaque_sp = lldb_object_sp;
Greg Clayton4e9267d2010-12-14 18:39:31 +000089 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +000090
91 if (log)
92 {
93 log->Printf ("SBFrame(%p)::SetFrame(sp=%p) := SBFrame(%p)",
94 old_ptr, lldb_object_sp.get(), m_opaque_sp.get());
95 }
96
Chris Lattner24943d22010-06-08 16:52:24 +000097}
98
99
100bool
101SBFrame::IsValid() const
102{
Greg Clayton63094e02010-06-23 01:19:29 +0000103 return (m_opaque_sp.get() != NULL);
Chris Lattner24943d22010-06-08 16:52:24 +0000104}
105
106SBSymbolContext
107SBFrame::GetSymbolContext (uint32_t resolve_scope) const
108{
Caroline Tice7826c882010-10-26 03:11:13 +0000109
Chris Lattner24943d22010-06-08 16:52:24 +0000110 SBSymbolContext sb_sym_ctx;
Greg Clayton63094e02010-06-23 01:19:29 +0000111 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000112 {
113 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
Greg Clayton63094e02010-06-23 01:19:29 +0000114 sb_sym_ctx.SetSymbolContext(&m_opaque_sp->GetSymbolContext (resolve_scope));
Greg Claytonbdcda462010-12-20 20:49:23 +0000115 }
Caroline Tice7826c882010-10-26 03:11:13 +0000116
Greg Clayton4e9267d2010-12-14 18:39:31 +0000117 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000118 if (log)
Greg Claytona66ba462010-10-30 04:51:46 +0000119 log->Printf ("SBFrame(%p)::GetSymbolContext (resolve_scope=0x%8.8x) => SBSymbolContext(%p)",
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000120 m_opaque_sp.get(), resolve_scope, sb_sym_ctx.get());
Caroline Tice7826c882010-10-26 03:11:13 +0000121
Chris Lattner24943d22010-06-08 16:52:24 +0000122 return sb_sym_ctx;
123}
124
125SBModule
126SBFrame::GetModule () const
127{
Greg Claytondd62d722010-12-14 04:58:53 +0000128 SBModule sb_module;
129 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000130 {
131 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
Greg Claytondd62d722010-12-14 04:58:53 +0000132 *sb_module = m_opaque_sp->GetSymbolContext (eSymbolContextModule).module_sp;
Greg Claytonbdcda462010-12-20 20:49:23 +0000133 }
Greg Claytondd62d722010-12-14 04:58:53 +0000134
Greg Clayton4e9267d2010-12-14 18:39:31 +0000135 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000136 if (log)
137 log->Printf ("SBFrame(%p)::GetModule () => SBModule(%p)",
138 m_opaque_sp.get(), sb_module.get());
139
Chris Lattner24943d22010-06-08 16:52:24 +0000140 return sb_module;
141}
142
143SBCompileUnit
144SBFrame::GetCompileUnit () const
145{
Greg Claytondd62d722010-12-14 04:58:53 +0000146 SBCompileUnit sb_comp_unit;
147 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000148 {
149 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
Greg Claytondd62d722010-12-14 04:58:53 +0000150 sb_comp_unit.reset (m_opaque_sp->GetSymbolContext (eSymbolContextCompUnit).comp_unit);
Greg Claytonbdcda462010-12-20 20:49:23 +0000151 }
Greg Clayton4e9267d2010-12-14 18:39:31 +0000152 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000153 if (log)
Greg Claytona66ba462010-10-30 04:51:46 +0000154 log->Printf ("SBFrame(%p)::GetModule () => SBCompileUnit(%p)",
155 m_opaque_sp.get(), sb_comp_unit.get());
Caroline Tice7826c882010-10-26 03:11:13 +0000156
Chris Lattner24943d22010-06-08 16:52:24 +0000157 return sb_comp_unit;
158}
159
160SBFunction
161SBFrame::GetFunction () const
162{
Greg Claytondd62d722010-12-14 04:58:53 +0000163 SBFunction sb_function;
164 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000165 {
166 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
Greg Claytondd62d722010-12-14 04:58:53 +0000167 sb_function.reset(m_opaque_sp->GetSymbolContext (eSymbolContextFunction).function);
Greg Claytonbdcda462010-12-20 20:49:23 +0000168 }
Greg Clayton4e9267d2010-12-14 18:39:31 +0000169 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000170 if (log)
171 log->Printf ("SBFrame(%p)::GetFunction () => SBFunction(%p)",
172 m_opaque_sp.get(), sb_function.get());
173
Chris Lattner24943d22010-06-08 16:52:24 +0000174 return sb_function;
175}
176
Greg Clayton8f1e08b2010-10-04 18:37:52 +0000177SBSymbol
178SBFrame::GetSymbol () const
179{
Greg Claytondd62d722010-12-14 04:58:53 +0000180 SBSymbol sb_symbol;
181 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000182 {
183 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
Greg Claytondd62d722010-12-14 04:58:53 +0000184 sb_symbol.reset(m_opaque_sp->GetSymbolContext (eSymbolContextSymbol).symbol);
Greg Claytonbdcda462010-12-20 20:49:23 +0000185 }
Greg Clayton4e9267d2010-12-14 18:39:31 +0000186 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000187 if (log)
188 log->Printf ("SBFrame(%p)::GetSymbol () => SBSymbol(%p)",
189 m_opaque_sp.get(), sb_symbol.get());
Greg Clayton8f1e08b2010-10-04 18:37:52 +0000190 return sb_symbol;
191}
192
Chris Lattner24943d22010-06-08 16:52:24 +0000193SBBlock
194SBFrame::GetBlock () const
195{
Greg Claytondd62d722010-12-14 04:58:53 +0000196 SBBlock sb_block;
197 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000198 {
199 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
Greg Claytondd62d722010-12-14 04:58:53 +0000200 sb_block.reset (m_opaque_sp->GetSymbolContext (eSymbolContextBlock).block);
Greg Claytonbdcda462010-12-20 20:49:23 +0000201 }
Greg Clayton4e9267d2010-12-14 18:39:31 +0000202 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000203 if (log)
204 log->Printf ("SBFrame(%p)::GetBlock () => SBBlock(%p)",
205 m_opaque_sp.get(), sb_block.get());
Chris Lattner24943d22010-06-08 16:52:24 +0000206 return sb_block;
207}
208
Greg Clayton69aa5d92010-09-07 04:20:48 +0000209SBBlock
210SBFrame::GetFrameBlock () const
211{
Greg Claytondd62d722010-12-14 04:58:53 +0000212 SBBlock sb_block;
213 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000214 {
215 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
Greg Claytondd62d722010-12-14 04:58:53 +0000216 sb_block.reset(m_opaque_sp->GetFrameBlock ());
Greg Claytonbdcda462010-12-20 20:49:23 +0000217 }
Greg Clayton4e9267d2010-12-14 18:39:31 +0000218 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000219 if (log)
220 log->Printf ("SBFrame(%p)::GetFrameBlock () => SBBlock(%p)",
221 m_opaque_sp.get(), sb_block.get());
Greg Clayton69aa5d92010-09-07 04:20:48 +0000222 return sb_block;
223}
224
Chris Lattner24943d22010-06-08 16:52:24 +0000225SBLineEntry
226SBFrame::GetLineEntry () const
227{
Greg Claytondd62d722010-12-14 04:58:53 +0000228 SBLineEntry sb_line_entry;
229 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000230 {
231 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
Greg Claytondd62d722010-12-14 04:58:53 +0000232 sb_line_entry.SetLineEntry (m_opaque_sp->GetSymbolContext (eSymbolContextLineEntry).line_entry);
Greg Claytonbdcda462010-12-20 20:49:23 +0000233 }
Greg Clayton4e9267d2010-12-14 18:39:31 +0000234 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000235 if (log)
236 log->Printf ("SBFrame(%p)::GetLineEntry () => SBLineEntry(%p)",
237 m_opaque_sp.get(), sb_line_entry.get());
Chris Lattner24943d22010-06-08 16:52:24 +0000238 return sb_line_entry;
239}
240
241uint32_t
242SBFrame::GetFrameID () const
243{
Greg Claytona66ba462010-10-30 04:51:46 +0000244 uint32_t frame_idx = m_opaque_sp ? m_opaque_sp->GetFrameIndex () : UINT32_MAX;
245
Greg Clayton4e9267d2010-12-14 18:39:31 +0000246 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000247 if (log)
248 log->Printf ("SBFrame(%p)::GetFrameID () => %u",
249 m_opaque_sp.get(), frame_idx);
250 return frame_idx;
Chris Lattner24943d22010-06-08 16:52:24 +0000251}
252
Greg Clayton4e9267d2010-12-14 18:39:31 +0000253addr_t
Chris Lattner24943d22010-06-08 16:52:24 +0000254SBFrame::GetPC () const
255{
Greg Clayton4e9267d2010-12-14 18:39:31 +0000256 addr_t addr = LLDB_INVALID_ADDRESS;
Greg Clayton63094e02010-06-23 01:19:29 +0000257 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000258 {
259 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
Caroline Tice7826c882010-10-26 03:11:13 +0000260 addr = m_opaque_sp->GetFrameCodeAddress().GetLoadAddress (&m_opaque_sp->GetThread().GetProcess().GetTarget());
Greg Claytonbdcda462010-12-20 20:49:23 +0000261 }
Caroline Tice7826c882010-10-26 03:11:13 +0000262
Greg Clayton4e9267d2010-12-14 18:39:31 +0000263 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000264 if (log)
Greg Clayton49ce6822010-10-31 03:01:06 +0000265 log->Printf ("SBFrame(%p)::GetPC () => 0x%llx", m_opaque_sp.get(), addr);
Caroline Tice7826c882010-10-26 03:11:13 +0000266
267 return addr;
Chris Lattner24943d22010-06-08 16:52:24 +0000268}
269
270bool
Greg Clayton4e9267d2010-12-14 18:39:31 +0000271SBFrame::SetPC (addr_t new_pc)
Chris Lattner24943d22010-06-08 16:52:24 +0000272{
Caroline Tice7826c882010-10-26 03:11:13 +0000273 bool ret_val = false;
Greg Clayton63094e02010-06-23 01:19:29 +0000274 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000275 {
276 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
Caroline Tice7826c882010-10-26 03:11:13 +0000277 ret_val = m_opaque_sp->GetRegisterContext()->SetPC (new_pc);
Greg Claytonbdcda462010-12-20 20:49:23 +0000278 }
Caroline Tice7826c882010-10-26 03:11:13 +0000279
Greg Clayton4e9267d2010-12-14 18:39:31 +0000280 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000281 if (log)
Greg Claytona66ba462010-10-30 04:51:46 +0000282 log->Printf ("SBFrame(%p)::SetPC (new_pc=0x%llx) => %i",
283 m_opaque_sp.get(), new_pc, ret_val);
Caroline Tice7826c882010-10-26 03:11:13 +0000284
285 return ret_val;
Chris Lattner24943d22010-06-08 16:52:24 +0000286}
287
Greg Clayton4e9267d2010-12-14 18:39:31 +0000288addr_t
Chris Lattner24943d22010-06-08 16:52:24 +0000289SBFrame::GetSP () const
290{
Greg Claytona66ba462010-10-30 04:51:46 +0000291 addr_t addr = LLDB_INVALID_ADDRESS;
Greg Clayton63094e02010-06-23 01:19:29 +0000292 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000293 {
294 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
Greg Claytona66ba462010-10-30 04:51:46 +0000295 addr = m_opaque_sp->GetRegisterContext()->GetSP();
Greg Claytonbdcda462010-12-20 20:49:23 +0000296 }
Greg Clayton4e9267d2010-12-14 18:39:31 +0000297 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000298 if (log)
Greg Clayton49ce6822010-10-31 03:01:06 +0000299 log->Printf ("SBFrame(%p)::GetSP () => 0x%llx", m_opaque_sp.get(), addr);
Greg Claytona66ba462010-10-30 04:51:46 +0000300
301 return addr;
Chris Lattner24943d22010-06-08 16:52:24 +0000302}
303
304
Greg Clayton4e9267d2010-12-14 18:39:31 +0000305addr_t
Chris Lattner24943d22010-06-08 16:52:24 +0000306SBFrame::GetFP () const
307{
Greg Clayton4e9267d2010-12-14 18:39:31 +0000308 addr_t addr = LLDB_INVALID_ADDRESS;
Greg Clayton63094e02010-06-23 01:19:29 +0000309 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000310 {
311 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
Caroline Tice7826c882010-10-26 03:11:13 +0000312 addr = m_opaque_sp->GetRegisterContext()->GetFP();
Greg Claytonbdcda462010-12-20 20:49:23 +0000313 }
Caroline Tice7826c882010-10-26 03:11:13 +0000314
Greg Clayton4e9267d2010-12-14 18:39:31 +0000315 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000316 if (log)
Greg Clayton49ce6822010-10-31 03:01:06 +0000317 log->Printf ("SBFrame(%p)::GetFP () => 0x%llx", m_opaque_sp.get(), addr);
Caroline Tice7826c882010-10-26 03:11:13 +0000318 return addr;
Chris Lattner24943d22010-06-08 16:52:24 +0000319}
320
321
322SBAddress
323SBFrame::GetPCAddress () const
324{
325 SBAddress sb_addr;
Greg Clayton63094e02010-06-23 01:19:29 +0000326 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000327 {
328 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
Greg Claytonb04e7a82010-08-24 21:05:24 +0000329 sb_addr.SetAddress (&m_opaque_sp->GetFrameCodeAddress());
Greg Claytonbdcda462010-12-20 20:49:23 +0000330 }
Greg Clayton4e9267d2010-12-14 18:39:31 +0000331 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000332 if (log)
333 log->Printf ("SBFrame(%p)::GetPCAddress () => SBAddress(%p)", m_opaque_sp.get(), sb_addr.get());
Chris Lattner24943d22010-06-08 16:52:24 +0000334 return sb_addr;
335}
336
337void
338SBFrame::Clear()
339{
Greg Clayton63094e02010-06-23 01:19:29 +0000340 m_opaque_sp.reset();
Chris Lattner24943d22010-06-08 16:52:24 +0000341}
342
343SBValue
Greg Clayton4e9267d2010-12-14 18:39:31 +0000344SBFrame::FindVariable (const char *name)
Chris Lattner24943d22010-06-08 16:52:24 +0000345{
Jim Inghame41494a2011-04-16 00:01:13 +0000346 bool use_dynamic = m_opaque_sp->CalculateTarget()->GetPreferDynamicValue();
347 return FindVariable (name, use_dynamic);
348}
349
350SBValue
351SBFrame::FindVariable (const char *name, bool use_dynamic)
352{
Greg Clayton4e9267d2010-12-14 18:39:31 +0000353 VariableSP var_sp;
354 if (m_opaque_sp && name && name[0])
Chris Lattner24943d22010-06-08 16:52:24 +0000355 {
Greg Clayton4e9267d2010-12-14 18:39:31 +0000356 VariableList variable_list;
Greg Claytonbdcda462010-12-20 20:49:23 +0000357 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
Greg Claytondd62d722010-12-14 04:58:53 +0000358 SymbolContext sc (m_opaque_sp->GetSymbolContext (eSymbolContextBlock));
Chris Lattner24943d22010-06-08 16:52:24 +0000359
Greg Claytondd62d722010-12-14 04:58:53 +0000360 if (sc.block)
Chris Lattner24943d22010-06-08 16:52:24 +0000361 {
Greg Claytondd62d722010-12-14 04:58:53 +0000362 const bool can_create = true;
363 const bool get_parent_variables = true;
364 const bool stop_if_block_is_inlined_function = true;
365
366 if (sc.block->AppendVariables (can_create,
367 get_parent_variables,
368 stop_if_block_is_inlined_function,
369 &variable_list))
370 {
Greg Clayton4e9267d2010-12-14 18:39:31 +0000371 var_sp = variable_list.FindVariable (ConstString(name));
Greg Claytondd62d722010-12-14 04:58:53 +0000372 }
Chris Lattner24943d22010-06-08 16:52:24 +0000373 }
Chris Lattner24943d22010-06-08 16:52:24 +0000374 }
Caroline Tice98f930f2010-09-20 05:20:02 +0000375
376 SBValue sb_value;
Greg Claytona66ba462010-10-30 04:51:46 +0000377
378 if (var_sp)
Jim Inghame41494a2011-04-16 00:01:13 +0000379 *sb_value = ValueObjectSP (m_opaque_sp->GetValueObjectForFrameVariable(var_sp, use_dynamic));
Greg Claytona66ba462010-10-30 04:51:46 +0000380
Greg Clayton4e9267d2010-12-14 18:39:31 +0000381 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000382 if (log)
Greg Clayton4e9267d2010-12-14 18:39:31 +0000383 log->Printf ("SBFrame(%p)::FindVariable (name=\"%s\") => SBValue(%p)",
384 m_opaque_sp.get(), name, sb_value.get());
Greg Claytona66ba462010-10-30 04:51:46 +0000385
Chris Lattner24943d22010-06-08 16:52:24 +0000386 return sb_value;
387}
388
389SBValue
Greg Clayton4e9267d2010-12-14 18:39:31 +0000390SBFrame::FindValue (const char *name, ValueType value_type)
Chris Lattner24943d22010-06-08 16:52:24 +0000391{
Jim Inghame41494a2011-04-16 00:01:13 +0000392 bool use_dynamic = m_opaque_sp->CalculateTarget()->GetPreferDynamicValue();
393 return FindValue (name, value_type, use_dynamic);
394}
395
396SBValue
397SBFrame::FindValue (const char *name, ValueType value_type, bool use_dynamic)
398{
Greg Clayton4e9267d2010-12-14 18:39:31 +0000399 SBValue sb_value;
400 if (m_opaque_sp && name && name[0])
Chris Lattner24943d22010-06-08 16:52:24 +0000401 {
Greg Claytonbdcda462010-12-20 20:49:23 +0000402 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
Greg Clayton4e9267d2010-12-14 18:39:31 +0000403
404 switch (value_type)
Chris Lattner24943d22010-06-08 16:52:24 +0000405 {
Greg Clayton4e9267d2010-12-14 18:39:31 +0000406 case eValueTypeVariableGlobal: // global variable
407 case eValueTypeVariableStatic: // static variable
408 case eValueTypeVariableArgument: // function argument variables
409 case eValueTypeVariableLocal: // function local variables
Chris Lattner24943d22010-06-08 16:52:24 +0000410 {
Greg Clayton4e9267d2010-12-14 18:39:31 +0000411 VariableList *variable_list = m_opaque_sp->GetVariableList(true);
412
413 SymbolContext sc (m_opaque_sp->GetSymbolContext (eSymbolContextBlock));
414
415 const bool can_create = true;
416 const bool get_parent_variables = true;
417 const bool stop_if_block_is_inlined_function = true;
418
419 if (sc.block && sc.block->AppendVariables (can_create,
420 get_parent_variables,
421 stop_if_block_is_inlined_function,
422 variable_list))
Johnny Chenc35750a2010-11-19 18:07:14 +0000423 {
Greg Clayton4e9267d2010-12-14 18:39:31 +0000424 ConstString const_name(name);
425 const uint32_t num_variables = variable_list->GetSize();
426 for (uint32_t i = 0; i < num_variables; ++i)
Johnny Chenc35750a2010-11-19 18:07:14 +0000427 {
Greg Clayton4e9267d2010-12-14 18:39:31 +0000428 VariableSP variable_sp (variable_list->GetVariableAtIndex(i));
429 if (variable_sp &&
430 variable_sp->GetScope() == value_type &&
431 variable_sp->GetName() == const_name)
432 {
Jim Inghame41494a2011-04-16 00:01:13 +0000433 *sb_value = ValueObjectSP (m_opaque_sp->GetValueObjectForFrameVariable(variable_sp,
434 use_dynamic));
Greg Clayton4e9267d2010-12-14 18:39:31 +0000435 break;
436 }
Johnny Chenc35750a2010-11-19 18:07:14 +0000437 }
438 }
Chris Lattner24943d22010-06-08 16:52:24 +0000439 }
Greg Clayton4e9267d2010-12-14 18:39:31 +0000440 break;
441
442 case eValueTypeRegister: // stack frame register value
443 {
Greg Clayton08d7d3a2011-01-06 22:15:06 +0000444 RegisterContextSP reg_ctx (m_opaque_sp->GetRegisterContext());
Greg Clayton4e9267d2010-12-14 18:39:31 +0000445 if (reg_ctx)
446 {
447 const uint32_t num_regs = reg_ctx->GetRegisterCount();
448 for (uint32_t reg_idx = 0; reg_idx < num_regs; ++reg_idx)
449 {
450 const RegisterInfo *reg_info = reg_ctx->GetRegisterInfoAtIndex (reg_idx);
451 if (reg_info &&
452 ((reg_info->name && strcasecmp (reg_info->name, name) == 0) ||
453 (reg_info->alt_name && strcasecmp (reg_info->alt_name, name) == 0)))
454 {
Jim Inghamfa3a16a2011-03-31 00:19:25 +0000455 *sb_value = ValueObjectSP (new ValueObjectRegister (m_opaque_sp.get(), reg_ctx, reg_idx));
Greg Clayton4e9267d2010-12-14 18:39:31 +0000456 }
457 }
458 }
459 }
460 break;
461
462 case eValueTypeRegisterSet: // A collection of stack frame register values
463 {
Greg Clayton08d7d3a2011-01-06 22:15:06 +0000464 RegisterContextSP reg_ctx (m_opaque_sp->GetRegisterContext());
Greg Clayton4e9267d2010-12-14 18:39:31 +0000465 if (reg_ctx)
466 {
467 const uint32_t num_sets = reg_ctx->GetRegisterSetCount();
468 for (uint32_t set_idx = 0; set_idx < num_sets; ++set_idx)
469 {
470 const RegisterSet *reg_set = reg_ctx->GetRegisterSet (set_idx);
471 if (reg_set &&
472 ((reg_set->name && strcasecmp (reg_set->name, name) == 0) ||
473 (reg_set->short_name && strcasecmp (reg_set->short_name, name) == 0)))
474 {
Jim Inghamfa3a16a2011-03-31 00:19:25 +0000475 *sb_value = ValueObjectSP (new ValueObjectRegisterSet (m_opaque_sp.get(), reg_ctx, set_idx));
Greg Clayton4e9267d2010-12-14 18:39:31 +0000476 }
477 }
478 }
479 }
480 break;
481
482 case eValueTypeConstResult: // constant result variables
483 {
484 ConstString const_name(name);
485 ClangExpressionVariableSP expr_var_sp (m_opaque_sp->GetThread().GetProcess().GetTarget().GetPersistentVariables().GetVariable (const_name));
486 if (expr_var_sp)
487 *sb_value = expr_var_sp->GetValueObject();
488 }
489 break;
490
491 default:
492 break;
Chris Lattner24943d22010-06-08 16:52:24 +0000493 }
494 }
Caroline Tice98f930f2010-09-20 05:20:02 +0000495
Greg Clayton4e9267d2010-12-14 18:39:31 +0000496 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000497 if (log)
Greg Clayton4e9267d2010-12-14 18:39:31 +0000498 log->Printf ("SBFrame(%p)::FindVariableInScope (name=\"%s\", value_type=%i) => SBValue(%p)",
499 m_opaque_sp.get(), name, value_type, sb_value.get());
Greg Claytona66ba462010-10-30 04:51:46 +0000500
501
Chris Lattner24943d22010-06-08 16:52:24 +0000502 return sb_value;
503}
504
505bool
506SBFrame::operator == (const SBFrame &rhs) const
507{
Greg Clayton63094e02010-06-23 01:19:29 +0000508 return m_opaque_sp.get() == rhs.m_opaque_sp.get();
Chris Lattner24943d22010-06-08 16:52:24 +0000509}
510
511bool
512SBFrame::operator != (const SBFrame &rhs) const
513{
Greg Clayton63094e02010-06-23 01:19:29 +0000514 return m_opaque_sp.get() != rhs.m_opaque_sp.get();
Chris Lattner24943d22010-06-08 16:52:24 +0000515}
516
517lldb_private::StackFrame *
518SBFrame::operator->() const
519{
Greg Clayton63094e02010-06-23 01:19:29 +0000520 return m_opaque_sp.get();
Chris Lattner24943d22010-06-08 16:52:24 +0000521}
522
523lldb_private::StackFrame *
524SBFrame::get() const
525{
Greg Clayton63094e02010-06-23 01:19:29 +0000526 return m_opaque_sp.get();
Chris Lattner24943d22010-06-08 16:52:24 +0000527}
528
Greg Clayton1ebdcc72011-01-21 06:11:58 +0000529const lldb::StackFrameSP &
530SBFrame::get_sp() const
531{
532 return m_opaque_sp;
533}
Chris Lattner24943d22010-06-08 16:52:24 +0000534
535SBThread
536SBFrame::GetThread () const
537{
Greg Clayton4e9267d2010-12-14 18:39:31 +0000538 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000539
Greg Claytondd62d722010-12-14 04:58:53 +0000540 SBThread sb_thread;
541 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000542 {
543 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
Greg Claytondd62d722010-12-14 04:58:53 +0000544 sb_thread.SetThread (m_opaque_sp->GetThread().GetSP());
Greg Claytonbdcda462010-12-20 20:49:23 +0000545 }
Caroline Tice7826c882010-10-26 03:11:13 +0000546
547 if (log)
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000548 {
549 SBStream sstr;
550 sb_thread.GetDescription (sstr);
Greg Claytona66ba462010-10-30 04:51:46 +0000551 log->Printf ("SBFrame(%p)::GetThread () => SBThread(%p): %s", m_opaque_sp.get(),
552 sb_thread.get(), sstr.GetData());
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000553 }
Caroline Tice7826c882010-10-26 03:11:13 +0000554
Chris Lattner24943d22010-06-08 16:52:24 +0000555 return sb_thread;
556}
557
558const char *
559SBFrame::Disassemble () const
560{
Greg Claytona66ba462010-10-30 04:51:46 +0000561 const char *disassembly = NULL;
Greg Clayton63094e02010-06-23 01:19:29 +0000562 if (m_opaque_sp)
Greg Claytonbdcda462010-12-20 20:49:23 +0000563 {
564 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
Greg Claytona66ba462010-10-30 04:51:46 +0000565 disassembly = m_opaque_sp->Disassemble();
Greg Claytonbdcda462010-12-20 20:49:23 +0000566 }
Greg Clayton4e9267d2010-12-14 18:39:31 +0000567 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000568
569 if (log)
570 log->Printf ("SBFrame(%p)::Disassemble () => %s", m_opaque_sp.get(), disassembly);
571
572 return disassembly;
Chris Lattner24943d22010-06-08 16:52:24 +0000573}
574
575
Chris Lattner24943d22010-06-08 16:52:24 +0000576SBValueList
577SBFrame::GetVariables (bool arguments,
578 bool locals,
579 bool statics,
580 bool in_scope_only)
581{
Jim Inghame41494a2011-04-16 00:01:13 +0000582 bool use_dynamic = m_opaque_sp->CalculateTarget()->GetPreferDynamicValue();
583 return GetVariables (arguments, locals, statics, in_scope_only, use_dynamic);
584}
585
586SBValueList
587SBFrame::GetVariables (bool arguments,
588 bool locals,
589 bool statics,
590 bool in_scope_only,
591 bool use_dynamic)
592{
Greg Clayton4e9267d2010-12-14 18:39:31 +0000593 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000594
595 if (log)
Greg Claytona66ba462010-10-30 04:51:46 +0000596 log->Printf ("SBFrame(%p)::GetVariables (arguments=%i, locals=%i, statics=%i, in_scope_only=%i)",
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000597 m_opaque_sp.get(),
Greg Claytona66ba462010-10-30 04:51:46 +0000598 arguments,
599 locals,
600 statics,
601 in_scope_only);
Caroline Tice7826c882010-10-26 03:11:13 +0000602
Chris Lattner24943d22010-06-08 16:52:24 +0000603 SBValueList value_list;
Greg Clayton63094e02010-06-23 01:19:29 +0000604 if (m_opaque_sp)
Chris Lattner24943d22010-06-08 16:52:24 +0000605 {
Greg Claytonbdcda462010-12-20 20:49:23 +0000606
Chris Lattner24943d22010-06-08 16:52:24 +0000607 size_t i;
Greg Claytonbdcda462010-12-20 20:49:23 +0000608 VariableList *variable_list = NULL;
609 // Scope for locker
610 {
611 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
612 variable_list = m_opaque_sp->GetVariableList(true);
613 }
Chris Lattner24943d22010-06-08 16:52:24 +0000614 if (variable_list)
615 {
616 const size_t num_variables = variable_list->GetSize();
617 if (num_variables)
618 {
619 for (i = 0; i < num_variables; ++i)
620 {
621 VariableSP variable_sp (variable_list->GetVariableAtIndex(i));
622 if (variable_sp)
623 {
624 bool add_variable = false;
625 switch (variable_sp->GetScope())
626 {
627 case eValueTypeVariableGlobal:
628 case eValueTypeVariableStatic:
629 add_variable = statics;
630 break;
631
632 case eValueTypeVariableArgument:
633 add_variable = arguments;
634 break;
635
636 case eValueTypeVariableLocal:
637 add_variable = locals;
638 break;
Greg Clayton54e7afa2010-07-09 20:39:50 +0000639
640 default:
641 break;
Chris Lattner24943d22010-06-08 16:52:24 +0000642 }
643 if (add_variable)
644 {
Greg Clayton63094e02010-06-23 01:19:29 +0000645 if (in_scope_only && !variable_sp->IsInScope(m_opaque_sp.get()))
Chris Lattner24943d22010-06-08 16:52:24 +0000646 continue;
647
Jim Inghame41494a2011-04-16 00:01:13 +0000648 value_list.Append(m_opaque_sp->GetValueObjectForFrameVariable (variable_sp, use_dynamic));
Chris Lattner24943d22010-06-08 16:52:24 +0000649 }
650 }
651 }
652 }
Greg Clayton17dae082010-09-02 02:59:18 +0000653 }
Chris Lattner24943d22010-06-08 16:52:24 +0000654 }
Caroline Tice7826c882010-10-26 03:11:13 +0000655
656 if (log)
657 {
Greg Claytona66ba462010-10-30 04:51:46 +0000658 log->Printf ("SBFrame(%p)::GetVariables (...) => SBValueList(%p)", m_opaque_sp.get(),
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000659 value_list.get());
Caroline Tice7826c882010-10-26 03:11:13 +0000660 }
661
Chris Lattner24943d22010-06-08 16:52:24 +0000662 return value_list;
663}
664
Greg Clayton4e9267d2010-12-14 18:39:31 +0000665SBValueList
Chris Lattner24943d22010-06-08 16:52:24 +0000666SBFrame::GetRegisters ()
667{
Greg Clayton4e9267d2010-12-14 18:39:31 +0000668 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000669
Chris Lattner24943d22010-06-08 16:52:24 +0000670 SBValueList value_list;
Greg Clayton63094e02010-06-23 01:19:29 +0000671 if (m_opaque_sp)
Chris Lattner24943d22010-06-08 16:52:24 +0000672 {
Greg Claytonbdcda462010-12-20 20:49:23 +0000673 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
Greg Clayton08d7d3a2011-01-06 22:15:06 +0000674 RegisterContextSP reg_ctx (m_opaque_sp->GetRegisterContext());
Chris Lattner24943d22010-06-08 16:52:24 +0000675 if (reg_ctx)
676 {
677 const uint32_t num_sets = reg_ctx->GetRegisterSetCount();
678 for (uint32_t set_idx = 0; set_idx < num_sets; ++set_idx)
679 {
Jim Inghamfa3a16a2011-03-31 00:19:25 +0000680 value_list.Append(ValueObjectSP (new ValueObjectRegisterSet (m_opaque_sp.get(), reg_ctx, set_idx)));
Chris Lattner24943d22010-06-08 16:52:24 +0000681 }
682 }
683 }
Caroline Tice7826c882010-10-26 03:11:13 +0000684
685 if (log)
Greg Claytona66ba462010-10-30 04:51:46 +0000686 log->Printf ("SBFrame(%p)::Registers () => SBValueList(%p)", m_opaque_sp.get(), value_list.get());
Caroline Tice7826c882010-10-26 03:11:13 +0000687
Chris Lattner24943d22010-06-08 16:52:24 +0000688 return value_list;
689}
690
Caroline Tice98f930f2010-09-20 05:20:02 +0000691bool
692SBFrame::GetDescription (SBStream &description)
693{
694 if (m_opaque_sp)
695 {
Greg Claytonbdcda462010-12-20 20:49:23 +0000696 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
Greg Clayton49ce6822010-10-31 03:01:06 +0000697 Stream &s = description.ref();
698 m_opaque_sp->DumpUsingSettingsFormat (&s);
Caroline Tice98f930f2010-09-20 05:20:02 +0000699 }
700 else
701 description.Printf ("No value");
702
703 return true;
704}
Greg Clayton66ed2fb2010-10-05 00:00:42 +0000705
Greg Clayton4e9267d2010-12-14 18:39:31 +0000706SBValue
Greg Clayton66ed2fb2010-10-05 00:00:42 +0000707SBFrame::EvaluateExpression (const char *expr)
708{
Jim Inghame41494a2011-04-16 00:01:13 +0000709 bool use_dynamic = m_opaque_sp->CalculateTarget()->GetPreferDynamicValue();
710 return EvaluateExpression (expr, use_dynamic);
711}
712
713SBValue
714SBFrame::EvaluateExpression (const char *expr, bool fetch_dynamic_value)
715{
Greg Claytonbdcda462010-12-20 20:49:23 +0000716 Mutex::Locker api_locker (m_opaque_sp->GetThread().GetProcess().GetTarget().GetAPIMutex());
717
Greg Clayton4e9267d2010-12-14 18:39:31 +0000718 LogSP log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Sean Callanan94d255f2010-12-07 22:55:01 +0000719
Greg Clayton4e9267d2010-12-14 18:39:31 +0000720 LogSP expr_log(GetLogIfAllCategoriesSet (LIBLLDB_LOG_EXPRESSIONS));
Greg Claytona66ba462010-10-30 04:51:46 +0000721
Greg Clayton4e9267d2010-12-14 18:39:31 +0000722 SBValue expr_result;
Greg Claytona66ba462010-10-30 04:51:46 +0000723 if (log)
724 log->Printf ("SBFrame(%p)::EvaluateExpression (expr=\"%s\")...", m_opaque_sp.get(), expr);
725
Greg Clayton66ed2fb2010-10-05 00:00:42 +0000726 if (m_opaque_sp)
727 {
Greg Clayton4e9267d2010-12-14 18:39:31 +0000728 ExecutionResults exe_results;
Greg Clayton427f2902010-12-14 02:59:59 +0000729 const bool unwind_on_error = true;
Sean Callanan6a925532011-01-13 08:53:35 +0000730 const bool keep_in_memory = false;
Greg Clayton427f2902010-12-14 02:59:59 +0000731
Jim Inghame41494a2011-04-16 00:01:13 +0000732 exe_results = m_opaque_sp->GetThread().GetProcess().GetTarget().EvaluateExpression(expr,
733 m_opaque_sp.get(),
734 unwind_on_error,
735 fetch_dynamic_value,
736 keep_in_memory,
737 *expr_result);
Greg Clayton66ed2fb2010-10-05 00:00:42 +0000738 }
Greg Claytona66ba462010-10-30 04:51:46 +0000739
Sean Callanan94d255f2010-12-07 22:55:01 +0000740 if (expr_log)
Jim Inghame41494a2011-04-16 00:01:13 +0000741 expr_log->Printf("** [SBFrame::EvaluateExpression] Expression result is %s, summary %s **",
742 expr_result.GetValue(*this),
743 expr_result.GetSummary(*this));
Sean Callanan94d255f2010-12-07 22:55:01 +0000744
Greg Claytona66ba462010-10-30 04:51:46 +0000745 if (log)
Jim Inghame41494a2011-04-16 00:01:13 +0000746 log->Printf ("SBFrame(%p)::EvaluateExpression (expr=\"%s\") => SBValue(%p)", m_opaque_sp.get(),
747 expr,
748 expr_result.get());
Greg Claytona66ba462010-10-30 04:51:46 +0000749
Greg Clayton49ce6822010-10-31 03:01:06 +0000750 return expr_result;
Greg Clayton66ed2fb2010-10-05 00:00:42 +0000751}