blob: 2d685fa75f32c7327818cc9dc716d18d98bf1c26 [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
51SBFrame::SBFrame (const lldb::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 Claytone005f2c2010-11-06 01:53:30 +000054 LogSP log(lldb_private::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
85SBFrame::SetFrame (const lldb::StackFrameSP &lldb_object_sp)
86{
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 Claytone005f2c2010-11-06 01:53:30 +000089 LogSP log(lldb_private::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)
112 sb_sym_ctx.SetSymbolContext(&m_opaque_sp->GetSymbolContext (resolve_scope));
Caroline Tice7826c882010-10-26 03:11:13 +0000113
Greg Claytone005f2c2010-11-06 01:53:30 +0000114 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000115 if (log)
Greg Claytona66ba462010-10-30 04:51:46 +0000116 log->Printf ("SBFrame(%p)::GetSymbolContext (resolve_scope=0x%8.8x) => SBSymbolContext(%p)",
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000117 m_opaque_sp.get(), resolve_scope, sb_sym_ctx.get());
Caroline Tice7826c882010-10-26 03:11:13 +0000118
Chris Lattner24943d22010-06-08 16:52:24 +0000119 return sb_sym_ctx;
120}
121
122SBModule
123SBFrame::GetModule () const
124{
Greg Clayton63094e02010-06-23 01:19:29 +0000125 SBModule sb_module (m_opaque_sp->GetSymbolContext (eSymbolContextModule).module_sp);
Greg Claytone005f2c2010-11-06 01:53:30 +0000126 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000127 if (log)
128 log->Printf ("SBFrame(%p)::GetModule () => SBModule(%p)",
129 m_opaque_sp.get(), sb_module.get());
130
Chris Lattner24943d22010-06-08 16:52:24 +0000131 return sb_module;
132}
133
134SBCompileUnit
135SBFrame::GetCompileUnit () const
136{
Greg Clayton63094e02010-06-23 01:19:29 +0000137 SBCompileUnit sb_comp_unit(m_opaque_sp->GetSymbolContext (eSymbolContextCompUnit).comp_unit);
Caroline Tice7826c882010-10-26 03:11:13 +0000138
Greg Claytone005f2c2010-11-06 01:53:30 +0000139 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000140 if (log)
Greg Claytona66ba462010-10-30 04:51:46 +0000141 log->Printf ("SBFrame(%p)::GetModule () => SBCompileUnit(%p)",
142 m_opaque_sp.get(), sb_comp_unit.get());
Caroline Tice7826c882010-10-26 03:11:13 +0000143
Chris Lattner24943d22010-06-08 16:52:24 +0000144 return sb_comp_unit;
145}
146
147SBFunction
148SBFrame::GetFunction () const
149{
Greg Clayton63094e02010-06-23 01:19:29 +0000150 SBFunction sb_function(m_opaque_sp->GetSymbolContext (eSymbolContextFunction).function);
Greg Claytona66ba462010-10-30 04:51:46 +0000151
Greg Claytone005f2c2010-11-06 01:53:30 +0000152 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000153 if (log)
154 log->Printf ("SBFrame(%p)::GetFunction () => SBFunction(%p)",
155 m_opaque_sp.get(), sb_function.get());
156
Chris Lattner24943d22010-06-08 16:52:24 +0000157 return sb_function;
158}
159
Greg Clayton8f1e08b2010-10-04 18:37:52 +0000160SBSymbol
161SBFrame::GetSymbol () const
162{
163 SBSymbol sb_symbol(m_opaque_sp->GetSymbolContext (eSymbolContextSymbol).symbol);
Greg Claytone005f2c2010-11-06 01:53:30 +0000164 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000165 if (log)
166 log->Printf ("SBFrame(%p)::GetSymbol () => SBSymbol(%p)",
167 m_opaque_sp.get(), sb_symbol.get());
Greg Clayton8f1e08b2010-10-04 18:37:52 +0000168 return sb_symbol;
169}
170
Chris Lattner24943d22010-06-08 16:52:24 +0000171SBBlock
172SBFrame::GetBlock () const
173{
Greg Clayton63094e02010-06-23 01:19:29 +0000174 SBBlock sb_block(m_opaque_sp->GetSymbolContext (eSymbolContextBlock).block);
Greg Claytone005f2c2010-11-06 01:53:30 +0000175 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000176 if (log)
177 log->Printf ("SBFrame(%p)::GetBlock () => SBBlock(%p)",
178 m_opaque_sp.get(), sb_block.get());
Chris Lattner24943d22010-06-08 16:52:24 +0000179 return sb_block;
180}
181
Greg Clayton69aa5d92010-09-07 04:20:48 +0000182SBBlock
183SBFrame::GetFrameBlock () const
184{
185 SBBlock sb_block(m_opaque_sp->GetFrameBlock ());
Greg Claytone005f2c2010-11-06 01:53:30 +0000186 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000187 if (log)
188 log->Printf ("SBFrame(%p)::GetFrameBlock () => SBBlock(%p)",
189 m_opaque_sp.get(), sb_block.get());
Greg Clayton69aa5d92010-09-07 04:20:48 +0000190 return sb_block;
191}
192
Chris Lattner24943d22010-06-08 16:52:24 +0000193SBLineEntry
194SBFrame::GetLineEntry () const
195{
Greg Clayton63094e02010-06-23 01:19:29 +0000196 SBLineEntry sb_line_entry(&m_opaque_sp->GetSymbolContext (eSymbolContextLineEntry).line_entry);
Greg Claytone005f2c2010-11-06 01:53:30 +0000197 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000198 if (log)
199 log->Printf ("SBFrame(%p)::GetLineEntry () => SBLineEntry(%p)",
200 m_opaque_sp.get(), sb_line_entry.get());
Chris Lattner24943d22010-06-08 16:52:24 +0000201 return sb_line_entry;
202}
203
204uint32_t
205SBFrame::GetFrameID () const
206{
Greg Claytona66ba462010-10-30 04:51:46 +0000207 uint32_t frame_idx = m_opaque_sp ? m_opaque_sp->GetFrameIndex () : UINT32_MAX;
208
Greg Claytone005f2c2010-11-06 01:53:30 +0000209 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000210 if (log)
211 log->Printf ("SBFrame(%p)::GetFrameID () => %u",
212 m_opaque_sp.get(), frame_idx);
213 return frame_idx;
Chris Lattner24943d22010-06-08 16:52:24 +0000214}
215
Chris Lattner24943d22010-06-08 16:52:24 +0000216lldb::addr_t
217SBFrame::GetPC () const
218{
Caroline Tice7826c882010-10-26 03:11:13 +0000219
220 lldb::addr_t addr = LLDB_INVALID_ADDRESS;
Greg Clayton63094e02010-06-23 01:19:29 +0000221 if (m_opaque_sp)
Caroline Tice7826c882010-10-26 03:11:13 +0000222 addr = m_opaque_sp->GetFrameCodeAddress().GetLoadAddress (&m_opaque_sp->GetThread().GetProcess().GetTarget());
223
Greg Claytone005f2c2010-11-06 01:53:30 +0000224 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000225 if (log)
Greg Clayton49ce6822010-10-31 03:01:06 +0000226 log->Printf ("SBFrame(%p)::GetPC () => 0x%llx", m_opaque_sp.get(), addr);
Caroline Tice7826c882010-10-26 03:11:13 +0000227
228 return addr;
Chris Lattner24943d22010-06-08 16:52:24 +0000229}
230
231bool
232SBFrame::SetPC (lldb::addr_t new_pc)
233{
Caroline Tice7826c882010-10-26 03:11:13 +0000234
235 bool ret_val = false;
Greg Clayton63094e02010-06-23 01:19:29 +0000236 if (m_opaque_sp)
Caroline Tice7826c882010-10-26 03:11:13 +0000237 ret_val = m_opaque_sp->GetRegisterContext()->SetPC (new_pc);
238
Greg Claytone005f2c2010-11-06 01:53:30 +0000239 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000240 if (log)
Greg Claytona66ba462010-10-30 04:51:46 +0000241 log->Printf ("SBFrame(%p)::SetPC (new_pc=0x%llx) => %i",
242 m_opaque_sp.get(), new_pc, ret_val);
Caroline Tice7826c882010-10-26 03:11:13 +0000243
244 return ret_val;
Chris Lattner24943d22010-06-08 16:52:24 +0000245}
246
247lldb::addr_t
248SBFrame::GetSP () const
249{
Greg Claytona66ba462010-10-30 04:51:46 +0000250 addr_t addr = LLDB_INVALID_ADDRESS;
Greg Clayton63094e02010-06-23 01:19:29 +0000251 if (m_opaque_sp)
Greg Claytona66ba462010-10-30 04:51:46 +0000252 addr = m_opaque_sp->GetRegisterContext()->GetSP();
Greg Claytone005f2c2010-11-06 01:53:30 +0000253 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000254 if (log)
Greg Clayton49ce6822010-10-31 03:01:06 +0000255 log->Printf ("SBFrame(%p)::GetSP () => 0x%llx", m_opaque_sp.get(), addr);
Greg Claytona66ba462010-10-30 04:51:46 +0000256
257 return addr;
Chris Lattner24943d22010-06-08 16:52:24 +0000258}
259
260
261lldb::addr_t
262SBFrame::GetFP () const
263{
Caroline Tice7826c882010-10-26 03:11:13 +0000264 lldb::addr_t addr = LLDB_INVALID_ADDRESS;
Greg Clayton63094e02010-06-23 01:19:29 +0000265 if (m_opaque_sp)
Caroline Tice7826c882010-10-26 03:11:13 +0000266 addr = m_opaque_sp->GetRegisterContext()->GetFP();
267
Greg Claytone005f2c2010-11-06 01:53:30 +0000268 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000269 if (log)
Greg Clayton49ce6822010-10-31 03:01:06 +0000270 log->Printf ("SBFrame(%p)::GetFP () => 0x%llx", m_opaque_sp.get(), addr);
Caroline Tice7826c882010-10-26 03:11:13 +0000271 return addr;
Chris Lattner24943d22010-06-08 16:52:24 +0000272}
273
274
275SBAddress
276SBFrame::GetPCAddress () const
277{
278 SBAddress sb_addr;
Greg Clayton63094e02010-06-23 01:19:29 +0000279 if (m_opaque_sp)
Greg Claytonb04e7a82010-08-24 21:05:24 +0000280 sb_addr.SetAddress (&m_opaque_sp->GetFrameCodeAddress());
Greg Claytone005f2c2010-11-06 01:53:30 +0000281 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000282 if (log)
283 log->Printf ("SBFrame(%p)::GetPCAddress () => SBAddress(%p)", m_opaque_sp.get(), sb_addr.get());
Chris Lattner24943d22010-06-08 16:52:24 +0000284 return sb_addr;
285}
286
287void
288SBFrame::Clear()
289{
Greg Clayton63094e02010-06-23 01:19:29 +0000290 m_opaque_sp.reset();
Chris Lattner24943d22010-06-08 16:52:24 +0000291}
292
293SBValue
294SBFrame::LookupVar (const char *var_name)
295{
296 lldb::VariableSP var_sp;
297 if (IsValid ())
298 {
299 lldb_private::VariableList variable_list;
300 SBSymbolContext sc = GetSymbolContext (eSymbolContextEverything);
301
302 SBBlock block = sc.GetBlock();
303 if (block.IsValid())
304 block.AppendVariables (true, true, &variable_list);
305
306 const uint32_t num_variables = variable_list.GetSize();
307
308 bool found = false;
Greg Clayton54e7afa2010-07-09 20:39:50 +0000309 for (uint32_t i = 0; i < num_variables && !found; ++i)
Chris Lattner24943d22010-06-08 16:52:24 +0000310 {
311 var_sp = variable_list.GetVariableAtIndex(i);
312 if (var_sp
313 && (var_sp.get()->GetName() == lldb_private::ConstString(var_name)))
314 found = true;
315 }
316 if (!found)
317 var_sp.reset();
318 }
Caroline Tice98f930f2010-09-20 05:20:02 +0000319
320 SBValue sb_value;
Greg Claytona66ba462010-10-30 04:51:46 +0000321
322 if (var_sp)
323 *sb_value = ValueObjectSP (new ValueObjectVariable (var_sp));
324
Greg Claytone005f2c2010-11-06 01:53:30 +0000325 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000326 if (log)
327 log->Printf ("SBFrame(%p)::LookupVar (name=\"%s\") => SBValue(%p)",
328 m_opaque_sp.get(), var_name, sb_value.get());
329
Chris Lattner24943d22010-06-08 16:52:24 +0000330 return sb_value;
331}
332
333SBValue
334SBFrame::LookupVarInScope (const char *var_name, const char *scope)
335{
336 lldb::VariableSP var_sp;
337 if (IsValid())
338 {
339 std::string scope_str = scope;
340 lldb::ValueType var_scope = eValueTypeInvalid;
341 // Convert scope_str to be all lowercase;
342 std::transform (scope_str.begin(), scope_str.end(), scope_str.begin(), ::tolower);
343
344 if (scope_str.compare ("global") == 0)
345 var_scope = eValueTypeVariableGlobal;
346 else if (scope_str.compare ("local") == 0)
347 var_scope = eValueTypeVariableLocal;
348 else if (scope_str.compare ("parameter") == 0)
349 var_scope = eValueTypeVariableArgument;
350
351 if (var_scope != eValueTypeInvalid)
352 {
Johnny Chenc35750a2010-11-19 18:07:14 +0000353 lldb_private::VariableList *variable_list = m_opaque_sp->GetVariableList(true);
354 if (variable_list)
Chris Lattner24943d22010-06-08 16:52:24 +0000355 {
Johnny Chenc35750a2010-11-19 18:07:14 +0000356 const uint32_t num_variables = variable_list->GetSize();
357 bool found = false;
358 for (uint32_t i = 0; i < num_variables && !found; ++i)
359 {
360 var_sp = variable_list->GetVariableAtIndex(i);
361 if (var_sp
362 && (var_sp.get()->GetName() == lldb_private::ConstString(var_name))
363 && var_sp.get()->GetScope() == var_scope)
364 {
365 found = true;
366 break;
367 }
368 }
369 if (!found)
370 var_sp.reset();
Chris Lattner24943d22010-06-08 16:52:24 +0000371 }
Chris Lattner24943d22010-06-08 16:52:24 +0000372 }
373 }
Caroline Tice98f930f2010-09-20 05:20:02 +0000374
Caroline Tice98f930f2010-09-20 05:20:02 +0000375 SBValue sb_value;
Greg Claytona66ba462010-10-30 04:51:46 +0000376 if (var_sp)
377 *sb_value = ValueObjectSP (new ValueObjectVariable (var_sp));
378
Greg Claytone005f2c2010-11-06 01:53:30 +0000379 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000380 if (log)
381 log->Printf ("SBFrame(%p)::LookupVarInScope (name=\"%s\", scope=%s) => SBValue(%p)",
382 m_opaque_sp.get(), var_name, scope, sb_value.get());
383
384
Chris Lattner24943d22010-06-08 16:52:24 +0000385 return sb_value;
386}
387
388bool
389SBFrame::operator == (const SBFrame &rhs) const
390{
Greg Clayton63094e02010-06-23 01:19:29 +0000391 return m_opaque_sp.get() == rhs.m_opaque_sp.get();
Chris Lattner24943d22010-06-08 16:52:24 +0000392}
393
394bool
395SBFrame::operator != (const SBFrame &rhs) const
396{
Greg Clayton63094e02010-06-23 01:19:29 +0000397 return m_opaque_sp.get() != rhs.m_opaque_sp.get();
Chris Lattner24943d22010-06-08 16:52:24 +0000398}
399
400lldb_private::StackFrame *
401SBFrame::operator->() const
402{
Greg Clayton63094e02010-06-23 01:19:29 +0000403 return m_opaque_sp.get();
Chris Lattner24943d22010-06-08 16:52:24 +0000404}
405
406lldb_private::StackFrame *
407SBFrame::get() const
408{
Greg Clayton63094e02010-06-23 01:19:29 +0000409 return m_opaque_sp.get();
Chris Lattner24943d22010-06-08 16:52:24 +0000410}
411
412
413SBThread
414SBFrame::GetThread () const
415{
Greg Claytone005f2c2010-11-06 01:53:30 +0000416 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000417
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000418 //if (log)
419 // log->Printf ("SBFrame::GetThread ()");
Caroline Tice7826c882010-10-26 03:11:13 +0000420
Greg Clayton63094e02010-06-23 01:19:29 +0000421 SBThread sb_thread (m_opaque_sp->GetThread().GetSP());
Caroline Tice7826c882010-10-26 03:11:13 +0000422
423 if (log)
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000424 {
425 SBStream sstr;
426 sb_thread.GetDescription (sstr);
Greg Claytona66ba462010-10-30 04:51:46 +0000427 log->Printf ("SBFrame(%p)::GetThread () => SBThread(%p): %s", m_opaque_sp.get(),
428 sb_thread.get(), sstr.GetData());
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000429 }
Caroline Tice7826c882010-10-26 03:11:13 +0000430
Chris Lattner24943d22010-06-08 16:52:24 +0000431 return sb_thread;
432}
433
434const char *
435SBFrame::Disassemble () const
436{
Greg Claytona66ba462010-10-30 04:51:46 +0000437 const char *disassembly = NULL;
Greg Clayton63094e02010-06-23 01:19:29 +0000438 if (m_opaque_sp)
Greg Claytona66ba462010-10-30 04:51:46 +0000439 disassembly = m_opaque_sp->Disassemble();
Greg Claytone005f2c2010-11-06 01:53:30 +0000440 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Greg Claytona66ba462010-10-30 04:51:46 +0000441
442 if (log)
443 log->Printf ("SBFrame(%p)::Disassemble () => %s", m_opaque_sp.get(), disassembly);
444
445 return disassembly;
Chris Lattner24943d22010-06-08 16:52:24 +0000446}
447
448
Chris Lattner24943d22010-06-08 16:52:24 +0000449SBValueList
450SBFrame::GetVariables (bool arguments,
451 bool locals,
452 bool statics,
453 bool in_scope_only)
454{
Greg Claytone005f2c2010-11-06 01:53:30 +0000455 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000456
457 if (log)
Greg Claytona66ba462010-10-30 04:51:46 +0000458 log->Printf ("SBFrame(%p)::GetVariables (arguments=%i, locals=%i, statics=%i, in_scope_only=%i)",
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000459 m_opaque_sp.get(),
Greg Claytona66ba462010-10-30 04:51:46 +0000460 arguments,
461 locals,
462 statics,
463 in_scope_only);
Caroline Tice7826c882010-10-26 03:11:13 +0000464
Chris Lattner24943d22010-06-08 16:52:24 +0000465 SBValueList value_list;
Greg Clayton63094e02010-06-23 01:19:29 +0000466 if (m_opaque_sp)
Chris Lattner24943d22010-06-08 16:52:24 +0000467 {
468 size_t i;
Greg Clayton17dae082010-09-02 02:59:18 +0000469 VariableList *variable_list = m_opaque_sp->GetVariableList(true);
Chris Lattner24943d22010-06-08 16:52:24 +0000470 if (variable_list)
471 {
472 const size_t num_variables = variable_list->GetSize();
473 if (num_variables)
474 {
475 for (i = 0; i < num_variables; ++i)
476 {
477 VariableSP variable_sp (variable_list->GetVariableAtIndex(i));
478 if (variable_sp)
479 {
480 bool add_variable = false;
481 switch (variable_sp->GetScope())
482 {
483 case eValueTypeVariableGlobal:
484 case eValueTypeVariableStatic:
485 add_variable = statics;
486 break;
487
488 case eValueTypeVariableArgument:
489 add_variable = arguments;
490 break;
491
492 case eValueTypeVariableLocal:
493 add_variable = locals;
494 break;
Greg Clayton54e7afa2010-07-09 20:39:50 +0000495
496 default:
497 break;
Chris Lattner24943d22010-06-08 16:52:24 +0000498 }
499 if (add_variable)
500 {
Greg Clayton63094e02010-06-23 01:19:29 +0000501 if (in_scope_only && !variable_sp->IsInScope(m_opaque_sp.get()))
Chris Lattner24943d22010-06-08 16:52:24 +0000502 continue;
503
Greg Clayton17dae082010-09-02 02:59:18 +0000504 value_list.Append(m_opaque_sp->GetValueObjectForFrameVariable (variable_sp));
Chris Lattner24943d22010-06-08 16:52:24 +0000505 }
506 }
507 }
508 }
Greg Clayton17dae082010-09-02 02:59:18 +0000509 }
Chris Lattner24943d22010-06-08 16:52:24 +0000510 }
Caroline Tice7826c882010-10-26 03:11:13 +0000511
512 if (log)
513 {
Greg Claytona66ba462010-10-30 04:51:46 +0000514 log->Printf ("SBFrame(%p)::GetVariables (...) => SBValueList(%p)", m_opaque_sp.get(),
Caroline Tice61ba7ec2010-10-26 23:49:36 +0000515 value_list.get());
Caroline Tice7826c882010-10-26 03:11:13 +0000516 }
517
Chris Lattner24943d22010-06-08 16:52:24 +0000518 return value_list;
519}
520
521lldb::SBValueList
522SBFrame::GetRegisters ()
523{
Greg Claytone005f2c2010-11-06 01:53:30 +0000524 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Caroline Tice7826c882010-10-26 03:11:13 +0000525
Chris Lattner24943d22010-06-08 16:52:24 +0000526 SBValueList value_list;
Greg Clayton63094e02010-06-23 01:19:29 +0000527 if (m_opaque_sp)
Chris Lattner24943d22010-06-08 16:52:24 +0000528 {
Greg Clayton63094e02010-06-23 01:19:29 +0000529 RegisterContext *reg_ctx = m_opaque_sp->GetRegisterContext();
Chris Lattner24943d22010-06-08 16:52:24 +0000530 if (reg_ctx)
531 {
532 const uint32_t num_sets = reg_ctx->GetRegisterSetCount();
533 for (uint32_t set_idx = 0; set_idx < num_sets; ++set_idx)
534 {
Greg Claytonbf8e42b2010-10-14 22:52:14 +0000535 value_list.Append(ValueObjectSP (new ValueObjectRegisterSet (NULL, reg_ctx, set_idx)));
Chris Lattner24943d22010-06-08 16:52:24 +0000536 }
537 }
538 }
Caroline Tice7826c882010-10-26 03:11:13 +0000539
540 if (log)
Greg Claytona66ba462010-10-30 04:51:46 +0000541 log->Printf ("SBFrame(%p)::Registers () => SBValueList(%p)", m_opaque_sp.get(), value_list.get());
Caroline Tice7826c882010-10-26 03:11:13 +0000542
Chris Lattner24943d22010-06-08 16:52:24 +0000543 return value_list;
544}
545
Caroline Tice98f930f2010-09-20 05:20:02 +0000546bool
547SBFrame::GetDescription (SBStream &description)
548{
549 if (m_opaque_sp)
550 {
Greg Clayton49ce6822010-10-31 03:01:06 +0000551 Stream &s = description.ref();
552 m_opaque_sp->DumpUsingSettingsFormat (&s);
Caroline Tice98f930f2010-09-20 05:20:02 +0000553 }
554 else
555 description.Printf ("No value");
556
557 return true;
558}
Greg Clayton66ed2fb2010-10-05 00:00:42 +0000559
560lldb::SBValue
561SBFrame::EvaluateExpression (const char *expr)
562{
Greg Claytone005f2c2010-11-06 01:53:30 +0000563 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API));
Sean Callanan94d255f2010-12-07 22:55:01 +0000564
565 LogSP expr_log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_EXPRESSIONS));
Greg Claytona66ba462010-10-30 04:51:46 +0000566
Greg Clayton49ce6822010-10-31 03:01:06 +0000567 lldb::SBValue expr_result;
Greg Claytona66ba462010-10-30 04:51:46 +0000568 if (log)
569 log->Printf ("SBFrame(%p)::EvaluateExpression (expr=\"%s\")...", m_opaque_sp.get(), expr);
570
Greg Clayton66ed2fb2010-10-05 00:00:42 +0000571 if (m_opaque_sp)
572 {
Greg Clayton427f2902010-12-14 02:59:59 +0000573 lldb::ExecutionResults exe_results;
574 const bool unwind_on_error = true;
575
576 exe_results = m_opaque_sp->GetThread().GetProcess().GetTarget().EvaluateExpression(expr, m_opaque_sp.get(), unwind_on_error, *expr_result);
Greg Clayton66ed2fb2010-10-05 00:00:42 +0000577 }
Greg Claytona66ba462010-10-30 04:51:46 +0000578
Sean Callanan94d255f2010-12-07 22:55:01 +0000579 if (expr_log)
580 expr_log->Printf("** [SBFrame::EvaluateExpression] Expression result is %s, summary %s **", expr_result.GetValue(*this), expr_result.GetSummary(*this));
581
Greg Claytona66ba462010-10-30 04:51:46 +0000582 if (log)
Greg Clayton49ce6822010-10-31 03:01:06 +0000583 log->Printf ("SBFrame(%p)::EvaluateExpression (expr=\"%s\") => SBValue(%p)", m_opaque_sp.get(), expr, expr_result.get());
Greg Claytona66ba462010-10-30 04:51:46 +0000584
Greg Clayton49ce6822010-10-31 03:01:06 +0000585 return expr_result;
Greg Clayton66ed2fb2010-10-05 00:00:42 +0000586}