blob: e747f5b56f0306ae32049eeb9b962ed676444252 [file] [log] [blame]
Chris Lattner30fdc8d2010-06-08 16:52:24 +00001//===-- ClangExpressionDeclMap.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
10#include "lldb/Expression/ClangExpressionDeclMap.h"
11
12// C Includes
13// C++ Includes
14// Other libraries and framework includes
15// Project includes
Sean Callanan3d654b32012-09-24 22:25:51 +000016#include "clang/AST/ASTContext.h"
Sean Callanane2ef6e32010-09-23 03:01:22 +000017#include "clang/AST/DeclarationName.h"
Sean Callanan530782942010-11-01 23:22:47 +000018#include "clang/AST/Decl.h"
Chris Lattner30fdc8d2010-06-08 16:52:24 +000019#include "lldb/lldb-private.h"
20#include "lldb/Core/Address.h"
Sean Callananea22d422010-07-16 00:09:46 +000021#include "lldb/Core/Error.h"
Sean Callananf06ba8d2010-06-23 00:47:48 +000022#include "lldb/Core/Log.h"
Chris Lattner30fdc8d2010-06-08 16:52:24 +000023#include "lldb/Core/Module.h"
Greg Clayton7349bd92011-05-09 20:18:18 +000024#include "lldb/Core/RegisterValue.h"
Sean Callanane4ec90e2010-12-16 03:17:46 +000025#include "lldb/Core/ValueObjectConstResult.h"
Sean Callanan9b3569b2011-12-10 03:12:34 +000026#include "lldb/Core/ValueObjectVariable.h"
Sean Callanan0917d6e2011-02-01 23:43:26 +000027#include "lldb/Expression/ASTDumper.h"
Chris Lattner30fdc8d2010-06-08 16:52:24 +000028#include "lldb/Expression/ClangASTSource.h"
Sean Callanan2235f322010-08-11 03:57:18 +000029#include "lldb/Expression/ClangPersistentVariables.h"
Greg Clayton7fb56d02011-02-01 01:31:41 +000030#include "lldb/Host/Endian.h"
Chris Lattner30fdc8d2010-06-08 16:52:24 +000031#include "lldb/Symbol/ClangASTContext.h"
Greg Clayton526e5af2010-11-13 03:52:47 +000032#include "lldb/Symbol/ClangNamespaceDecl.h"
Chris Lattner30fdc8d2010-06-08 16:52:24 +000033#include "lldb/Symbol/CompileUnit.h"
34#include "lldb/Symbol/Function.h"
35#include "lldb/Symbol/ObjectFile.h"
36#include "lldb/Symbol/SymbolContext.h"
Sean Callanan503aa522011-10-12 00:12:34 +000037#include "lldb/Symbol/SymbolVendor.h"
Chris Lattner30fdc8d2010-06-08 16:52:24 +000038#include "lldb/Symbol/Type.h"
39#include "lldb/Symbol/TypeList.h"
40#include "lldb/Symbol/Variable.h"
41#include "lldb/Symbol/VariableList.h"
Sean Callanan1d180662010-07-20 23:31:16 +000042#include "lldb/Target/ExecutionContext.h"
Sean Callanane0b23b52012-11-15 02:02:04 +000043#include "lldb/Target/ObjCLanguageRuntime.h"
Sean Callananea22d422010-07-16 00:09:46 +000044#include "lldb/Target/Process.h"
Sean Callananf4b9bd32010-10-05 20:18:48 +000045#include "lldb/Target/RegisterContext.h"
Chris Lattner30fdc8d2010-06-08 16:52:24 +000046#include "lldb/Target/StackFrame.h"
Sean Callanan1d180662010-07-20 23:31:16 +000047#include "lldb/Target/Target.h"
Jim Ingham895c9822010-12-07 01:56:02 +000048#include "lldb/Target/Thread.h"
Chris Lattner30fdc8d2010-06-08 16:52:24 +000049
Greg Clayton83c5cd92010-11-14 22:13:40 +000050using namespace lldb;
Chris Lattner30fdc8d2010-06-08 16:52:24 +000051using namespace lldb_private;
52using namespace clang;
53
Sean Callanan1ee44b72011-10-29 01:58:46 +000054ClangExpressionDeclMap::ClangExpressionDeclMap (bool keep_result_in_memory, ExecutionContext &exe_ctx) :
55 ClangASTSource (exe_ctx.GetTargetSP()),
Greg Clayton7b462cc2010-10-15 22:48:33 +000056 m_found_entities (),
57 m_struct_members (),
Stephen Wilson71c21d12011-04-11 19:41:40 +000058 m_keep_result_in_memory (keep_result_in_memory),
Sean Callanan979f74d2010-12-03 01:38:59 +000059 m_parser_vars (),
Stephen Wilson71c21d12011-04-11 19:41:40 +000060 m_struct_vars ()
Chris Lattner30fdc8d2010-06-08 16:52:24 +000061{
Sean Callanan979f74d2010-12-03 01:38:59 +000062 EnableStructVars();
Chris Lattner30fdc8d2010-06-08 16:52:24 +000063}
64
65ClangExpressionDeclMap::~ClangExpressionDeclMap()
Sean Callanan979f74d2010-12-03 01:38:59 +000066{
Sean Callanane3aef1d2011-10-12 22:20:02 +000067 // Note: The model is now that the parser's AST context and all associated
68 // data does not vanish until the expression has been executed. This means
69 // that valuable lookup data (like namespaces) doesn't vanish, but
70
71 DidParse();
Sean Callanan979f74d2010-12-03 01:38:59 +000072 DidDematerialize();
73 DisableStructVars();
74}
Sean Callananbe3a1b12010-10-26 00:31:56 +000075
Sean Callananb9951192011-08-01 18:18:33 +000076bool
Greg Clayton8b2fe6d2010-12-14 02:59:59 +000077ClangExpressionDeclMap::WillParse(ExecutionContext &exe_ctx)
Sean Callanan8106d802013-03-08 20:04:57 +000078{
79 ClangASTMetrics::ClearLocalCounters();
80
Sean Callanan979f74d2010-12-03 01:38:59 +000081 EnableParserVars();
Sean Callanan933693b2012-02-10 01:22:05 +000082 m_parser_vars->m_exe_ctx = exe_ctx;
Greg Claytonc14ee322011-09-22 04:58:26 +000083
84 Target *target = exe_ctx.GetTargetPtr();
85 if (exe_ctx.GetFramePtr())
86 m_parser_vars->m_sym_ctx = exe_ctx.GetFramePtr()->GetSymbolContext(lldb::eSymbolContextEverything);
Sean Callanand4fac252013-02-21 22:01:43 +000087 else if (exe_ctx.GetThreadPtr() && exe_ctx.GetThreadPtr()->GetStackFrameAtIndex(0))
Greg Claytonc14ee322011-09-22 04:58:26 +000088 m_parser_vars->m_sym_ctx = exe_ctx.GetThreadPtr()->GetStackFrameAtIndex(0)->GetSymbolContext(lldb::eSymbolContextEverything);
89 else if (exe_ctx.GetProcessPtr())
Greg Clayton4d122c42011-09-17 08:33:22 +000090 {
Greg Clayton72310352013-02-23 04:12:47 +000091 m_parser_vars->m_sym_ctx.Clear(true);
Greg Claytonc14ee322011-09-22 04:58:26 +000092 m_parser_vars->m_sym_ctx.target_sp = exe_ctx.GetTargetSP();
Greg Clayton4d122c42011-09-17 08:33:22 +000093 }
Greg Claytonc14ee322011-09-22 04:58:26 +000094 else if (target)
Greg Clayton4d122c42011-09-17 08:33:22 +000095 {
Greg Clayton72310352013-02-23 04:12:47 +000096 m_parser_vars->m_sym_ctx.Clear(true);
Greg Claytonc14ee322011-09-22 04:58:26 +000097 m_parser_vars->m_sym_ctx.target_sp = exe_ctx.GetTargetSP();
Greg Clayton4d122c42011-09-17 08:33:22 +000098 }
Sean Callananc2ff2742011-09-15 18:41:04 +000099
Greg Claytonc14ee322011-09-22 04:58:26 +0000100 if (target)
101 {
102 m_parser_vars->m_persistent_vars = &target->GetPersistentVariables();
Sean Callananb9951192011-08-01 18:18:33 +0000103
Greg Claytonc14ee322011-09-22 04:58:26 +0000104 if (!target->GetScratchClangASTContext())
105 return false;
106 }
Sean Callananb9951192011-08-01 18:18:33 +0000107
Sean Callanan3bfdaa22011-09-15 02:13:07 +0000108 m_parser_vars->m_target_info = GetTargetInfo();
109
Sean Callananb9951192011-08-01 18:18:33 +0000110 return true;
Sean Callanan979f74d2010-12-03 01:38:59 +0000111}
112
Greg Clayton8b2fe6d2010-12-14 02:59:59 +0000113void
114ClangExpressionDeclMap::DidParse()
Sean Callanan979f74d2010-12-03 01:38:59 +0000115{
Sean Callanan8106d802013-03-08 20:04:57 +0000116 lldb::LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_EXPRESSIONS));
117
118 if (log)
119 ClangASTMetrics::DumpCounters(log);
120
Sean Callanan979f74d2010-12-03 01:38:59 +0000121 if (m_parser_vars.get())
122 {
Greg Clayton8b2fe6d2010-12-14 02:59:59 +0000123 for (size_t entity_index = 0, num_entities = m_found_entities.GetSize();
Sean Callanan979f74d2010-12-03 01:38:59 +0000124 entity_index < num_entities;
125 ++entity_index)
126 {
Greg Clayton8b2fe6d2010-12-14 02:59:59 +0000127 ClangExpressionVariableSP var_sp(m_found_entities.GetVariableAtIndex(entity_index));
Jim Ingham28eb5712012-10-12 17:34:26 +0000128 if (var_sp)
129 {
Sean Callanan3c495c12013-01-15 23:29:36 +0000130 ClangExpressionVariable::ParserVars *parser_vars = var_sp->GetParserVars(GetParserID());
131
132 if (parser_vars && parser_vars->m_lldb_value)
133 delete parser_vars->m_lldb_value;
Sean Callanan979f74d2010-12-03 01:38:59 +0000134
Sean Callanan3c495c12013-01-15 23:29:36 +0000135 var_sp->DisableParserVars(GetParserID());
Jim Ingham28eb5712012-10-12 17:34:26 +0000136 }
Sean Callanan979f74d2010-12-03 01:38:59 +0000137 }
138
Greg Clayton8b2fe6d2010-12-14 02:59:59 +0000139 for (size_t pvar_index = 0, num_pvars = m_parser_vars->m_persistent_vars->GetSize();
Sean Callanan979f74d2010-12-03 01:38:59 +0000140 pvar_index < num_pvars;
141 ++pvar_index)
142 {
Greg Clayton8b2fe6d2010-12-14 02:59:59 +0000143 ClangExpressionVariableSP pvar_sp(m_parser_vars->m_persistent_vars->GetVariableAtIndex(pvar_index));
144 if (pvar_sp)
Sean Callanan3c495c12013-01-15 23:29:36 +0000145 pvar_sp->DisableParserVars(GetParserID());
Sean Callanan979f74d2010-12-03 01:38:59 +0000146 }
147
148 DisableParserVars();
Sean Callanan6b1b9532010-10-08 01:58:41 +0000149 }
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000150}
151
Sean Callanan549c9f72010-07-13 21:41:46 +0000152// Interface for IRForTarget
153
Sean Callanan3bfdaa22011-09-15 02:13:07 +0000154ClangExpressionDeclMap::TargetInfo
155ClangExpressionDeclMap::GetTargetInfo()
156{
157 assert (m_parser_vars.get());
158
159 TargetInfo ret;
160
Sean Callanan933693b2012-02-10 01:22:05 +0000161 ExecutionContext &exe_ctx = m_parser_vars->m_exe_ctx;
162
163 Process *process = exe_ctx.GetProcessPtr();
164 if (process)
Sean Callanan3bfdaa22011-09-15 02:13:07 +0000165 {
Sean Callanan933693b2012-02-10 01:22:05 +0000166 ret.byte_order = process->GetByteOrder();
167 ret.address_byte_size = process->GetAddressByteSize();
168 }
169 else
170 {
171 Target *target = exe_ctx.GetTargetPtr();
172 if (target)
Greg Claytonc14ee322011-09-22 04:58:26 +0000173 {
Sean Callanan933693b2012-02-10 01:22:05 +0000174 ret.byte_order = target->GetArchitecture().GetByteOrder();
175 ret.address_byte_size = target->GetArchitecture().GetAddressByteSize();
Greg Claytonc14ee322011-09-22 04:58:26 +0000176 }
Sean Callanan3bfdaa22011-09-15 02:13:07 +0000177 }
Sean Callanan933693b2012-02-10 01:22:05 +0000178
Sean Callanan3bfdaa22011-09-15 02:13:07 +0000179 return ret;
180}
181
Greg Clayton7b462cc2010-10-15 22:48:33 +0000182const ConstString &
183ClangExpressionDeclMap::GetPersistentResultName ()
Sean Callanand1e5b432010-08-12 01:56:52 +0000184{
Sean Callanan979f74d2010-12-03 01:38:59 +0000185 assert (m_struct_vars.get());
186 assert (m_parser_vars.get());
Sean Callanan979f74d2010-12-03 01:38:59 +0000187 if (!m_struct_vars->m_result_name)
Greg Clayton8b2fe6d2010-12-14 02:59:59 +0000188 {
189 Target *target = m_parser_vars->GetTarget();
190 assert (target);
191 m_struct_vars->m_result_name = target->GetPersistentVariables().GetNextPersistentVariableName();
192 }
Sean Callanan979f74d2010-12-03 01:38:59 +0000193 return m_struct_vars->m_result_name;
Sean Callanand1e5b432010-08-12 01:56:52 +0000194}
195
Sean Callanane4ec90e2010-12-16 03:17:46 +0000196lldb::ClangExpressionVariableSP
197ClangExpressionDeclMap::BuildIntegerVariable (const ConstString &name,
198 lldb_private::TypeFromParser type,
199 const llvm::APInt& value)
200{
201 assert (m_parser_vars.get());
Sean Callananb9951192011-08-01 18:18:33 +0000202
Sean Callanan933693b2012-02-10 01:22:05 +0000203 ExecutionContext &exe_ctx = m_parser_vars->m_exe_ctx;
204
205 Target *target = exe_ctx.GetTargetPtr();
206
207 if (!target)
208 return ClangExpressionVariableSP();
Greg Claytonc14ee322011-09-22 04:58:26 +0000209
210 ASTContext *context(target->GetScratchClangASTContext()->getASTContext());
Sean Callanane4ec90e2010-12-16 03:17:46 +0000211
Sean Callanan00f43622011-11-18 03:28:09 +0000212 TypeFromUser user_type(m_ast_importer->CopyType(context,
213 type.GetASTContext(),
214 type.GetOpaqueQualType()),
Sean Callanane4ec90e2010-12-16 03:17:46 +0000215 context);
Sean Callanan3bfdaa22011-09-15 02:13:07 +0000216
Sean Callanane0a64f72011-12-01 21:04:37 +0000217 if (!user_type.GetOpaqueQualType())
218 {
219 lldb::LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_EXPRESSIONS));
220
221 if (log)
222 log->Printf("ClangExpressionDeclMap::BuildIntegerVariable - Couldn't export the type for a constant integer result");
223
224 return lldb::ClangExpressionVariableSP();
225 }
226
Sean Callanan933693b2012-02-10 01:22:05 +0000227 if (!m_parser_vars->m_persistent_vars->CreatePersistentVariable (exe_ctx.GetBestExecutionContextScope (),
Jim Ingham6035b672011-03-31 00:19:25 +0000228 name,
Sean Callanane4f987222011-01-04 02:41:41 +0000229 user_type,
Sean Callanan3bfdaa22011-09-15 02:13:07 +0000230 m_parser_vars->m_target_info.byte_order,
231 m_parser_vars->m_target_info.address_byte_size))
Sean Callanane4f987222011-01-04 02:41:41 +0000232 return lldb::ClangExpressionVariableSP();
Sean Callanane4ec90e2010-12-16 03:17:46 +0000233
Sean Callanane4f987222011-01-04 02:41:41 +0000234 ClangExpressionVariableSP pvar_sp (m_parser_vars->m_persistent_vars->GetVariable(name));
235
236 if (!pvar_sp)
237 return lldb::ClangExpressionVariableSP();
238
239 uint8_t *pvar_data = pvar_sp->GetValueBytes();
240 if (pvar_data == NULL)
241 return lldb::ClangExpressionVariableSP();
Sean Callanane4ec90e2010-12-16 03:17:46 +0000242
243 uint64_t value64 = value.getLimitedValue();
Sean Callanan3bfdaa22011-09-15 02:13:07 +0000244
Sean Callanane4ec90e2010-12-16 03:17:46 +0000245 size_t num_val_bytes = sizeof(value64);
Sean Callanane4f987222011-01-04 02:41:41 +0000246 size_t num_data_bytes = pvar_sp->GetByteSize();
Sean Callanane4ec90e2010-12-16 03:17:46 +0000247
248 size_t num_bytes = num_val_bytes;
249 if (num_bytes > num_data_bytes)
250 num_bytes = num_data_bytes;
251
Johnny Chen44805302011-07-19 19:48:13 +0000252 for (size_t byte_idx = 0;
Sean Callanane4ec90e2010-12-16 03:17:46 +0000253 byte_idx < num_bytes;
254 ++byte_idx)
255 {
256 uint64_t shift = byte_idx * 8;
257 uint64_t mask = 0xffll << shift;
258 uint8_t cur_byte = (uint8_t)((value64 & mask) >> shift);
259
Sean Callanan3bfdaa22011-09-15 02:13:07 +0000260 switch (m_parser_vars->m_target_info.byte_order)
Sean Callanane4ec90e2010-12-16 03:17:46 +0000261 {
Sean Callanane4f987222011-01-04 02:41:41 +0000262 case eByteOrderBig:
263 // High Low
264 // Original: |AABBCCDDEEFFGGHH|
265 // Target: |EEFFGGHH|
266
267 pvar_data[num_data_bytes - (1 + byte_idx)] = cur_byte;
268 break;
269 case eByteOrderLittle:
270 // Target: |HHGGFFEE|
271 pvar_data[byte_idx] = cur_byte;
272 break;
273 default:
274 return lldb::ClangExpressionVariableSP();
Sean Callanane4ec90e2010-12-16 03:17:46 +0000275 }
276 }
Sean Callanan92adcac2011-01-13 08:53:35 +0000277
278 pvar_sp->m_flags |= ClangExpressionVariable::EVIsFreezeDried;
Sean Callanan63697e52011-05-07 01:06:41 +0000279 pvar_sp->m_flags |= ClangExpressionVariable::EVIsLLDBAllocated;
280 pvar_sp->m_flags |= ClangExpressionVariable::EVNeedsAllocation;
Sean Callanane4f987222011-01-04 02:41:41 +0000281
282 return pvar_sp;
Sean Callanane4ec90e2010-12-16 03:17:46 +0000283}
284
Sean Callanan63697e52011-05-07 01:06:41 +0000285lldb::ClangExpressionVariableSP
286ClangExpressionDeclMap::BuildCastVariable (const ConstString &name,
Sean Callanancc427fa2011-07-30 02:42:06 +0000287 VarDecl *decl,
Sean Callanan63697e52011-05-07 01:06:41 +0000288 lldb_private::TypeFromParser type)
289{
290 assert (m_parser_vars.get());
291
292 lldb::LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_EXPRESSIONS));
293
Sean Callanan933693b2012-02-10 01:22:05 +0000294 ExecutionContext &exe_ctx = m_parser_vars->m_exe_ctx;
295 Target *target = exe_ctx.GetTargetPtr();
Greg Claytonc14ee322011-09-22 04:58:26 +0000296 if (target == NULL)
297 return lldb::ClangExpressionVariableSP();
298
299 ASTContext *context(target->GetScratchClangASTContext()->getASTContext());
Sean Callanan63697e52011-05-07 01:06:41 +0000300
Sean Callanan3c495c12013-01-15 23:29:36 +0000301 ClangExpressionVariableSP var_sp (m_found_entities.GetVariable(decl, GetParserID()));
Sean Callanan63697e52011-05-07 01:06:41 +0000302
303 if (!var_sp)
Sean Callanan3c495c12013-01-15 23:29:36 +0000304 var_sp = m_parser_vars->m_persistent_vars->GetVariable(decl, GetParserID());
Sean Callanan63697e52011-05-07 01:06:41 +0000305
306 if (!var_sp)
307 return ClangExpressionVariableSP();
308
Sean Callanan00f43622011-11-18 03:28:09 +0000309 TypeFromUser user_type(m_ast_importer->CopyType(context,
310 type.GetASTContext(),
311 type.GetOpaqueQualType()),
Sean Callanan63697e52011-05-07 01:06:41 +0000312 context);
313
Sean Callanane0a64f72011-12-01 21:04:37 +0000314 if (!user_type.GetOpaqueQualType())
Jason Molendaccd41e52012-10-04 22:47:07 +0000315 {
Sean Callanane0a64f72011-12-01 21:04:37 +0000316 if (log)
317 log->Printf("ClangExpressionDeclMap::BuildCastVariable - Couldn't export the type for a constant cast result");
318
319 return lldb::ClangExpressionVariableSP();
320 }
321
Sean Callanan63697e52011-05-07 01:06:41 +0000322 TypeFromUser var_type = var_sp->GetTypeFromUser();
323
Sean Callanan933693b2012-02-10 01:22:05 +0000324 StackFrame *frame = exe_ctx.GetFramePtr();
Greg Claytonc14ee322011-09-22 04:58:26 +0000325 if (frame == NULL)
326 return lldb::ClangExpressionVariableSP();
327
328 VariableSP var = FindVariableInScope (*frame, var_sp->GetName(), &var_type);
Sean Callanan63697e52011-05-07 01:06:41 +0000329
330 if (!var)
331 return lldb::ClangExpressionVariableSP(); // but we should handle this; it may be a persistent variable
332
Greg Claytonc14ee322011-09-22 04:58:26 +0000333 ValueObjectSP var_valobj = frame->GetValueObjectForFrameVariable(var, lldb::eNoDynamicValues);
Sean Callanan63697e52011-05-07 01:06:41 +0000334
335 if (!var_valobj)
336 return lldb::ClangExpressionVariableSP();
337
338 ValueObjectSP var_casted_valobj = var_valobj->CastPointerType(name.GetCString(), user_type);
339
340 if (!var_casted_valobj)
341 return lldb::ClangExpressionVariableSP();
342
343 if (log)
344 {
345 StreamString my_stream_string;
346
347 ClangASTType::DumpTypeDescription (var_type.GetASTContext(),
348 var_type.GetOpaqueQualType(),
349 &my_stream_string);
350
351
352 log->Printf("Building cast variable to type: %s", my_stream_string.GetString().c_str());
353 }
354
355 ClangExpressionVariableSP pvar_sp = m_parser_vars->m_persistent_vars->CreatePersistentVariable (var_casted_valobj);
356
357 if (!pvar_sp)
358 return lldb::ClangExpressionVariableSP();
359
360 if (pvar_sp != m_parser_vars->m_persistent_vars->GetVariable(name))
361 return lldb::ClangExpressionVariableSP();
362
363 pvar_sp->m_flags |= ClangExpressionVariable::EVIsFreezeDried;
364 pvar_sp->m_flags |= ClangExpressionVariable::EVIsLLDBAllocated;
365 pvar_sp->m_flags |= ClangExpressionVariable::EVNeedsAllocation;
366
367 return pvar_sp;
368}
369
Sean Callanan3bfdaa22011-09-15 02:13:07 +0000370bool
371ClangExpressionDeclMap::ResultIsReference (const ConstString &name)
372{
373 ClangExpressionVariableSP pvar_sp = m_parser_vars->m_persistent_vars->GetVariable(name);
374
375 return (pvar_sp->m_flags & ClangExpressionVariable::EVIsProgramReference);
376}
377
378bool
379ClangExpressionDeclMap::CompleteResultVariable (lldb::ClangExpressionVariableSP &valobj,
380 lldb_private::Value &value,
381 const ConstString &name,
Sean Callanan0886e562011-09-22 00:41:11 +0000382 lldb_private::TypeFromParser type,
Sean Callanan80c48c12011-10-21 05:18:02 +0000383 bool transient,
384 bool maybe_make_load)
Sean Callanan3bfdaa22011-09-15 02:13:07 +0000385{
386 assert (m_parser_vars.get());
387
388 ClangExpressionVariableSP pvar_sp = m_parser_vars->m_persistent_vars->GetVariable(name);
389
390 if (!pvar_sp)
391 return false;
Sean Callanan80c48c12011-10-21 05:18:02 +0000392
393 if (maybe_make_load &&
394 value.GetValueType() == Value::eValueTypeFileAddress &&
Sean Callanan933693b2012-02-10 01:22:05 +0000395 m_parser_vars->m_exe_ctx.GetProcessPtr())
Sean Callanan80c48c12011-10-21 05:18:02 +0000396 {
397 value.SetValueType(Value::eValueTypeLoadAddress);
398 }
Sean Callanan3bfdaa22011-09-15 02:13:07 +0000399
400 if (pvar_sp->m_flags & ClangExpressionVariable::EVIsProgramReference &&
Sean Callanan0886e562011-09-22 00:41:11 +0000401 !pvar_sp->m_live_sp &&
402 !transient)
Sean Callanan3bfdaa22011-09-15 02:13:07 +0000403 {
404 // The reference comes from the program. We need to set up a live SP for it.
405
Johnny Chenb456b792011-12-16 23:04:52 +0000406 unsigned long long address = value.GetScalar().ULongLong();
407 AddressType address_type = value.GetValueAddressType();
408
Sean Callanan933693b2012-02-10 01:22:05 +0000409 pvar_sp->m_live_sp = ValueObjectConstResult::Create(m_parser_vars->m_exe_ctx.GetBestExecutionContextScope(),
Sean Callanan3bfdaa22011-09-15 02:13:07 +0000410 pvar_sp->GetTypeFromUser().GetASTContext(),
411 pvar_sp->GetTypeFromUser().GetOpaqueQualType(),
412 pvar_sp->GetName(),
Johnny Chenb456b792011-12-16 23:04:52 +0000413 address,
414 address_type,
Sean Callanan3bfdaa22011-09-15 02:13:07 +0000415 pvar_sp->GetByteSize());
416 }
417
418 if (pvar_sp->m_flags & ClangExpressionVariable::EVNeedsFreezeDry)
419 {
420 pvar_sp->ValueUpdated();
421
422 const size_t pvar_byte_size = pvar_sp->GetByteSize();
423 uint8_t *pvar_data = pvar_sp->GetValueBytes();
424
Sean Callanan5b26f272012-02-04 08:49:35 +0000425 if (!ReadTarget(pvar_data, value, pvar_byte_size))
426 return false;
Sean Callanan3bfdaa22011-09-15 02:13:07 +0000427
428 pvar_sp->m_flags &= ~(ClangExpressionVariable::EVNeedsFreezeDry);
429 }
430
431 valobj = pvar_sp;
432
433 return true;
434}
435
Sean Callanan5b26f272012-02-04 08:49:35 +0000436void
437ClangExpressionDeclMap::RemoveResultVariable
438(
439 const ConstString &name
440)
441{
442 ClangExpressionVariableSP pvar_sp = m_parser_vars->m_persistent_vars->GetVariable(name);
443 m_parser_vars->m_persistent_vars->RemovePersistentVariable(pvar_sp);
444}
445
Sean Callanan549c9f72010-07-13 21:41:46 +0000446bool
Greg Clayton7b462cc2010-10-15 22:48:33 +0000447ClangExpressionDeclMap::AddPersistentVariable
448(
Sean Callanancc427fa2011-07-30 02:42:06 +0000449 const NamedDecl *decl,
Greg Clayton7b462cc2010-10-15 22:48:33 +0000450 const ConstString &name,
Sean Callanan92adcac2011-01-13 08:53:35 +0000451 TypeFromParser parser_type,
452 bool is_result,
453 bool is_lvalue
Greg Clayton7b462cc2010-10-15 22:48:33 +0000454)
Sean Callanan2235f322010-08-11 03:57:18 +0000455{
Sean Callanan979f74d2010-12-03 01:38:59 +0000456 assert (m_parser_vars.get());
457
Sean Callanan92adcac2011-01-13 08:53:35 +0000458 lldb::LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_EXPRESSIONS));
Sean Callanan933693b2012-02-10 01:22:05 +0000459 ExecutionContext &exe_ctx = m_parser_vars->m_exe_ctx;
460 Target *target = exe_ctx.GetTargetPtr();
Greg Claytonc14ee322011-09-22 04:58:26 +0000461 if (target == NULL)
462 return false;
463
464 ASTContext *context(target->GetScratchClangASTContext()->getASTContext());
Sean Callanan2235f322010-08-11 03:57:18 +0000465
Sean Callananbb120042011-12-16 21:06:35 +0000466 TypeFromUser user_type(m_ast_importer->DeportType(context,
467 parser_type.GetASTContext(),
468 parser_type.GetOpaqueQualType()),
Sean Callanane1175b72011-01-13 21:23:32 +0000469 context);
Sean Callanan00f43622011-11-18 03:28:09 +0000470
471 if (!user_type.GetOpaqueQualType())
472 {
473 if (log)
474 log->Printf("Persistent variable's type wasn't copied successfully");
475 return false;
476 }
Sean Callanan3bfdaa22011-09-15 02:13:07 +0000477
478 if (!m_parser_vars->m_target_info.IsValid())
479 return false;
Sean Callanan2235f322010-08-11 03:57:18 +0000480
Sean Callanan933693b2012-02-10 01:22:05 +0000481 if (!m_parser_vars->m_persistent_vars->CreatePersistentVariable (exe_ctx.GetBestExecutionContextScope (),
Jim Ingham6035b672011-03-31 00:19:25 +0000482 name,
Greg Clayton8b2fe6d2010-12-14 02:59:59 +0000483 user_type,
Sean Callanan3bfdaa22011-09-15 02:13:07 +0000484 m_parser_vars->m_target_info.byte_order,
485 m_parser_vars->m_target_info.address_byte_size))
Sean Callanan64dfc9a2010-08-23 23:09:38 +0000486 return false;
487
Greg Clayton8b2fe6d2010-12-14 02:59:59 +0000488 ClangExpressionVariableSP var_sp (m_parser_vars->m_persistent_vars->GetVariable(name));
Sean Callanan64dfc9a2010-08-23 23:09:38 +0000489
Greg Clayton8b2fe6d2010-12-14 02:59:59 +0000490 if (!var_sp)
Sean Callanan64dfc9a2010-08-23 23:09:38 +0000491 return false;
492
Sean Callanan2cb5e522012-09-20 23:21:16 +0000493 var_sp->m_frozen_sp->SetHasCompleteType();
494
Sean Callanan92adcac2011-01-13 08:53:35 +0000495 if (is_result)
496 var_sp->m_flags |= ClangExpressionVariable::EVNeedsFreezeDry;
497 else
498 var_sp->m_flags |= ClangExpressionVariable::EVKeepInTarget; // explicitly-declared persistent variables should persist
499
500 if (is_lvalue)
501 {
502 var_sp->m_flags |= ClangExpressionVariable::EVIsProgramReference;
503 }
504 else
505 {
506 var_sp->m_flags |= ClangExpressionVariable::EVIsLLDBAllocated;
507 var_sp->m_flags |= ClangExpressionVariable::EVNeedsAllocation;
508 }
509
510 if (log)
511 log->Printf("Created persistent variable with flags 0x%hx", var_sp->m_flags);
512
Sean Callanan3c495c12013-01-15 23:29:36 +0000513 var_sp->EnableParserVars(GetParserID());
Sean Callanan64dfc9a2010-08-23 23:09:38 +0000514
Sean Callanan3c495c12013-01-15 23:29:36 +0000515 ClangExpressionVariable::ParserVars *parser_vars = var_sp->GetParserVars(GetParserID());
516
517 parser_vars->m_named_decl = decl;
518 parser_vars->m_parser_type = parser_type;
Sean Callanan64dfc9a2010-08-23 23:09:38 +0000519
520 return true;
Sean Callanan2235f322010-08-11 03:57:18 +0000521}
522
523bool
Greg Clayton7b462cc2010-10-15 22:48:33 +0000524ClangExpressionDeclMap::AddValueToStruct
525(
Sean Callanancc427fa2011-07-30 02:42:06 +0000526 const NamedDecl *decl,
Greg Clayton7b462cc2010-10-15 22:48:33 +0000527 const ConstString &name,
528 llvm::Value *value,
529 size_t size,
530 off_t alignment
531)
Sean Callanan549c9f72010-07-13 21:41:46 +0000532{
Sean Callanan979f74d2010-12-03 01:38:59 +0000533 assert (m_struct_vars.get());
534 assert (m_parser_vars.get());
535
Greg Clayton2d4edfb2010-11-06 01:53:30 +0000536 lldb::LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_EXPRESSIONS));
Sean Callanan823bb4c2010-08-30 22:17:16 +0000537
Sean Callanan979f74d2010-12-03 01:38:59 +0000538 m_struct_vars->m_struct_laid_out = false;
Sean Callanan549c9f72010-07-13 21:41:46 +0000539
Sean Callanan3c495c12013-01-15 23:29:36 +0000540 if (m_struct_members.GetVariable(decl, GetParserID()))
Sean Callanan64dfc9a2010-08-23 23:09:38 +0000541 return true;
Sean Callanan549c9f72010-07-13 21:41:46 +0000542
Sean Callanan3c495c12013-01-15 23:29:36 +0000543 ClangExpressionVariableSP var_sp (m_found_entities.GetVariable(decl, GetParserID()));
Sean Callanan549c9f72010-07-13 21:41:46 +0000544
Greg Clayton8b2fe6d2010-12-14 02:59:59 +0000545 if (!var_sp)
Sean Callanan3c495c12013-01-15 23:29:36 +0000546 var_sp = m_parser_vars->m_persistent_vars->GetVariable(decl, GetParserID());
Sean Callanan549c9f72010-07-13 21:41:46 +0000547
Greg Clayton8b2fe6d2010-12-14 02:59:59 +0000548 if (!var_sp)
Sean Callanan64dfc9a2010-08-23 23:09:38 +0000549 return false;
550
Sean Callanan823bb4c2010-08-30 22:17:16 +0000551 if (log)
Sean Callanan00f43622011-11-18 03:28:09 +0000552 log->Printf("Adding value for (NamedDecl*)%p [%s - %s] to the structure",
Sean Callanan823bb4c2010-08-30 22:17:16 +0000553 decl,
Greg Clayton7b462cc2010-10-15 22:48:33 +0000554 name.GetCString(),
Greg Clayton8b2fe6d2010-12-14 02:59:59 +0000555 var_sp->GetName().GetCString());
Sean Callanan823bb4c2010-08-30 22:17:16 +0000556
Sean Callanan64dfc9a2010-08-23 23:09:38 +0000557 // We know entity->m_parser_vars is valid because we used a parser variable
558 // to find it
Sean Callanan64dfc9a2010-08-23 23:09:38 +0000559
Sean Callanan3c495c12013-01-15 23:29:36 +0000560 ClangExpressionVariable::ParserVars *parser_vars = var_sp->GetParserVars(GetParserID());
561
562 parser_vars->m_llvm_value = value;
563
564 var_sp->EnableJITVars(GetParserID());
565
566 ClangExpressionVariable::JITVars *jit_vars = var_sp->GetJITVars(GetParserID());
567
568 jit_vars->m_alignment = alignment;
569 jit_vars->m_size = size;
Sean Callanan64dfc9a2010-08-23 23:09:38 +0000570
Greg Clayton8b2fe6d2010-12-14 02:59:59 +0000571 m_struct_members.AddVariable(var_sp);
Sean Callanan549c9f72010-07-13 21:41:46 +0000572
573 return true;
574}
575
576bool
577ClangExpressionDeclMap::DoStructLayout ()
578{
Sean Callanan979f74d2010-12-03 01:38:59 +0000579 assert (m_struct_vars.get());
580
581 if (m_struct_vars->m_struct_laid_out)
Sean Callanan549c9f72010-07-13 21:41:46 +0000582 return true;
583
Sean Callanan549c9f72010-07-13 21:41:46 +0000584 off_t cursor = 0;
585
Sean Callanan979f74d2010-12-03 01:38:59 +0000586 m_struct_vars->m_struct_alignment = 0;
587 m_struct_vars->m_struct_size = 0;
Sean Callanan549c9f72010-07-13 21:41:46 +0000588
Greg Clayton8b2fe6d2010-12-14 02:59:59 +0000589 for (size_t member_index = 0, num_members = m_struct_members.GetSize();
Sean Callanan64dfc9a2010-08-23 23:09:38 +0000590 member_index < num_members;
591 ++member_index)
Sean Callanan549c9f72010-07-13 21:41:46 +0000592 {
Greg Clayton8b2fe6d2010-12-14 02:59:59 +0000593 ClangExpressionVariableSP member_sp(m_struct_members.GetVariableAtIndex(member_index));
594 if (!member_sp)
595 return false;
Sean Callanan3c495c12013-01-15 23:29:36 +0000596
597 ClangExpressionVariable::JITVars *jit_vars = member_sp->GetJITVars(GetParserID());
Greg Clayton8b2fe6d2010-12-14 02:59:59 +0000598
Sean Callanan3c495c12013-01-15 23:29:36 +0000599 if (!jit_vars)
Sean Callanan64dfc9a2010-08-23 23:09:38 +0000600 return false;
Sean Callanan549c9f72010-07-13 21:41:46 +0000601
Sean Callanan64dfc9a2010-08-23 23:09:38 +0000602 if (member_index == 0)
Sean Callanan3c495c12013-01-15 23:29:36 +0000603 m_struct_vars->m_struct_alignment = jit_vars->m_alignment;
Sean Callanan64dfc9a2010-08-23 23:09:38 +0000604
Sean Callanan3c495c12013-01-15 23:29:36 +0000605 if (cursor % jit_vars->m_alignment)
606 cursor += (jit_vars->m_alignment - (cursor % jit_vars->m_alignment));
Sean Callanan64dfc9a2010-08-23 23:09:38 +0000607
Sean Callanan3c495c12013-01-15 23:29:36 +0000608 jit_vars->m_offset = cursor;
609 cursor += jit_vars->m_size;
Sean Callanan549c9f72010-07-13 21:41:46 +0000610 }
611
Sean Callanan979f74d2010-12-03 01:38:59 +0000612 m_struct_vars->m_struct_size = cursor;
Sean Callanan549c9f72010-07-13 21:41:46 +0000613
Sean Callanan979f74d2010-12-03 01:38:59 +0000614 m_struct_vars->m_struct_laid_out = true;
Sean Callanan549c9f72010-07-13 21:41:46 +0000615 return true;
616}
617
Greg Clayton7b462cc2010-10-15 22:48:33 +0000618bool ClangExpressionDeclMap::GetStructInfo
619(
620 uint32_t &num_elements,
621 size_t &size,
622 off_t &alignment
623)
Sean Callanan549c9f72010-07-13 21:41:46 +0000624{
Sean Callanan979f74d2010-12-03 01:38:59 +0000625 assert (m_struct_vars.get());
626
627 if (!m_struct_vars->m_struct_laid_out)
Sean Callanan549c9f72010-07-13 21:41:46 +0000628 return false;
629
Greg Clayton8b2fe6d2010-12-14 02:59:59 +0000630 num_elements = m_struct_members.GetSize();
Sean Callanan979f74d2010-12-03 01:38:59 +0000631 size = m_struct_vars->m_struct_size;
632 alignment = m_struct_vars->m_struct_alignment;
Sean Callanan549c9f72010-07-13 21:41:46 +0000633
634 return true;
635}
636
637bool
Greg Clayton7b462cc2010-10-15 22:48:33 +0000638ClangExpressionDeclMap::GetStructElement
639(
Sean Callanancc427fa2011-07-30 02:42:06 +0000640 const NamedDecl *&decl,
Greg Clayton7b462cc2010-10-15 22:48:33 +0000641 llvm::Value *&value,
642 off_t &offset,
643 ConstString &name,
644 uint32_t index
645)
Sean Callanan549c9f72010-07-13 21:41:46 +0000646{
Sean Callanan979f74d2010-12-03 01:38:59 +0000647 assert (m_struct_vars.get());
648
649 if (!m_struct_vars->m_struct_laid_out)
Sean Callanan549c9f72010-07-13 21:41:46 +0000650 return false;
651
Greg Clayton8b2fe6d2010-12-14 02:59:59 +0000652 if (index >= m_struct_members.GetSize())
Sean Callanan549c9f72010-07-13 21:41:46 +0000653 return false;
654
Greg Clayton8b2fe6d2010-12-14 02:59:59 +0000655 ClangExpressionVariableSP member_sp(m_struct_members.GetVariableAtIndex(index));
Sean Callanan549c9f72010-07-13 21:41:46 +0000656
Sean Callanan3c495c12013-01-15 23:29:36 +0000657 if (!member_sp)
658 return false;
659
660 ClangExpressionVariable::ParserVars *parser_vars = member_sp->GetParserVars(GetParserID());
661 ClangExpressionVariable::JITVars *jit_vars = member_sp->GetJITVars(GetParserID());
662
663 if (!parser_vars ||
664 !jit_vars ||
Sean Callanan6f3e5ad2012-04-12 16:58:26 +0000665 !member_sp->GetValueObject())
Sean Callanan64dfc9a2010-08-23 23:09:38 +0000666 return false;
667
Sean Callanan3c495c12013-01-15 23:29:36 +0000668 decl = parser_vars->m_named_decl;
669 value = parser_vars->m_llvm_value;
670 offset = jit_vars->m_offset;
Greg Clayton8b2fe6d2010-12-14 02:59:59 +0000671 name = member_sp->GetName();
Sean Callanan64dfc9a2010-08-23 23:09:38 +0000672
Sean Callanan549c9f72010-07-13 21:41:46 +0000673 return true;
674}
675
Sean Callanan7ea35012010-07-27 21:39:39 +0000676bool
Greg Clayton7b462cc2010-10-15 22:48:33 +0000677ClangExpressionDeclMap::GetFunctionInfo
678(
Sean Callanancc427fa2011-07-30 02:42:06 +0000679 const NamedDecl *decl,
Greg Clayton7b462cc2010-10-15 22:48:33 +0000680 uint64_t &ptr
681)
Sean Callanan4edba2d2010-07-27 02:07:53 +0000682{
Sean Callanan3c495c12013-01-15 23:29:36 +0000683 ClangExpressionVariableSP entity_sp(m_found_entities.GetVariable(decl, GetParserID()));
Sean Callanan64dfc9a2010-08-23 23:09:38 +0000684
Greg Clayton8b2fe6d2010-12-14 02:59:59 +0000685 if (!entity_sp)
Sean Callanan64dfc9a2010-08-23 23:09:38 +0000686 return false;
Sean Callanan4edba2d2010-07-27 02:07:53 +0000687
Sean Callanan64dfc9a2010-08-23 23:09:38 +0000688 // We know m_parser_vars is valid since we searched for the variable by
689 // its NamedDecl
Sean Callanan4edba2d2010-07-27 02:07:53 +0000690
Sean Callanan3c495c12013-01-15 23:29:36 +0000691 ClangExpressionVariable::ParserVars *parser_vars = entity_sp->GetParserVars(GetParserID());
692
693 ptr = parser_vars->m_lldb_value->GetScalar().ULongLong();
Sean Callanan64dfc9a2010-08-23 23:09:38 +0000694
695 return true;
Sean Callanan4edba2d2010-07-27 02:07:53 +0000696}
697
Sean Callananefe9a422011-08-16 18:09:29 +0000698static void
699FindCodeSymbolInContext
700(
701 const ConstString &name,
702 SymbolContext &sym_ctx,
703 SymbolContextList &sc_list
704)
705{
Matt Kopec00049b82013-02-27 20:13:38 +0000706 SymbolContextList temp_sc_list;
Sean Callananefe9a422011-08-16 18:09:29 +0000707 if (sym_ctx.module_sp)
Matt Kopec00049b82013-02-27 20:13:38 +0000708 sym_ctx.module_sp->FindSymbolsWithNameAndType(name, eSymbolTypeAny, temp_sc_list);
Sean Callananefe9a422011-08-16 18:09:29 +0000709
Matt Kopec00049b82013-02-27 20:13:38 +0000710 if (!sc_list.GetSize() && sym_ctx.target_sp)
711 sym_ctx.target_sp->GetImages().FindSymbolsWithNameAndType(name, eSymbolTypeAny, temp_sc_list);
712
713 unsigned temp_sc_list_size = temp_sc_list.GetSize();
714 for (unsigned i = 0; i < temp_sc_list_size; i++)
715 {
716 SymbolContext sym_ctx;
717 temp_sc_list.GetContextAtIndex(i, sym_ctx);
718 if (sym_ctx.symbol)
719 {
720 switch (sym_ctx.symbol->GetType())
721 {
722 case eSymbolTypeCode:
723 case eSymbolTypeResolver:
724 sc_list.Append(sym_ctx);
725 break;
726
727 default:
728 break;
729 }
730 }
731 }
Sean Callananefe9a422011-08-16 18:09:29 +0000732}
733
Sean Callanan5300d372010-07-31 01:32:05 +0000734bool
Greg Clayton7b462cc2010-10-15 22:48:33 +0000735ClangExpressionDeclMap::GetFunctionAddress
736(
737 const ConstString &name,
Greg Clayton3f5c08f2011-05-18 22:01:49 +0000738 uint64_t &func_addr
Greg Clayton7b462cc2010-10-15 22:48:33 +0000739)
Sean Callanan5300d372010-07-31 01:32:05 +0000740{
Sean Callanan979f74d2010-12-03 01:38:59 +0000741 assert (m_parser_vars.get());
742
Sean Callanan19b6afe2011-05-13 18:27:02 +0000743 lldb::LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_EXPRESSIONS));
Sean Callanan933693b2012-02-10 01:22:05 +0000744 ExecutionContext &exe_ctx = m_parser_vars->m_exe_ctx;
745 Target *target = exe_ctx.GetTargetPtr();
Sean Callanan5300d372010-07-31 01:32:05 +0000746 // Back out in all cases where we're not fully initialized
Greg Claytonc14ee322011-09-22 04:58:26 +0000747 if (target == NULL)
Jim Ingham895c9822010-12-07 01:56:02 +0000748 return false;
749 if (!m_parser_vars->m_sym_ctx.target_sp)
Sean Callanan5300d372010-07-31 01:32:05 +0000750 return false;
751
Greg Clayton7a345282010-11-09 23:46:37 +0000752 SymbolContextList sc_list;
Sean Callanan5300d372010-07-31 01:32:05 +0000753
Sean Callananefe9a422011-08-16 18:09:29 +0000754 FindCodeSymbolInContext(name, m_parser_vars->m_sym_ctx, sc_list);
Matt Kopec00049b82013-02-27 20:13:38 +0000755
Greg Clayton7a345282010-11-09 23:46:37 +0000756 if (!sc_list.GetSize())
Sean Callanan19b6afe2011-05-13 18:27:02 +0000757 {
758 // We occasionally get debug information in which a const function is reported
759 // as non-const, so the mangled name is wrong. This is a hack to compensate.
760
Sean Callananf4638562011-10-25 18:02:05 +0000761 if (!strncmp(name.GetCString(), "_ZN", 3) &&
762 strncmp(name.GetCString(), "_ZNK", 4))
Sean Callanan19b6afe2011-05-13 18:27:02 +0000763 {
Sean Callananf4638562011-10-25 18:02:05 +0000764 std::string fixed_scratch("_ZNK");
765 fixed_scratch.append(name.GetCString() + 3);
766 ConstString fixed_name(fixed_scratch.c_str());
Sean Callanan19b6afe2011-05-13 18:27:02 +0000767
768 if (log)
Sean Callananf4638562011-10-25 18:02:05 +0000769 log->Printf("Failed to find symbols given non-const name %s; trying %s", name.GetCString(), fixed_name.GetCString());
770
771 FindCodeSymbolInContext(fixed_name, m_parser_vars->m_sym_ctx, sc_list);
Sean Callanan19b6afe2011-05-13 18:27:02 +0000772 }
773 }
774
775 if (!sc_list.GetSize())
Sean Callanan5300d372010-07-31 01:32:05 +0000776 return false;
Matt Kopec00049b82013-02-27 20:13:38 +0000777
Sean Callanan5300d372010-07-31 01:32:05 +0000778 SymbolContext sym_ctx;
Greg Clayton7a345282010-11-09 23:46:37 +0000779 sc_list.GetContextAtIndex(0, sym_ctx);
Matt Kopec00049b82013-02-27 20:13:38 +0000780
Greg Clayton3f5c08f2011-05-18 22:01:49 +0000781 const Address *func_so_addr = NULL;
Matt Kopec00049b82013-02-27 20:13:38 +0000782 bool is_indirect_function = false;
783
Sean Callanan5300d372010-07-31 01:32:05 +0000784 if (sym_ctx.function)
Greg Clayton3f5c08f2011-05-18 22:01:49 +0000785 func_so_addr = &sym_ctx.function->GetAddressRange().GetBaseAddress();
Matt Kopec00049b82013-02-27 20:13:38 +0000786 else if (sym_ctx.symbol) {
Greg Claytone7612132012-03-07 21:03:09 +0000787 func_so_addr = &sym_ctx.symbol->GetAddress();
Matt Kopec00049b82013-02-27 20:13:38 +0000788 is_indirect_function = sym_ctx.symbol->IsIndirect();
789 } else
Sean Callanan5300d372010-07-31 01:32:05 +0000790 return false;
Matt Kopec00049b82013-02-27 20:13:38 +0000791
Sean Callananc6466fc2011-07-07 23:05:43 +0000792 if (!func_so_addr || !func_so_addr->IsValid())
793 return false;
Matt Kopec00049b82013-02-27 20:13:38 +0000794
795 func_addr = func_so_addr->GetCallableLoadAddress (target, is_indirect_function);
Greg Clayton3f5c08f2011-05-18 22:01:49 +0000796
Sean Callanan5300d372010-07-31 01:32:05 +0000797 return true;
798}
799
Greg Clayton084db102011-06-23 04:25:29 +0000800addr_t
Sean Callanane0b23b52012-11-15 02:02:04 +0000801ClangExpressionDeclMap::GetSymbolAddress (Target &target, Process *process, const ConstString &name, lldb::SymbolType symbol_type)
Sean Callananc3a16002011-01-17 23:42:46 +0000802{
Sean Callananc3a16002011-01-17 23:42:46 +0000803 SymbolContextList sc_list;
804
Sean Callanan947ccc72011-12-01 02:04:16 +0000805 target.GetImages().FindSymbolsWithNameAndType(name, symbol_type, sc_list);
Sean Callananc3a16002011-01-17 23:42:46 +0000806
Greg Clayton084db102011-06-23 04:25:29 +0000807 const uint32_t num_matches = sc_list.GetSize();
808 addr_t symbol_load_addr = LLDB_INVALID_ADDRESS;
809
Sean Callanan947ccc72011-12-01 02:04:16 +0000810 for (uint32_t i=0; i<num_matches && (symbol_load_addr == 0 || symbol_load_addr == LLDB_INVALID_ADDRESS); i++)
Greg Clayton084db102011-06-23 04:25:29 +0000811 {
812 SymbolContext sym_ctx;
813 sc_list.GetContextAtIndex(i, sym_ctx);
Sean Callananc3a16002011-01-17 23:42:46 +0000814
Greg Claytone7612132012-03-07 21:03:09 +0000815 const Address *sym_address = &sym_ctx.symbol->GetAddress();
Sean Callananc6466fc2011-07-07 23:05:43 +0000816
817 if (!sym_address || !sym_address->IsValid())
818 return LLDB_INVALID_ADDRESS;
819
Greg Clayton084db102011-06-23 04:25:29 +0000820 if (sym_address)
821 {
822 switch (sym_ctx.symbol->GetType())
823 {
824 case eSymbolTypeCode:
825 case eSymbolTypeTrampoline:
826 symbol_load_addr = sym_address->GetCallableLoadAddress (&target);
827 break;
Matt Kopec00049b82013-02-27 20:13:38 +0000828
829 case eSymbolTypeResolver:
830 symbol_load_addr = sym_address->GetCallableLoadAddress (&target, true);
831 break;
832
Greg Clayton084db102011-06-23 04:25:29 +0000833 case eSymbolTypeData:
834 case eSymbolTypeRuntime:
835 case eSymbolTypeVariable:
836 case eSymbolTypeLocal:
837 case eSymbolTypeParam:
838 case eSymbolTypeInvalid:
839 case eSymbolTypeAbsolute:
Greg Clayton084db102011-06-23 04:25:29 +0000840 case eSymbolTypeException:
841 case eSymbolTypeSourceFile:
842 case eSymbolTypeHeaderFile:
843 case eSymbolTypeObjectFile:
844 case eSymbolTypeCommonBlock:
845 case eSymbolTypeBlock:
846 case eSymbolTypeVariableType:
847 case eSymbolTypeLineEntry:
848 case eSymbolTypeLineHeader:
849 case eSymbolTypeScopeBegin:
850 case eSymbolTypeScopeEnd:
851 case eSymbolTypeAdditional:
852 case eSymbolTypeCompiler:
853 case eSymbolTypeInstrumentation:
854 case eSymbolTypeUndefined:
Greg Clayton456809c2011-12-03 02:30:59 +0000855 case eSymbolTypeObjCClass:
856 case eSymbolTypeObjCMetaClass:
857 case eSymbolTypeObjCIVar:
Greg Clayton084db102011-06-23 04:25:29 +0000858 symbol_load_addr = sym_address->GetLoadAddress (&target);
859 break;
860 }
861 }
862 }
Sean Callananc3a16002011-01-17 23:42:46 +0000863
Sean Callanane0b23b52012-11-15 02:02:04 +0000864 if (symbol_load_addr == LLDB_INVALID_ADDRESS && process)
865 {
866 ObjCLanguageRuntime *runtime = process->GetObjCLanguageRuntime();
867
868 if (runtime)
869 {
870 symbol_load_addr = runtime->LookupRuntimeSymbol(name);
871 }
872 }
873
Greg Clayton084db102011-06-23 04:25:29 +0000874 return symbol_load_addr;
Sean Callananc3a16002011-01-17 23:42:46 +0000875}
876
Greg Clayton084db102011-06-23 04:25:29 +0000877addr_t
Sean Callanan947ccc72011-12-01 02:04:16 +0000878ClangExpressionDeclMap::GetSymbolAddress (const ConstString &name, lldb::SymbolType symbol_type)
Sean Callanand9ca42a2011-05-08 02:21:26 +0000879{
880 assert (m_parser_vars.get());
881
Sean Callanan933693b2012-02-10 01:22:05 +0000882 if (!m_parser_vars->m_exe_ctx.GetTargetPtr())
Sean Callanand9ca42a2011-05-08 02:21:26 +0000883 return false;
884
Sean Callanane0b23b52012-11-15 02:02:04 +0000885 return GetSymbolAddress(m_parser_vars->m_exe_ctx.GetTargetRef(), m_parser_vars->m_exe_ctx.GetProcessPtr(), name, symbol_type);
Sean Callanand9ca42a2011-05-08 02:21:26 +0000886}
887
Sean Callanan3bfdaa22011-09-15 02:13:07 +0000888// Interface for IRInterpreter
889
Sean Callanan80c48c12011-10-21 05:18:02 +0000890Value
891ClangExpressionDeclMap::WrapBareAddress (lldb::addr_t addr)
892{
893 Value ret;
894
895 ret.SetContext(Value::eContextTypeInvalid, NULL);
896
Sean Callanan933693b2012-02-10 01:22:05 +0000897 if (m_parser_vars->m_exe_ctx.GetProcessPtr())
Sean Callanan80c48c12011-10-21 05:18:02 +0000898 ret.SetValueType(Value::eValueTypeLoadAddress);
899 else
900 ret.SetValueType(Value::eValueTypeFileAddress);
901
902 ret.GetScalar() = (unsigned long long)addr;
903
904 return ret;
905}
906
Sean Callanan3bfdaa22011-09-15 02:13:07 +0000907bool
908ClangExpressionDeclMap::WriteTarget (lldb_private::Value &value,
909 const uint8_t *data,
910 size_t length)
911{
912 assert (m_parser_vars.get());
913
Sean Callanan933693b2012-02-10 01:22:05 +0000914 ExecutionContext &exe_ctx = m_parser_vars->m_exe_ctx;
Sean Callanan3bfdaa22011-09-15 02:13:07 +0000915
Sean Callanan933693b2012-02-10 01:22:05 +0000916 Process *process = exe_ctx.GetProcessPtr();
Sean Callanan3bfdaa22011-09-15 02:13:07 +0000917 if (value.GetContextType() == Value::eContextTypeRegisterInfo)
918 {
Greg Claytonc14ee322011-09-22 04:58:26 +0000919 if (!process)
Sean Callanan3bfdaa22011-09-15 02:13:07 +0000920 return false;
921
Sean Callanan933693b2012-02-10 01:22:05 +0000922 RegisterContext *reg_ctx = exe_ctx.GetRegisterContext();
Sean Callanan3bfdaa22011-09-15 02:13:07 +0000923 RegisterInfo *reg_info = value.GetRegisterInfo();
924
925 if (!reg_ctx)
926 return false;
927
928 lldb_private::RegisterValue reg_value;
929 Error err;
930
Greg Claytonc14ee322011-09-22 04:58:26 +0000931 if (!reg_value.SetFromMemoryData (reg_info, data, length, process->GetByteOrder(), err))
Sean Callanan3bfdaa22011-09-15 02:13:07 +0000932 return false;
933
934 return reg_ctx->WriteRegister(reg_info, reg_value);
935 }
936 else
937 {
938 switch (value.GetValueType())
939 {
940 default:
941 return false;
942 case Value::eValueTypeFileAddress:
943 {
Greg Claytonc14ee322011-09-22 04:58:26 +0000944 if (!process)
Sean Callanan3bfdaa22011-09-15 02:13:07 +0000945 return false;
946
Sean Callanan933693b2012-02-10 01:22:05 +0000947 Target *target = exe_ctx.GetTargetPtr();
Sean Callanan3bfdaa22011-09-15 02:13:07 +0000948 Address file_addr;
949
Greg Claytonc14ee322011-09-22 04:58:26 +0000950 if (!target->GetImages().ResolveFileAddress((lldb::addr_t)value.GetScalar().ULongLong(), file_addr))
Sean Callanan3bfdaa22011-09-15 02:13:07 +0000951 return false;
952
Greg Claytonc14ee322011-09-22 04:58:26 +0000953 lldb::addr_t load_addr = file_addr.GetLoadAddress(target);
Sean Callanan3bfdaa22011-09-15 02:13:07 +0000954
955 Error err;
Greg Claytonc14ee322011-09-22 04:58:26 +0000956 process->WriteMemory(load_addr, data, length, err);
Sean Callanan3bfdaa22011-09-15 02:13:07 +0000957
958 return err.Success();
959 }
960 case Value::eValueTypeLoadAddress:
961 {
Greg Claytonc14ee322011-09-22 04:58:26 +0000962 if (!process)
Sean Callanan3bfdaa22011-09-15 02:13:07 +0000963 return false;
964
965 Error err;
Greg Claytonc14ee322011-09-22 04:58:26 +0000966 process->WriteMemory((lldb::addr_t)value.GetScalar().ULongLong(), data, length, err);
Sean Callanan3bfdaa22011-09-15 02:13:07 +0000967
968 return err.Success();
969 }
970 case Value::eValueTypeHostAddress:
Sean Callanan0eed0d42011-12-06 03:41:14 +0000971 {
972 if (value.GetScalar().ULongLong() == 0 || data == NULL)
973 return false;
974 memcpy ((void *)value.GetScalar().ULongLong(), data, length);
975 return true;
976 }
Sean Callanan3bfdaa22011-09-15 02:13:07 +0000977 case Value::eValueTypeScalar:
978 return false;
979 }
980 }
981}
982
983bool
984ClangExpressionDeclMap::ReadTarget (uint8_t *data,
985 lldb_private::Value &value,
986 size_t length)
987{
988 assert (m_parser_vars.get());
989
Sean Callanan933693b2012-02-10 01:22:05 +0000990 ExecutionContext &exe_ctx = m_parser_vars->m_exe_ctx;
Greg Claytonc14ee322011-09-22 04:58:26 +0000991
Sean Callanan933693b2012-02-10 01:22:05 +0000992 Process *process = exe_ctx.GetProcessPtr();
Greg Claytonc14ee322011-09-22 04:58:26 +0000993
Sean Callanan3bfdaa22011-09-15 02:13:07 +0000994 if (value.GetContextType() == Value::eContextTypeRegisterInfo)
995 {
Greg Claytonc14ee322011-09-22 04:58:26 +0000996 if (!process)
Sean Callanan3bfdaa22011-09-15 02:13:07 +0000997 return false;
998
Sean Callanan933693b2012-02-10 01:22:05 +0000999 RegisterContext *reg_ctx = exe_ctx.GetRegisterContext();
Sean Callanan3bfdaa22011-09-15 02:13:07 +00001000 RegisterInfo *reg_info = value.GetRegisterInfo();
1001
1002 if (!reg_ctx)
1003 return false;
1004
1005 lldb_private::RegisterValue reg_value;
1006 Error err;
1007
1008 if (!reg_ctx->ReadRegister(reg_info, reg_value))
1009 return false;
1010
Greg Claytonc14ee322011-09-22 04:58:26 +00001011 return reg_value.GetAsMemoryData(reg_info, data, length, process->GetByteOrder(), err);
Sean Callanan3bfdaa22011-09-15 02:13:07 +00001012 }
1013 else
1014 {
1015 switch (value.GetValueType())
1016 {
1017 default:
1018 return false;
1019 case Value::eValueTypeFileAddress:
1020 {
Sean Callanan933693b2012-02-10 01:22:05 +00001021 Target *target = exe_ctx.GetTargetPtr();
Greg Claytonc14ee322011-09-22 04:58:26 +00001022 if (target == NULL)
Sean Callanan3bfdaa22011-09-15 02:13:07 +00001023 return false;
1024
1025 Address file_addr;
1026
Greg Claytonc14ee322011-09-22 04:58:26 +00001027 if (!target->GetImages().ResolveFileAddress((lldb::addr_t)value.GetScalar().ULongLong(), file_addr))
Sean Callanan3bfdaa22011-09-15 02:13:07 +00001028 return false;
1029
1030 Error err;
Sean Callanan80ef1242012-02-08 21:55:14 +00001031 target->ReadMemory(file_addr, false, data, length, err);
Sean Callanan3bfdaa22011-09-15 02:13:07 +00001032
1033 return err.Success();
1034 }
1035 case Value::eValueTypeLoadAddress:
1036 {
Greg Claytonc14ee322011-09-22 04:58:26 +00001037 if (!process)
Sean Callanan3bfdaa22011-09-15 02:13:07 +00001038 return false;
1039
1040 Error err;
Greg Claytonc14ee322011-09-22 04:58:26 +00001041 process->ReadMemory((lldb::addr_t)value.GetScalar().ULongLong(), data, length, err);
Sean Callanan3bfdaa22011-09-15 02:13:07 +00001042
1043 return err.Success();
1044 }
1045 case Value::eValueTypeHostAddress:
Sean Callanan00f43622011-11-18 03:28:09 +00001046 {
1047 void *host_addr = (void*)value.GetScalar().ULongLong();
1048
1049 if (!host_addr)
1050 return false;
1051
1052 memcpy (data, host_addr, length);
Sean Callanan3bfdaa22011-09-15 02:13:07 +00001053 return true;
Sean Callanan00f43622011-11-18 03:28:09 +00001054 }
Sean Callanan3bfdaa22011-09-15 02:13:07 +00001055 case Value::eValueTypeScalar:
1056 return false;
1057 }
1058 }
1059}
1060
1061lldb_private::Value
Sean Callananf673e762012-02-15 01:40:39 +00001062ClangExpressionDeclMap::LookupDecl (clang::NamedDecl *decl, ClangExpressionVariable::FlagType &flags)
Sean Callanan3bfdaa22011-09-15 02:13:07 +00001063{
1064 assert (m_parser_vars.get());
Sean Callanan933693b2012-02-10 01:22:05 +00001065
Sean Callanan3c495c12013-01-15 23:29:36 +00001066 ClangExpressionVariableSP expr_var_sp (m_found_entities.GetVariable(decl, GetParserID()));
1067 ClangExpressionVariableSP persistent_var_sp (m_parser_vars->m_persistent_vars->GetVariable(decl, GetParserID()));
Sean Callanan9c95fd22011-11-02 23:24:30 +00001068
Sean Callanan3bfdaa22011-09-15 02:13:07 +00001069 if (expr_var_sp)
1070 {
Sean Callananf673e762012-02-15 01:40:39 +00001071 flags = expr_var_sp->m_flags;
1072
Sean Callanan3c495c12013-01-15 23:29:36 +00001073 ClangExpressionVariable::ParserVars *parser_vars = expr_var_sp->GetParserVars(GetParserID());
1074
1075 if (!parser_vars)
Sean Callanane3aef1d2011-10-12 22:20:02 +00001076 return Value();
1077
Sean Callanan9c95fd22011-11-02 23:24:30 +00001078 bool is_reference = expr_var_sp->m_flags & ClangExpressionVariable::EVTypeIsReference;
Sean Callanan80ef1242012-02-08 21:55:14 +00001079
Sean Callanan3c495c12013-01-15 23:29:36 +00001080 if (parser_vars->m_lldb_var)
Sean Callanan9c95fd22011-11-02 23:24:30 +00001081 {
Sean Callanan3c495c12013-01-15 23:29:36 +00001082 std::auto_ptr<Value> value(GetVariableValue(parser_vars->m_lldb_var, NULL));
Sean Callanan9c95fd22011-11-02 23:24:30 +00001083
Sean Callanan80ef1242012-02-08 21:55:14 +00001084 if (is_reference && value.get() && value->GetValueType() == Value::eValueTypeLoadAddress)
1085 {
Sean Callanan933693b2012-02-10 01:22:05 +00001086 Process *process = m_parser_vars->m_exe_ctx.GetProcessPtr();
Sean Callanan80ef1242012-02-08 21:55:14 +00001087
1088 if (!process)
1089 return Value();
1090
1091 lldb::addr_t value_addr = value->GetScalar().ULongLong();
1092 Error read_error;
1093 addr_t ref_value = process->ReadPointerFromMemory (value_addr, read_error);
1094
1095 if (!read_error.Success())
1096 return Value();
1097
1098 value->GetScalar() = (unsigned long long)ref_value;
1099 }
Sean Callanan9c95fd22011-11-02 23:24:30 +00001100
Sean Callanan80ef1242012-02-08 21:55:14 +00001101 if (value.get())
1102 return *value;
1103 else
1104 return Value();
1105 }
Sean Callanan3c495c12013-01-15 23:29:36 +00001106 else if (parser_vars->m_lldb_sym)
Sean Callanan80ef1242012-02-08 21:55:14 +00001107 {
Sean Callanan3c495c12013-01-15 23:29:36 +00001108 const Address sym_address = parser_vars->m_lldb_sym->GetAddress();
Sean Callanan80ef1242012-02-08 21:55:14 +00001109
1110 if (!sym_address.IsValid())
1111 return Value();
1112
1113 Value ret;
1114
Sean Callanan378ecbe2012-02-28 17:55:31 +00001115 ProcessSP process_sp (m_parser_vars->m_exe_ctx.GetProcessSP());
1116
1117 if (process_sp)
1118 {
1119 uint64_t symbol_load_addr = sym_address.GetLoadAddress(&process_sp->GetTarget());
1120
1121 ret.GetScalar() = symbol_load_addr;
1122 ret.SetValueType(Value::eValueTypeLoadAddress);
1123 }
1124 else
1125 {
1126 uint64_t symbol_file_addr = sym_address.GetFileAddress();
1127
1128 ret.GetScalar() = symbol_file_addr;
1129 ret.SetValueType(Value::eValueTypeFileAddress);
1130 }
Sean Callanan80ef1242012-02-08 21:55:14 +00001131
1132 return ret;
1133 }
Sean Callananf673e762012-02-15 01:40:39 +00001134 else if (RegisterInfo *reg_info = expr_var_sp->GetRegisterInfo())
1135 {
1136 StackFrame *frame = m_parser_vars->m_exe_ctx.GetFramePtr();
1137
1138 if (!frame)
1139 return Value();
1140
1141 RegisterContextSP reg_context_sp(frame->GetRegisterContextSP());
1142
1143 RegisterValue reg_value;
1144
1145 if (!reg_context_sp->ReadRegister(reg_info, reg_value))
1146 return Value();
1147
1148 Value ret;
1149
1150 ret.SetContext(Value::eContextTypeRegisterInfo, reg_info);
Greg Clayton0665a0f2012-10-30 18:18:43 +00001151 if (reg_info->encoding == eEncodingVector)
1152 {
1153 if (ret.SetVectorBytes((uint8_t *)reg_value.GetBytes(), reg_value.GetByteSize(), reg_value.GetByteOrder()))
1154 ret.SetScalarFromVector();
1155 }
1156 else if (!reg_value.GetScalarValue(ret.GetScalar()))
1157 return Value();
Sean Callananf673e762012-02-15 01:40:39 +00001158
1159 return ret;
1160 }
Sean Callanand2cb6262011-10-26 21:20:00 +00001161 else
Sean Callanan80ef1242012-02-08 21:55:14 +00001162 {
Sean Callanand2cb6262011-10-26 21:20:00 +00001163 return Value();
Sean Callanan80ef1242012-02-08 21:55:14 +00001164 }
Sean Callanan3bfdaa22011-09-15 02:13:07 +00001165 }
1166 else if (persistent_var_sp)
1167 {
Sean Callananf673e762012-02-15 01:40:39 +00001168 flags = persistent_var_sp->m_flags;
1169
Sean Callanan0886e562011-09-22 00:41:11 +00001170 if ((persistent_var_sp->m_flags & ClangExpressionVariable::EVIsProgramReference ||
1171 persistent_var_sp->m_flags & ClangExpressionVariable::EVIsLLDBAllocated) &&
Sean Callanana76eadd2011-10-22 01:58:08 +00001172 persistent_var_sp->m_live_sp &&
Sean Callanan9b3569b2011-12-10 03:12:34 +00001173 ((persistent_var_sp->m_live_sp->GetValue().GetValueType() == Value::eValueTypeLoadAddress &&
Sean Callanan933693b2012-02-10 01:22:05 +00001174 m_parser_vars->m_exe_ctx.GetProcessSP() &&
1175 m_parser_vars->m_exe_ctx.GetProcessSP()->IsAlive()) ||
Sean Callanan9b3569b2011-12-10 03:12:34 +00001176 (persistent_var_sp->m_live_sp->GetValue().GetValueType() == Value::eValueTypeFileAddress)))
Sean Callanan0886e562011-09-22 00:41:11 +00001177 {
Sean Callanand2cb6262011-10-26 21:20:00 +00001178 return persistent_var_sp->m_live_sp->GetValue();
Sean Callanan0886e562011-09-22 00:41:11 +00001179 }
1180 else
1181 {
1182 lldb_private::Value ret;
1183 ret.SetValueType(Value::eValueTypeHostAddress);
1184 ret.SetContext(Value::eContextTypeInvalid, NULL);
1185 ret.GetScalar() = (lldb::addr_t)persistent_var_sp->GetValueBytes();
1186 return ret;
1187 }
Sean Callanan3bfdaa22011-09-15 02:13:07 +00001188 }
1189 else
1190 {
1191 return Value();
1192 }
1193}
1194
Sean Callanand2cb6262011-10-26 21:20:00 +00001195Value
1196ClangExpressionDeclMap::GetSpecialValue (const ConstString &name)
1197{
1198 assert(m_parser_vars.get());
1199
Sean Callanan933693b2012-02-10 01:22:05 +00001200 StackFrame *frame = m_parser_vars->m_exe_ctx.GetFramePtr();
Sean Callanand2cb6262011-10-26 21:20:00 +00001201
1202 if (!frame)
1203 return Value();
1204
1205 VariableList *vars = frame->GetVariableList(false);
1206
1207 if (!vars)
1208 return Value();
1209
1210 lldb::VariableSP var = vars->FindVariable(name);
1211
1212 if (!var ||
1213 !var->IsInScope(frame) ||
1214 !var->LocationIsValidForFrame (frame))
1215 return Value();
1216
Sean Callanan933693b2012-02-10 01:22:05 +00001217 std::auto_ptr<Value> value(GetVariableValue(var, NULL));
Sean Callanand2cb6262011-10-26 21:20:00 +00001218
Sean Callanan3dea5c72011-11-03 22:48:37 +00001219 if (value.get() && value->GetValueType() == Value::eValueTypeLoadAddress)
1220 {
Sean Callanan933693b2012-02-10 01:22:05 +00001221 Process *process = m_parser_vars->m_exe_ctx.GetProcessPtr();
Sean Callanan3dea5c72011-11-03 22:48:37 +00001222
1223 if (!process)
1224 return Value();
1225
1226 lldb::addr_t value_addr = value->GetScalar().ULongLong();
1227 Error read_error;
1228 addr_t ptr_value = process->ReadPointerFromMemory (value_addr, read_error);
1229
1230 if (!read_error.Success())
1231 return Value();
1232
1233 value->GetScalar() = (unsigned long long)ptr_value;
1234 }
1235
Sean Callanand2cb6262011-10-26 21:20:00 +00001236 if (value.get())
1237 return *value;
1238 else
1239 return Value();
1240}
1241
Sean Callananea22d422010-07-16 00:09:46 +00001242// Interface for CommandObjectExpression
Sean Callanan1d180662010-07-20 23:31:16 +00001243
1244bool
Greg Clayton7b462cc2010-10-15 22:48:33 +00001245ClangExpressionDeclMap::Materialize
1246(
Greg Clayton7b462cc2010-10-15 22:48:33 +00001247 lldb::addr_t &struct_address,
1248 Error &err
1249)
Sean Callanan1d180662010-07-20 23:31:16 +00001250{
Sean Callanan933693b2012-02-10 01:22:05 +00001251 if (!m_parser_vars.get())
1252 return false;
1253
Sean Callanan979f74d2010-12-03 01:38:59 +00001254 EnableMaterialVars();
1255
Sean Callanan933693b2012-02-10 01:22:05 +00001256 m_material_vars->m_process = m_parser_vars->m_exe_ctx.GetProcessPtr();
Sean Callanan979f74d2010-12-03 01:38:59 +00001257
Sean Callanane359d9b2011-05-09 22:04:36 +00001258 bool result = DoMaterialize(false /* dematerialize */,
Sean Callanane359d9b2011-05-09 22:04:36 +00001259 LLDB_INVALID_ADDRESS /* top of stack frame */,
1260 LLDB_INVALID_ADDRESS /* bottom of stack frame */,
1261 NULL, /* result SP */
1262 err);
Sean Callanan1d180662010-07-20 23:31:16 +00001263
1264 if (result)
Sean Callanan979f74d2010-12-03 01:38:59 +00001265 struct_address = m_material_vars->m_materialized_location;
Sean Callanan1d180662010-07-20 23:31:16 +00001266
1267 return result;
1268}
1269
1270bool
Greg Clayton7b462cc2010-10-15 22:48:33 +00001271ClangExpressionDeclMap::GetObjectPointer
1272(
1273 lldb::addr_t &object_ptr,
Sean Callanan17827832010-12-13 22:46:15 +00001274 ConstString &object_name,
Sean Callanan9d48e802010-12-14 00:42:36 +00001275 Error &err,
1276 bool suppress_type_check
Greg Clayton7b462cc2010-10-15 22:48:33 +00001277)
Sean Callananfc55f5d2010-09-21 00:44:12 +00001278{
Sean Callanan979f74d2010-12-03 01:38:59 +00001279 assert (m_struct_vars.get());
1280
Sean Callanan933693b2012-02-10 01:22:05 +00001281 Target *target = m_parser_vars->m_exe_ctx.GetTargetPtr();
1282 Process *process = m_parser_vars->m_exe_ctx.GetProcessPtr();
1283 StackFrame *frame = m_parser_vars->m_exe_ctx.GetFramePtr();
Greg Claytonc14ee322011-09-22 04:58:26 +00001284
1285 if (frame == NULL || process == NULL || target == NULL)
Sean Callananfc55f5d2010-09-21 00:44:12 +00001286 {
Sean Callanand5c17ed2011-11-15 02:11:17 +00001287 err.SetErrorStringWithFormat("Couldn't load '%s' because the context is incomplete", object_name.AsCString());
Sean Callananfc55f5d2010-09-21 00:44:12 +00001288 return false;
1289 }
1290
Sean Callanan979f74d2010-12-03 01:38:59 +00001291 if (!m_struct_vars->m_object_pointer_type.GetOpaqueQualType())
Sean Callananfc55f5d2010-09-21 00:44:12 +00001292 {
Sean Callanand5c17ed2011-11-15 02:11:17 +00001293 err.SetErrorStringWithFormat("Couldn't load '%s' because its type is unknown", object_name.AsCString());
Sean Callananfc55f5d2010-09-21 00:44:12 +00001294 return false;
1295 }
1296
Sean Callanan0259e512012-05-21 21:29:52 +00001297 const bool object_pointer = true;
Sean Callanan5056ab02012-02-18 02:01:03 +00001298
Greg Claytonc14ee322011-09-22 04:58:26 +00001299 VariableSP object_ptr_var = FindVariableInScope (*frame,
Sean Callanan63697e52011-05-07 01:06:41 +00001300 object_name,
Sean Callanan5056ab02012-02-18 02:01:03 +00001301 (suppress_type_check ? NULL : &m_struct_vars->m_object_pointer_type),
Sean Callanan0259e512012-05-21 21:29:52 +00001302 object_pointer);
Sean Callananfc55f5d2010-09-21 00:44:12 +00001303
1304 if (!object_ptr_var)
1305 {
Sean Callanand5c17ed2011-11-15 02:11:17 +00001306 err.SetErrorStringWithFormat("Couldn't find '%s' with appropriate type in scope", object_name.AsCString());
Sean Callananfc55f5d2010-09-21 00:44:12 +00001307 return false;
1308 }
1309
Sean Callanan933693b2012-02-10 01:22:05 +00001310 std::auto_ptr<lldb_private::Value> location_value(GetVariableValue(object_ptr_var,
Sean Callanan979f74d2010-12-03 01:38:59 +00001311 NULL));
Sean Callananfc55f5d2010-09-21 00:44:12 +00001312
1313 if (!location_value.get())
1314 {
Sean Callanan17827832010-12-13 22:46:15 +00001315 err.SetErrorStringWithFormat("Couldn't get the location for '%s'", object_name.GetCString());
Sean Callananfc55f5d2010-09-21 00:44:12 +00001316 return false;
1317 }
1318
Sean Callanan54366f12011-03-04 00:23:47 +00001319 switch (location_value->GetValueType())
Sean Callananfc55f5d2010-09-21 00:44:12 +00001320 {
Sean Callanan54366f12011-03-04 00:23:47 +00001321 default:
Sean Callanan17827832010-12-13 22:46:15 +00001322 err.SetErrorStringWithFormat("'%s' is not in memory; LLDB must be extended to handle registers", object_name.GetCString());
Sean Callananfc55f5d2010-09-21 00:44:12 +00001323 return false;
Sean Callanan54366f12011-03-04 00:23:47 +00001324 case Value::eValueTypeLoadAddress:
1325 {
1326 lldb::addr_t value_addr = location_value->GetScalar().ULongLong();
Greg Claytonc14ee322011-09-22 04:58:26 +00001327 uint32_t address_byte_size = target->GetArchitecture().GetAddressByteSize();
Sean Callanan54366f12011-03-04 00:23:47 +00001328
1329 if (ClangASTType::GetClangTypeBitWidth(m_struct_vars->m_object_pointer_type.GetASTContext(),
1330 m_struct_vars->m_object_pointer_type.GetOpaqueQualType()) != address_byte_size * 8)
1331 {
1332 err.SetErrorStringWithFormat("'%s' is not of an expected pointer size", object_name.GetCString());
1333 return false;
1334 }
1335
Sean Callanan54366f12011-03-04 00:23:47 +00001336 Error read_error;
Greg Claytonc14ee322011-09-22 04:58:26 +00001337 object_ptr = process->ReadPointerFromMemory (value_addr, read_error);
Greg Claytonf3ef3d22011-05-22 22:46:53 +00001338 if (read_error.Fail() || object_ptr == LLDB_INVALID_ADDRESS)
Sean Callanan54366f12011-03-04 00:23:47 +00001339 {
1340 err.SetErrorStringWithFormat("Coldn't read '%s' from the target: %s", object_name.GetCString(), read_error.AsCString());
1341 return false;
Greg Claytonf3ef3d22011-05-22 22:46:53 +00001342 }
Sean Callanan54366f12011-03-04 00:23:47 +00001343 return true;
1344 }
1345 case Value::eValueTypeScalar:
1346 {
1347 if (location_value->GetContextType() != Value::eContextTypeRegisterInfo)
1348 {
1349 StreamString ss;
1350 location_value->Dump(&ss);
1351
1352 err.SetErrorStringWithFormat("%s is a scalar of unhandled type: %s", object_name.GetCString(), ss.GetString().c_str());
1353 return false;
1354 }
1355
Greg Clayton7349bd92011-05-09 20:18:18 +00001356 RegisterInfo *reg_info = location_value->GetRegisterInfo();
Sean Callanan54366f12011-03-04 00:23:47 +00001357
Greg Clayton7349bd92011-05-09 20:18:18 +00001358 if (!reg_info)
Sean Callanan54366f12011-03-04 00:23:47 +00001359 {
1360 err.SetErrorStringWithFormat("Couldn't get the register information for %s", object_name.GetCString());
1361 return false;
1362 }
1363
Sean Callanan933693b2012-02-10 01:22:05 +00001364 RegisterContext *reg_ctx = m_parser_vars->m_exe_ctx.GetRegisterContext();
Sean Callanan54366f12011-03-04 00:23:47 +00001365
Greg Clayton7349bd92011-05-09 20:18:18 +00001366 if (!reg_ctx)
Sean Callanan54366f12011-03-04 00:23:47 +00001367 {
Greg Clayton7349bd92011-05-09 20:18:18 +00001368 err.SetErrorStringWithFormat("Couldn't read register context to read %s from %s", object_name.GetCString(), reg_info->name);
Sean Callanan54366f12011-03-04 00:23:47 +00001369 return false;
1370 }
1371
Greg Clayton7349bd92011-05-09 20:18:18 +00001372 uint32_t register_number = reg_info->kinds[lldb::eRegisterKindLLDB];
Sean Callanan54366f12011-03-04 00:23:47 +00001373
Greg Clayton7349bd92011-05-09 20:18:18 +00001374 object_ptr = reg_ctx->ReadRegisterAsUnsigned(register_number, 0x0);
Sean Callanan54366f12011-03-04 00:23:47 +00001375
1376 return true;
1377 }
Sean Callananfc55f5d2010-09-21 00:44:12 +00001378 }
1379}
1380
1381bool
Greg Clayton7b462cc2010-10-15 22:48:33 +00001382ClangExpressionDeclMap::Dematerialize
1383(
Greg Clayton8b2fe6d2010-12-14 02:59:59 +00001384 ClangExpressionVariableSP &result_sp,
Sean Callanane359d9b2011-05-09 22:04:36 +00001385 lldb::addr_t stack_frame_top,
1386 lldb::addr_t stack_frame_bottom,
Greg Clayton7b462cc2010-10-15 22:48:33 +00001387 Error &err
1388)
Sean Callanan1d180662010-07-20 23:31:16 +00001389{
Sean Callanan933693b2012-02-10 01:22:05 +00001390 return DoMaterialize(true, stack_frame_top, stack_frame_bottom, &result_sp, err);
Sean Callanan979f74d2010-12-03 01:38:59 +00001391
1392 DidDematerialize();
1393}
1394
1395void
1396ClangExpressionDeclMap::DidDematerialize()
1397{
1398 if (m_material_vars.get())
1399 {
1400 if (m_material_vars->m_materialized_location)
1401 {
1402 //#define SINGLE_STEP_EXPRESSIONS
1403
1404#ifndef SINGLE_STEP_EXPRESSIONS
1405 m_material_vars->m_process->DeallocateMemory(m_material_vars->m_materialized_location);
1406#endif
1407 m_material_vars->m_materialized_location = 0;
1408 }
1409
1410 DisableMaterialVars();
1411 }
Sean Callanan1d180662010-07-20 23:31:16 +00001412}
1413
Sean Callanan289e07b2010-07-23 22:19:18 +00001414bool
Greg Clayton7b462cc2010-10-15 22:48:33 +00001415ClangExpressionDeclMap::DumpMaterializedStruct
1416(
Greg Clayton7b462cc2010-10-15 22:48:33 +00001417 Stream &s,
1418 Error &err
1419)
Sean Callanan289e07b2010-07-23 22:19:18 +00001420{
Sean Callanan979f74d2010-12-03 01:38:59 +00001421 assert (m_struct_vars.get());
1422 assert (m_material_vars.get());
1423
1424 if (!m_struct_vars->m_struct_laid_out)
Sean Callanan289e07b2010-07-23 22:19:18 +00001425 {
1426 err.SetErrorString("Structure hasn't been laid out yet");
1427 return false;
1428 }
Sean Callanan933693b2012-02-10 01:22:05 +00001429 Process *process = m_parser_vars->m_exe_ctx.GetProcessPtr();
Greg Claytonc14ee322011-09-22 04:58:26 +00001430
1431 if (!process)
Sean Callanan289e07b2010-07-23 22:19:18 +00001432 {
1433 err.SetErrorString("Couldn't find the process");
1434 return false;
1435 }
1436
Sean Callanan933693b2012-02-10 01:22:05 +00001437 Target *target = m_parser_vars->m_exe_ctx.GetTargetPtr();
Greg Claytonc14ee322011-09-22 04:58:26 +00001438 if (!target)
Sean Callanan289e07b2010-07-23 22:19:18 +00001439 {
1440 err.SetErrorString("Couldn't find the target");
1441 return false;
1442 }
1443
Sean Callananc673a6e2010-12-07 10:00:20 +00001444 if (!m_material_vars->m_materialized_location)
1445 {
1446 err.SetErrorString("No materialized location");
1447 return false;
1448 }
1449
Greg Claytonf3ef3d22011-05-22 22:46:53 +00001450 lldb::DataBufferSP data_sp(new DataBufferHeap(m_struct_vars->m_struct_size, 0));
Sean Callanan289e07b2010-07-23 22:19:18 +00001451
1452 Error error;
Greg Claytonc14ee322011-09-22 04:58:26 +00001453 if (process->ReadMemory (m_material_vars->m_materialized_location,
Greg Claytonf3ef3d22011-05-22 22:46:53 +00001454 data_sp->GetBytes(),
1455 data_sp->GetByteSize(), error) != data_sp->GetByteSize())
Sean Callanan289e07b2010-07-23 22:19:18 +00001456 {
1457 err.SetErrorStringWithFormat ("Couldn't read struct from the target: %s", error.AsCString());
1458 return false;
1459 }
1460
Greg Claytonc14ee322011-09-22 04:58:26 +00001461 DataExtractor extractor(data_sp, process->GetByteOrder(), target->GetArchitecture().GetAddressByteSize());
Sean Callanan289e07b2010-07-23 22:19:18 +00001462
Greg Clayton8b2fe6d2010-12-14 02:59:59 +00001463 for (size_t member_idx = 0, num_members = m_struct_members.GetSize();
1464 member_idx < num_members;
1465 ++member_idx)
Sean Callanan289e07b2010-07-23 22:19:18 +00001466 {
Greg Clayton8b2fe6d2010-12-14 02:59:59 +00001467 ClangExpressionVariableSP member_sp(m_struct_members.GetVariableAtIndex(member_idx));
Sean Callanan289e07b2010-07-23 22:19:18 +00001468
Greg Clayton8b2fe6d2010-12-14 02:59:59 +00001469 if (!member_sp)
1470 return false;
1471
1472 s.Printf("[%s]\n", member_sp->GetName().GetCString());
Sean Callanan64dfc9a2010-08-23 23:09:38 +00001473
Sean Callanan3c495c12013-01-15 23:29:36 +00001474 ClangExpressionVariable::JITVars *jit_vars = member_sp->GetJITVars(GetParserID());
1475
1476 if (!jit_vars)
Sean Callanan64dfc9a2010-08-23 23:09:38 +00001477 return false;
1478
Greg Clayton8b2fe6d2010-12-14 02:59:59 +00001479 extractor.Dump (&s, // stream
Sean Callanan3c495c12013-01-15 23:29:36 +00001480 jit_vars->m_offset, // offset
Greg Clayton8b2fe6d2010-12-14 02:59:59 +00001481 lldb::eFormatBytesWithASCII, // format
1482 1, // byte size of individual entries
Sean Callanan3c495c12013-01-15 23:29:36 +00001483 jit_vars->m_size, // number of entries
Greg Clayton8b2fe6d2010-12-14 02:59:59 +00001484 16, // entries per line
Sean Callanan3c495c12013-01-15 23:29:36 +00001485 m_material_vars->m_materialized_location + jit_vars->m_offset, // address to print
Greg Clayton8b2fe6d2010-12-14 02:59:59 +00001486 0, // bit size (bitfields only; 0 means ignore)
1487 0); // bit alignment (bitfields only; 0 means ignore)
Sean Callanan289e07b2010-07-23 22:19:18 +00001488
1489 s.PutChar('\n');
1490 }
1491
1492 return true;
1493}
1494
Sean Callanan1d180662010-07-20 23:31:16 +00001495bool
Greg Clayton7b462cc2010-10-15 22:48:33 +00001496ClangExpressionDeclMap::DoMaterialize
1497(
1498 bool dematerialize,
Sean Callanane359d9b2011-05-09 22:04:36 +00001499 lldb::addr_t stack_frame_top,
1500 lldb::addr_t stack_frame_bottom,
Greg Clayton8b2fe6d2010-12-14 02:59:59 +00001501 lldb::ClangExpressionVariableSP *result_sp_ptr,
Greg Clayton7b462cc2010-10-15 22:48:33 +00001502 Error &err
1503)
Sean Callananea22d422010-07-16 00:09:46 +00001504{
Greg Clayton8b2fe6d2010-12-14 02:59:59 +00001505 if (result_sp_ptr)
1506 result_sp_ptr->reset();
1507
Sean Callanan979f74d2010-12-03 01:38:59 +00001508 assert (m_struct_vars.get());
1509
Greg Clayton2d4edfb2010-11-06 01:53:30 +00001510 lldb::LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_EXPRESSIONS));
Sean Callanand1e5b432010-08-12 01:56:52 +00001511
Sean Callanan979f74d2010-12-03 01:38:59 +00001512 if (!m_struct_vars->m_struct_laid_out)
Sean Callananea22d422010-07-16 00:09:46 +00001513 {
1514 err.SetErrorString("Structure hasn't been laid out yet");
Greg Claytoncce86712011-09-13 04:03:52 +00001515 return false;
Sean Callananea22d422010-07-16 00:09:46 +00001516 }
1517
Sean Callanan933693b2012-02-10 01:22:05 +00001518 StackFrame *frame = m_parser_vars->m_exe_ctx.GetFramePtr();
Greg Claytonc14ee322011-09-22 04:58:26 +00001519 if (!frame)
Sean Callananddb46ef2010-07-24 01:37:44 +00001520 {
1521 err.SetErrorString("Received null execution frame");
Greg Claytoncce86712011-09-13 04:03:52 +00001522 return false;
Sean Callananddb46ef2010-07-24 01:37:44 +00001523 }
Sean Callanan933693b2012-02-10 01:22:05 +00001524 Target *target = m_parser_vars->m_exe_ctx.GetTargetPtr();
Sean Callananddb46ef2010-07-24 01:37:44 +00001525
Greg Claytonc14ee322011-09-22 04:58:26 +00001526 ClangPersistentVariables &persistent_vars = target->GetPersistentVariables();
Sean Callanan979f74d2010-12-03 01:38:59 +00001527
1528 if (!m_struct_vars->m_struct_size)
Sean Callanan9e6ed532010-09-13 21:34:21 +00001529 {
1530 if (log)
1531 log->PutCString("Not bothering to allocate a struct because no arguments are needed");
1532
Filipe Cabecinhasd0b87d82012-09-11 18:11:16 +00001533 m_material_vars->m_allocated_area = 0UL;
Sean Callanan9e6ed532010-09-13 21:34:21 +00001534
1535 return true;
1536 }
1537
Greg Claytonc14ee322011-09-22 04:58:26 +00001538 const SymbolContext &sym_ctx(frame->GetSymbolContext(lldb::eSymbolContextEverything));
Sean Callananea22d422010-07-16 00:09:46 +00001539
Sean Callanan1d180662010-07-20 23:31:16 +00001540 if (!dematerialize)
Sean Callananea22d422010-07-16 00:09:46 +00001541 {
Sean Callanan933693b2012-02-10 01:22:05 +00001542 Process *process = m_parser_vars->m_exe_ctx.GetProcessPtr();
Sean Callanan979f74d2010-12-03 01:38:59 +00001543 if (m_material_vars->m_materialized_location)
Sean Callanan1d180662010-07-20 23:31:16 +00001544 {
Greg Claytonc14ee322011-09-22 04:58:26 +00001545 process->DeallocateMemory(m_material_vars->m_materialized_location);
Sean Callanan979f74d2010-12-03 01:38:59 +00001546 m_material_vars->m_materialized_location = 0;
Sean Callanan1d180662010-07-20 23:31:16 +00001547 }
1548
Sean Callanan6b1b9532010-10-08 01:58:41 +00001549 if (log)
1550 log->PutCString("Allocating memory for materialized argument struct");
1551
Greg Claytonc14ee322011-09-22 04:58:26 +00001552 lldb::addr_t mem = process->AllocateMemory(m_struct_vars->m_struct_alignment + m_struct_vars->m_struct_size,
Sean Callanan00f43622011-11-18 03:28:09 +00001553 lldb::ePermissionsReadable | lldb::ePermissionsWritable,
1554 err);
Sean Callanan1d180662010-07-20 23:31:16 +00001555
1556 if (mem == LLDB_INVALID_ADDRESS)
Sean Callanan00f43622011-11-18 03:28:09 +00001557 {
Daniel Malead01b2952012-11-29 21:49:15 +00001558 err.SetErrorStringWithFormat("Couldn't allocate 0x%llx bytes for materialized argument struct",
Sean Callanan00f43622011-11-18 03:28:09 +00001559 (unsigned long long)(m_struct_vars->m_struct_alignment + m_struct_vars->m_struct_size));
Sean Callanan1d180662010-07-20 23:31:16 +00001560 return false;
Sean Callanan00f43622011-11-18 03:28:09 +00001561 }
1562
Sean Callanan979f74d2010-12-03 01:38:59 +00001563 m_material_vars->m_allocated_area = mem;
Sean Callananea22d422010-07-16 00:09:46 +00001564 }
1565
Sean Callanan979f74d2010-12-03 01:38:59 +00001566 m_material_vars->m_materialized_location = m_material_vars->m_allocated_area;
Sean Callanan1d180662010-07-20 23:31:16 +00001567
Sean Callanan979f74d2010-12-03 01:38:59 +00001568 if (m_material_vars->m_materialized_location % m_struct_vars->m_struct_alignment)
1569 m_material_vars->m_materialized_location += (m_struct_vars->m_struct_alignment - (m_material_vars->m_materialized_location % m_struct_vars->m_struct_alignment));
Sean Callanan1d180662010-07-20 23:31:16 +00001570
Greg Clayton8b2fe6d2010-12-14 02:59:59 +00001571 for (uint64_t member_index = 0, num_members = m_struct_members.GetSize();
Sean Callanan64dfc9a2010-08-23 23:09:38 +00001572 member_index < num_members;
1573 ++member_index)
Sean Callananea22d422010-07-16 00:09:46 +00001574 {
Greg Clayton8b2fe6d2010-12-14 02:59:59 +00001575 ClangExpressionVariableSP member_sp(m_struct_members.GetVariableAtIndex(member_index));
Sean Callananea22d422010-07-16 00:09:46 +00001576
Sean Callanan3c495c12013-01-15 23:29:36 +00001577 ClangExpressionVariable::JITVars *jit_vars = member_sp->GetJITVars(GetParserID());
1578
1579 if (!jit_vars)
1580 {
1581 err.SetErrorString("Variable being materialized doesn't have JIT state");
1582 return false;
1583 }
1584
Greg Clayton3e06bd92011-01-09 21:07:35 +00001585 if (m_found_entities.ContainsVariable (member_sp))
Sean Callanan64dfc9a2010-08-23 23:09:38 +00001586 {
Sean Callananaa01b832012-08-16 21:34:44 +00001587 if (!member_sp->GetValueObject())
1588 {
1589 err.SetErrorString("Variable being materialized doesn't have a frozen version");
1590 return false;
1591 }
1592
Greg Clayton3e06bd92011-01-09 21:07:35 +00001593 RegisterInfo *reg_info = member_sp->GetRegisterInfo ();
Greg Clayton8b2fe6d2010-12-14 02:59:59 +00001594 if (reg_info)
Sean Callanan348b5892010-11-30 00:27:43 +00001595 {
1596 // This is a register variable
1597
Sean Callanan933693b2012-02-10 01:22:05 +00001598 RegisterContext *reg_ctx = m_parser_vars->m_exe_ctx.GetRegisterContext();
Sean Callanan348b5892010-11-30 00:27:43 +00001599
1600 if (!reg_ctx)
Sean Callanan00f43622011-11-18 03:28:09 +00001601 {
1602 err.SetErrorString("Couldn't get register context");
Sean Callanan348b5892010-11-30 00:27:43 +00001603 return false;
Sean Callanan00f43622011-11-18 03:28:09 +00001604 }
1605
Greg Clayton8b2fe6d2010-12-14 02:59:59 +00001606 if (!DoMaterializeOneRegister (dematerialize,
Greg Clayton8b2fe6d2010-12-14 02:59:59 +00001607 *reg_ctx,
1608 *reg_info,
Sean Callanan3c495c12013-01-15 23:29:36 +00001609 m_material_vars->m_materialized_location + jit_vars->m_offset,
Greg Clayton8b2fe6d2010-12-14 02:59:59 +00001610 err))
Sean Callanan348b5892010-11-30 00:27:43 +00001611 return false;
1612 }
1613 else
Sean Callanan3c495c12013-01-15 23:29:36 +00001614 {
Greg Clayton8b2fe6d2010-12-14 02:59:59 +00001615 if (!DoMaterializeOneVariable (dematerialize,
Sean Callanan92adcac2011-01-13 08:53:35 +00001616 sym_ctx,
1617 member_sp,
Sean Callanan3c495c12013-01-15 23:29:36 +00001618 m_material_vars->m_materialized_location + jit_vars->m_offset,
Greg Clayton8b2fe6d2010-12-14 02:59:59 +00001619 err))
Sean Callanan348b5892010-11-30 00:27:43 +00001620 return false;
1621 }
Sean Callanan64dfc9a2010-08-23 23:09:38 +00001622 }
Sean Callanan64dfc9a2010-08-23 23:09:38 +00001623 else
1624 {
Greg Clayton3e06bd92011-01-09 21:07:35 +00001625 // No need to look for presistent variables if the name doesn't start
1626 // with with a '$' character...
1627 if (member_sp->GetName().AsCString ("!")[0] == '$' && persistent_vars.ContainsVariable(member_sp))
1628 {
Sean Callanan92adcac2011-01-13 08:53:35 +00001629
Greg Clayton3e06bd92011-01-09 21:07:35 +00001630 if (member_sp->GetName() == m_struct_vars->m_result_name)
1631 {
Greg Clayton3e06bd92011-01-09 21:07:35 +00001632 if (log)
1633 log->PutCString("Found result member in the struct");
Sean Callanan92adcac2011-01-13 08:53:35 +00001634
Greg Clayton3e06bd92011-01-09 21:07:35 +00001635 if (result_sp_ptr)
1636 *result_sp_ptr = member_sp;
Sean Callanan92adcac2011-01-13 08:53:35 +00001637
Greg Clayton3e06bd92011-01-09 21:07:35 +00001638 }
1639
1640 if (!DoMaterializeOnePersistentVariable (dematerialize,
Greg Clayton3e06bd92011-01-09 21:07:35 +00001641 member_sp,
Sean Callanan3c495c12013-01-15 23:29:36 +00001642 m_material_vars->m_materialized_location + jit_vars->m_offset,
Sean Callanane359d9b2011-05-09 22:04:36 +00001643 stack_frame_top,
1644 stack_frame_bottom,
Greg Clayton3e06bd92011-01-09 21:07:35 +00001645 err))
1646 return false;
1647 }
1648 else
1649 {
1650 err.SetErrorStringWithFormat("Unexpected variable %s", member_sp->GetName().GetCString());
1651 return false;
1652 }
Sean Callanan64dfc9a2010-08-23 23:09:38 +00001653 }
Sean Callananea22d422010-07-16 00:09:46 +00001654 }
1655
Sean Callanan1d180662010-07-20 23:31:16 +00001656 return true;
1657}
1658
Sean Callanan2235f322010-08-11 03:57:18 +00001659bool
Greg Clayton7b462cc2010-10-15 22:48:33 +00001660ClangExpressionDeclMap::DoMaterializeOnePersistentVariable
1661(
1662 bool dematerialize,
Greg Clayton8b2fe6d2010-12-14 02:59:59 +00001663 ClangExpressionVariableSP &var_sp,
Greg Clayton7b462cc2010-10-15 22:48:33 +00001664 lldb::addr_t addr,
Sean Callanane359d9b2011-05-09 22:04:36 +00001665 lldb::addr_t stack_frame_top,
1666 lldb::addr_t stack_frame_bottom,
Greg Clayton7b462cc2010-10-15 22:48:33 +00001667 Error &err
1668)
Sean Callanan979f74d2010-12-03 01:38:59 +00001669{
Sean Callanan92adcac2011-01-13 08:53:35 +00001670 lldb::LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_EXPRESSIONS));
1671
Greg Clayton8b2fe6d2010-12-14 02:59:59 +00001672 if (!var_sp)
Sean Callanan2235f322010-08-11 03:57:18 +00001673 {
Greg Clayton8b2fe6d2010-12-14 02:59:59 +00001674 err.SetErrorString("Invalid persistent variable");
Sean Callanan2235f322010-08-11 03:57:18 +00001675 return LLDB_INVALID_ADDRESS;
1676 }
1677
Greg Clayton8b2fe6d2010-12-14 02:59:59 +00001678 const size_t pvar_byte_size = var_sp->GetByteSize();
Sean Callanand0ef0ef2010-08-20 01:02:30 +00001679
Greg Clayton8b2fe6d2010-12-14 02:59:59 +00001680 uint8_t *pvar_data = var_sp->GetValueBytes();
1681 if (pvar_data == NULL)
Sean Callanan00f43622011-11-18 03:28:09 +00001682 {
1683 err.SetErrorString("Persistent variable being materialized contains no data");
Sean Callanand0ef0ef2010-08-20 01:02:30 +00001684 return false;
Sean Callanan00f43622011-11-18 03:28:09 +00001685 }
Sean Callanand0ef0ef2010-08-20 01:02:30 +00001686
Sean Callanan2235f322010-08-11 03:57:18 +00001687 Error error;
Sean Callanan933693b2012-02-10 01:22:05 +00001688 Process *process = m_parser_vars->m_exe_ctx.GetProcessPtr();
Greg Claytonc14ee322011-09-22 04:58:26 +00001689
Sean Callanan92adcac2011-01-13 08:53:35 +00001690 lldb::addr_t mem; // The address of a spare memory area used to hold the persistent variable.
1691
Sean Callanan2235f322010-08-11 03:57:18 +00001692 if (dematerialize)
1693 {
Sean Callanan92adcac2011-01-13 08:53:35 +00001694 if (log)
1695 log->Printf("Dematerializing persistent variable with flags 0x%hx", var_sp->m_flags);
1696
1697 if ((var_sp->m_flags & ClangExpressionVariable::EVIsLLDBAllocated) ||
1698 (var_sp->m_flags & ClangExpressionVariable::EVIsProgramReference))
Sean Callanan2235f322010-08-11 03:57:18 +00001699 {
Sean Callanan92adcac2011-01-13 08:53:35 +00001700 // Get the location of the target out of the struct.
1701
1702 Error read_error;
Greg Claytonc14ee322011-09-22 04:58:26 +00001703 mem = process->ReadPointerFromMemory (addr, read_error);
Sean Callanan92adcac2011-01-13 08:53:35 +00001704
1705 if (mem == LLDB_INVALID_ADDRESS)
1706 {
1707 err.SetErrorStringWithFormat("Couldn't read address of %s from struct: %s", var_sp->GetName().GetCString(), error.AsCString());
1708 return false;
1709 }
1710
1711 if (var_sp->m_flags & ClangExpressionVariable::EVIsProgramReference &&
1712 !var_sp->m_live_sp)
1713 {
1714 // If the reference comes from the program, then the ClangExpressionVariable's
1715 // live variable data hasn't been set up yet. Do this now.
1716
Sean Callanan933693b2012-02-10 01:22:05 +00001717 var_sp->m_live_sp = ValueObjectConstResult::Create (m_parser_vars->m_exe_ctx.GetBestExecutionContextScope (),
Jim Ingham58b59f92011-04-22 23:53:53 +00001718 var_sp->GetTypeFromUser().GetASTContext(),
1719 var_sp->GetTypeFromUser().GetOpaqueQualType(),
1720 var_sp->GetName(),
1721 mem,
1722 eAddressTypeLoad,
1723 pvar_byte_size);
Sean Callanan92adcac2011-01-13 08:53:35 +00001724 }
1725
1726 if (!var_sp->m_live_sp)
1727 {
1728 err.SetErrorStringWithFormat("Couldn't find the memory area used to store %s", var_sp->GetName().GetCString());
1729 return false;
1730 }
1731
Greg Claytone0d378b2011-03-24 21:19:54 +00001732 if (var_sp->m_live_sp->GetValue().GetValueAddressType() != eAddressTypeLoad)
Sean Callanan92adcac2011-01-13 08:53:35 +00001733 {
1734 err.SetErrorStringWithFormat("The address of the memory area for %s is in an incorrect format", var_sp->GetName().GetCString());
1735 return false;
1736 }
1737
Sean Callanane1175b72011-01-13 21:23:32 +00001738 if (var_sp->m_flags & ClangExpressionVariable::EVNeedsFreezeDry ||
1739 var_sp->m_flags & ClangExpressionVariable::EVKeepInTarget)
Sean Callanan92adcac2011-01-13 08:53:35 +00001740 {
1741 mem = var_sp->m_live_sp->GetValue().GetScalar().ULongLong();
1742
1743 if (log)
Daniel Malead01b2952012-11-29 21:49:15 +00001744 log->Printf("Dematerializing %s from 0x%" PRIx64 " (size = %u)", var_sp->GetName().GetCString(), (uint64_t)mem, (unsigned)pvar_byte_size);
Sean Callanan92adcac2011-01-13 08:53:35 +00001745
1746 // Read the contents of the spare memory area
Sean Callanane359d9b2011-05-09 22:04:36 +00001747
Sean Callanan92adcac2011-01-13 08:53:35 +00001748 var_sp->ValueUpdated ();
Greg Claytonc14ee322011-09-22 04:58:26 +00001749 if (process->ReadMemory (mem, pvar_data, pvar_byte_size, error) != pvar_byte_size)
Sean Callanan92adcac2011-01-13 08:53:35 +00001750 {
1751 err.SetErrorStringWithFormat ("Couldn't read a composite type from the target: %s", error.AsCString());
1752 return false;
1753 }
1754
Sean Callanane359d9b2011-05-09 22:04:36 +00001755 if (stack_frame_top != LLDB_INVALID_ADDRESS &&
1756 stack_frame_bottom != LLDB_INVALID_ADDRESS &&
1757 mem >= stack_frame_bottom &&
1758 mem <= stack_frame_top)
1759 {
1760 // If the variable is resident in the stack frame created by the expression,
1761 // then it cannot be relied upon to stay around. We treat it as needing
1762 // reallocation.
1763
1764 var_sp->m_flags |= ClangExpressionVariable::EVIsLLDBAllocated;
1765 var_sp->m_flags |= ClangExpressionVariable::EVNeedsAllocation;
1766 var_sp->m_flags &= ~ClangExpressionVariable::EVIsProgramReference;
1767 }
1768
Sean Callanan92adcac2011-01-13 08:53:35 +00001769 var_sp->m_flags &= ~ClangExpressionVariable::EVNeedsFreezeDry;
1770 }
1771
1772 if (var_sp->m_flags & ClangExpressionVariable::EVNeedsAllocation &&
1773 !(var_sp->m_flags & ClangExpressionVariable::EVKeepInTarget))
1774 {
1775 if (m_keep_result_in_memory)
1776 {
1777 var_sp->m_flags |= ClangExpressionVariable::EVKeepInTarget;
1778 }
1779 else
1780 {
Greg Claytonc14ee322011-09-22 04:58:26 +00001781 Error deallocate_error = process->DeallocateMemory(mem);
Sean Callanan92adcac2011-01-13 08:53:35 +00001782
1783 if (!err.Success())
1784 {
1785 err.SetErrorStringWithFormat ("Couldn't deallocate memory for %s: %s", var_sp->GetName().GetCString(), deallocate_error.AsCString());
1786 return false;
1787 }
1788 }
1789 }
1790 }
1791 else
1792 {
1793 err.SetErrorStringWithFormat("Persistent variables without separate allocations are not currently supported.");
Sean Callanan2235f322010-08-11 03:57:18 +00001794 return false;
1795 }
1796 }
1797 else
1798 {
Sean Callanan92adcac2011-01-13 08:53:35 +00001799 if (log)
1800 log->Printf("Materializing persistent variable with flags 0x%hx", var_sp->m_flags);
1801
1802 if (var_sp->m_flags & ClangExpressionVariable::EVNeedsAllocation)
Sean Callanan2235f322010-08-11 03:57:18 +00001803 {
Sean Callanan92adcac2011-01-13 08:53:35 +00001804 // Allocate a spare memory area to store the persistent variable's contents.
1805
1806 Error allocate_error;
1807
Greg Claytonc14ee322011-09-22 04:58:26 +00001808 mem = process->AllocateMemory(pvar_byte_size,
Sean Callanand2cb6262011-10-26 21:20:00 +00001809 lldb::ePermissionsReadable | lldb::ePermissionsWritable,
1810 allocate_error);
Sean Callanan92adcac2011-01-13 08:53:35 +00001811
1812 if (mem == LLDB_INVALID_ADDRESS)
1813 {
1814 err.SetErrorStringWithFormat("Couldn't allocate a memory area to store %s: %s", var_sp->GetName().GetCString(), allocate_error.AsCString());
1815 return false;
1816 }
1817
1818 if (log)
Daniel Malead01b2952012-11-29 21:49:15 +00001819 log->Printf("Allocated %s (0x%" PRIx64 ") sucessfully", var_sp->GetName().GetCString(), mem);
Sean Callanan92adcac2011-01-13 08:53:35 +00001820
1821 // Put the location of the spare memory into the live data of the ValueObject.
1822
Sean Callanan933693b2012-02-10 01:22:05 +00001823 var_sp->m_live_sp = ValueObjectConstResult::Create (m_parser_vars->m_exe_ctx.GetBestExecutionContextScope(),
Jim Ingham58b59f92011-04-22 23:53:53 +00001824 var_sp->GetTypeFromUser().GetASTContext(),
1825 var_sp->GetTypeFromUser().GetOpaqueQualType(),
1826 var_sp->GetName(),
1827 mem,
1828 eAddressTypeLoad,
1829 pvar_byte_size);
Sean Callanan92adcac2011-01-13 08:53:35 +00001830
1831 // Clear the flag if the variable will never be deallocated.
1832
1833 if (var_sp->m_flags & ClangExpressionVariable::EVKeepInTarget)
1834 var_sp->m_flags &= ~ClangExpressionVariable::EVNeedsAllocation;
1835
1836 // Write the contents of the variable to the area.
1837
Greg Claytonc14ee322011-09-22 04:58:26 +00001838 if (process->WriteMemory (mem, pvar_data, pvar_byte_size, error) != pvar_byte_size)
Sean Callanan92adcac2011-01-13 08:53:35 +00001839 {
1840 err.SetErrorStringWithFormat ("Couldn't write a composite type to the target: %s", error.AsCString());
1841 return false;
1842 }
1843 }
1844
1845 if ((var_sp->m_flags & ClangExpressionVariable::EVIsProgramReference && var_sp->m_live_sp) ||
1846 var_sp->m_flags & ClangExpressionVariable::EVIsLLDBAllocated)
1847 {
Sean Callanan92adcac2011-01-13 08:53:35 +00001848 // Now write the location of the area into the struct.
Sean Callanan92adcac2011-01-13 08:53:35 +00001849 Error write_error;
Greg Claytonc14ee322011-09-22 04:58:26 +00001850 if (!process->WriteScalarToMemory (addr,
Sean Callanand2cb6262011-10-26 21:20:00 +00001851 var_sp->m_live_sp->GetValue().GetScalar(),
1852 process->GetAddressByteSize(),
1853 write_error))
Sean Callanan92adcac2011-01-13 08:53:35 +00001854 {
1855 err.SetErrorStringWithFormat ("Couldn't write %s to the target: %s", var_sp->GetName().GetCString(), write_error.AsCString());
1856 return false;
1857 }
1858
1859 if (log)
Greg Claytonf3ef3d22011-05-22 22:46:53 +00001860 log->Printf("Materialized %s into 0x%llx", var_sp->GetName().GetCString(), var_sp->m_live_sp->GetValue().GetScalar().ULongLong());
Sean Callanan92adcac2011-01-13 08:53:35 +00001861 }
Sean Callanan63697e52011-05-07 01:06:41 +00001862 else if (!(var_sp->m_flags & ClangExpressionVariable::EVIsProgramReference))
Sean Callanan92adcac2011-01-13 08:53:35 +00001863 {
1864 err.SetErrorStringWithFormat("Persistent variables without separate allocations are not currently supported.");
Sean Callanan2235f322010-08-11 03:57:18 +00001865 return false;
1866 }
1867 }
1868
1869 return true;
1870}
1871
Sean Callanan7b5805d2013-01-18 21:20:51 +00001872bool
1873ClangExpressionDeclMap::CreateLiveMemoryForExpressionVariable
1874(
1875 Process &process,
1876 ClangExpressionVariableSP &expr_var,
1877 Error &err
1878)
1879{
1880 Error allocate_error;
1881 TypeFromUser type(expr_var->GetTypeFromUser());
1882 const ConstString &name(expr_var->GetName());
1883
1884 size_t value_bit_size = ClangASTType::GetClangTypeBitWidth(type.GetASTContext(), type.GetOpaqueQualType());
1885 size_t value_byte_size = value_bit_size % 8 ? ((value_bit_size + 8) / 8) : (value_bit_size / 8);
1886
1887 Scalar val_addr (process.AllocateMemory (value_byte_size,
1888 lldb::ePermissionsReadable | lldb::ePermissionsWritable,
1889 allocate_error));
1890
1891 if (val_addr.ULongLong() == LLDB_INVALID_ADDRESS)
1892 {
1893 err.SetErrorStringWithFormat ("Couldn't allocate a memory area to store %s: %s",
1894 name.GetCString(),
1895 allocate_error.AsCString());
1896 return false;
1897 }
1898
1899 // Put the location of the spare memory into the live data of the ValueObject.
1900
1901 expr_var->m_live_sp = ValueObjectConstResult::Create (m_parser_vars->m_exe_ctx.GetBestExecutionContextScope(),
1902 type.GetASTContext(),
1903 type.GetOpaqueQualType(),
1904 name,
1905 val_addr.ULongLong(),
1906 eAddressTypeLoad,
1907 value_byte_size);
1908
1909 return true;
1910}
1911
1912bool
1913ClangExpressionDeclMap::DeleteLiveMemoryForExpressionVariable
1914(
1915 Process &process,
1916 ClangExpressionVariableSP &expr_var,
1917 Error &err
1918)
1919{
1920 const ConstString &name(expr_var->GetName());
1921
1922 Scalar &val_addr = expr_var->m_live_sp->GetValue().GetScalar();
1923
1924 Error deallocate_error = process.DeallocateMemory(val_addr.ULongLong());
1925
1926 if (!deallocate_error.Success())
1927 {
1928 err.SetErrorStringWithFormat ("Couldn't deallocate spare memory area for %s: %s",
1929 name.GetCString(),
1930 deallocate_error.AsCString());
1931 return false;
1932 }
1933
1934 expr_var->m_live_sp.reset();
1935
1936 return true;
1937}
1938
1939bool
Greg Clayton7b462cc2010-10-15 22:48:33 +00001940ClangExpressionDeclMap::DoMaterializeOneVariable
1941(
1942 bool dematerialize,
Greg Clayton7b462cc2010-10-15 22:48:33 +00001943 const SymbolContext &sym_ctx,
Sean Callanan92adcac2011-01-13 08:53:35 +00001944 ClangExpressionVariableSP &expr_var,
Sean Callanan7b5805d2013-01-18 21:20:51 +00001945 lldb::addr_t addr,
Greg Clayton7b462cc2010-10-15 22:48:33 +00001946 Error &err
1947)
Sean Callanan1d180662010-07-20 23:31:16 +00001948{
Greg Clayton2d4edfb2010-11-06 01:53:30 +00001949 lldb::LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_EXPRESSIONS));
Sean Callanan933693b2012-02-10 01:22:05 +00001950 Target *target = m_parser_vars->m_exe_ctx.GetTargetPtr();
1951 Process *process = m_parser_vars->m_exe_ctx.GetProcessPtr();
1952 StackFrame *frame = m_parser_vars->m_exe_ctx.GetFramePtr();
Sean Callanan3c495c12013-01-15 23:29:36 +00001953
1954 ClangExpressionVariable::ParserVars *var_parser_vars = expr_var->GetParserVars(GetParserID());
Greg Claytonc14ee322011-09-22 04:58:26 +00001955
Sean Callanan3c495c12013-01-15 23:29:36 +00001956 if (!frame || !process || !target || !m_parser_vars.get() || !var_parser_vars)
Sean Callanan00f43622011-11-18 03:28:09 +00001957 {
1958 err.SetErrorString("Necessary state for variable materialization isn't present");
Sean Callanan44096b12010-09-14 21:59:34 +00001959 return false;
Sean Callanan00f43622011-11-18 03:28:09 +00001960 }
Sean Callanan44096b12010-09-14 21:59:34 +00001961
Sean Callanan92adcac2011-01-13 08:53:35 +00001962 // Vital information about the value
1963
1964 const ConstString &name(expr_var->GetName());
1965 TypeFromUser type(expr_var->GetTypeFromUser());
1966
Sean Callanan3c495c12013-01-15 23:29:36 +00001967 VariableSP &var(var_parser_vars->m_lldb_var);
1968 const lldb_private::Symbol *symbol = var_parser_vars->m_lldb_sym;
Sean Callanan1d180662010-07-20 23:31:16 +00001969
Sean Callanan98298012011-10-27 19:41:13 +00001970 bool is_reference(expr_var->m_flags & ClangExpressionVariable::EVTypeIsReference);
1971
Sean Callanand9ca42a2011-05-08 02:21:26 +00001972 std::auto_ptr<lldb_private::Value> location_value;
Sean Callanan8e5b8b92011-10-13 00:09:20 +00001973
Sean Callanand9ca42a2011-05-08 02:21:26 +00001974 if (var)
1975 {
Sean Callanan933693b2012-02-10 01:22:05 +00001976 location_value.reset(GetVariableValue(var,
Sean Callanand9ca42a2011-05-08 02:21:26 +00001977 NULL));
1978 }
Greg Clayton3d51b9f2012-11-27 01:52:16 +00001979 else if (symbol)
Sean Callanan8e5b8b92011-10-13 00:09:20 +00001980 {
Sean Callanane0b23b52012-11-15 02:02:04 +00001981 addr_t location_load_addr = GetSymbolAddress(*target, process, name, lldb::eSymbolTypeAny);
Sean Callanand9ca42a2011-05-08 02:21:26 +00001982
Greg Clayton084db102011-06-23 04:25:29 +00001983 if (location_load_addr == LLDB_INVALID_ADDRESS)
Sean Callanand9ca42a2011-05-08 02:21:26 +00001984 {
1985 if (log)
Greg Claytonf3ef3d22011-05-22 22:46:53 +00001986 err.SetErrorStringWithFormat ("Couldn't find value for global symbol %s",
1987 name.GetCString());
Sean Callanand9ca42a2011-05-08 02:21:26 +00001988 }
1989
Sean Callanan8e5b8b92011-10-13 00:09:20 +00001990 location_value.reset(new Value);
1991
Sean Callanand9ca42a2011-05-08 02:21:26 +00001992 location_value->SetValueType(Value::eValueTypeLoadAddress);
1993 location_value->GetScalar() = location_load_addr;
1994 }
1995 else
Sean Callanan1d180662010-07-20 23:31:16 +00001996 {
Greg Claytonf3ef3d22011-05-22 22:46:53 +00001997 err.SetErrorStringWithFormat ("Couldn't find %s with appropriate type",
1998 name.GetCString());
Sean Callanan1d180662010-07-20 23:31:16 +00001999 return false;
2000 }
2001
Sean Callananebf77072010-07-23 00:16:21 +00002002 if (log)
Sean Callanan77502262011-05-12 23:54:16 +00002003 {
2004 StreamString my_stream_string;
2005
2006 ClangASTType::DumpTypeDescription (type.GetASTContext(),
2007 type.GetOpaqueQualType(),
2008 &my_stream_string);
2009
Greg Claytonf3ef3d22011-05-22 22:46:53 +00002010 log->Printf ("%s %s with type %s",
2011 dematerialize ? "Dematerializing" : "Materializing",
2012 name.GetCString(),
2013 my_stream_string.GetString().c_str());
Sean Callanan77502262011-05-12 23:54:16 +00002014 }
Sean Callanan1d180662010-07-20 23:31:16 +00002015
2016 if (!location_value.get())
2017 {
Greg Clayton7b462cc2010-10-15 22:48:33 +00002018 err.SetErrorStringWithFormat("Couldn't get value for %s", name.GetCString());
Sean Callanan1d180662010-07-20 23:31:16 +00002019 return false;
2020 }
Sean Callananf4b9bd32010-10-05 20:18:48 +00002021
2022 // The size of the type contained in addr
Sean Callanan1d180662010-07-20 23:31:16 +00002023
Sean Callanan92adcac2011-01-13 08:53:35 +00002024 size_t value_bit_size = ClangASTType::GetClangTypeBitWidth(type.GetASTContext(), type.GetOpaqueQualType());
2025 size_t value_byte_size = value_bit_size % 8 ? ((value_bit_size + 8) / 8) : (value_bit_size / 8);
Sean Callananf4b9bd32010-10-05 20:18:48 +00002026
2027 Value::ValueType value_type = location_value->GetValueType();
2028
2029 switch (value_type)
Sean Callanan1d180662010-07-20 23:31:16 +00002030 {
Sean Callananf4b9bd32010-10-05 20:18:48 +00002031 default:
Sean Callanan1d180662010-07-20 23:31:16 +00002032 {
Sean Callananf4b9bd32010-10-05 20:18:48 +00002033 StreamString ss;
2034
2035 location_value->Dump(&ss);
2036
Greg Claytonf3ef3d22011-05-22 22:46:53 +00002037 err.SetErrorStringWithFormat ("%s has a value of unhandled type: %s",
2038 name.GetCString(),
2039 ss.GetString().c_str());
Sean Callanan1d180662010-07-20 23:31:16 +00002040 return false;
2041 }
Sean Callananf4b9bd32010-10-05 20:18:48 +00002042 break;
Sean Callanan7b5805d2013-01-18 21:20:51 +00002043 case Value::eValueTypeHostAddress:
2044 {
2045 if (dematerialize)
2046 {
2047 if (!DeleteLiveMemoryForExpressionVariable(*process, expr_var, err))
2048 return false;
2049 }
2050 else
2051 {
2052 DataExtractor value_data_extractor;
2053
2054 if (location_value->GetData(value_data_extractor))
2055 {
2056 if (value_byte_size != value_data_extractor.GetByteSize())
2057 {
Matt Kopec676a4872013-02-21 23:55:31 +00002058 err.SetErrorStringWithFormat ("Size mismatch for %s: %" PRIu64 " versus %" PRIu64,
Sean Callanan7b5805d2013-01-18 21:20:51 +00002059 name.GetCString(),
2060 (uint64_t)value_data_extractor.GetByteSize(),
2061 (uint64_t)value_byte_size);
2062 return false;
2063 }
2064
2065 if (!CreateLiveMemoryForExpressionVariable(*process, expr_var, err))
2066 return false;
2067
2068 Scalar &buf_addr = expr_var->m_live_sp->GetValue().GetScalar();
2069
2070 Error write_error;
2071
2072 if (!process->WriteMemory(buf_addr.ULongLong(),
2073 value_data_extractor.GetDataStart(),
2074 value_data_extractor.GetByteSize(),
2075 write_error))
2076 {
2077 err.SetErrorStringWithFormat ("Couldn't write %s to the target: %s",
2078 name.GetCString(),
2079 write_error.AsCString());
2080 return false;
2081 }
2082
2083 if (!process->WriteScalarToMemory(addr,
2084 buf_addr,
2085 process->GetAddressByteSize(),
2086 write_error))
2087 {
2088 err.SetErrorStringWithFormat ("Couldn't write the address of %s to the target: %s",
2089 name.GetCString(),
2090 write_error.AsCString());
2091 return false;
2092 }
2093 }
2094 else
2095 {
2096 err.SetErrorStringWithFormat ("%s is marked as a host address but doesn't contain any data",
2097 name.GetCString());
2098 return false;
2099 }
2100 }
2101 }
2102 break;
Sean Callananf4b9bd32010-10-05 20:18:48 +00002103 case Value::eValueTypeLoadAddress:
Sean Callanan1d180662010-07-20 23:31:16 +00002104 {
Sean Callanan92adcac2011-01-13 08:53:35 +00002105 if (!dematerialize)
Sean Callananf4b9bd32010-10-05 20:18:48 +00002106 {
Greg Claytonf3ef3d22011-05-22 22:46:53 +00002107 Error write_error;
Sean Callanan92adcac2011-01-13 08:53:35 +00002108
Sean Callanan98298012011-10-27 19:41:13 +00002109 if (is_reference)
Sean Callanan92adcac2011-01-13 08:53:35 +00002110 {
Sean Callanan98298012011-10-27 19:41:13 +00002111 Error read_error;
2112
2113 addr_t ref_value = process->ReadPointerFromMemory(location_value->GetScalar().ULongLong(), read_error);
2114
2115 if (!read_error.Success())
2116 {
2117 err.SetErrorStringWithFormat ("Couldn't read reference to %s from the target: %s",
2118 name.GetCString(),
2119 read_error.AsCString());
2120 return false;
2121 }
2122
2123 if (!process->WritePointerToMemory(addr,
2124 ref_value,
2125 write_error))
2126 {
2127 err.SetErrorStringWithFormat ("Couldn't write %s to the target: %s",
2128 name.GetCString(),
2129 write_error.AsCString());
2130 return false;
2131 }
2132 }
2133 else
2134 {
2135 if (!process->WriteScalarToMemory (addr,
2136 location_value->GetScalar(),
2137 process->GetAddressByteSize(),
2138 write_error))
2139 {
2140 err.SetErrorStringWithFormat ("Couldn't write %s to the target: %s",
2141 name.GetCString(),
2142 write_error.AsCString());
2143 return false;
2144 }
Sean Callanan92adcac2011-01-13 08:53:35 +00002145 }
Sean Callananf4b9bd32010-10-05 20:18:48 +00002146 }
Sean Callanan1d180662010-07-20 23:31:16 +00002147 }
Sean Callananf4b9bd32010-10-05 20:18:48 +00002148 break;
2149 case Value::eValueTypeScalar:
2150 {
Andrew Kaylor60cdeb62013-03-06 19:35:33 +00002151 if (location_value->GetContextType() == Value::eContextTypeRegisterInfo)
Sean Callananf4b9bd32010-10-05 20:18:48 +00002152 {
Andrew Kaylor60cdeb62013-03-06 19:35:33 +00002153 RegisterInfo *reg_info = location_value->GetRegisterInfo();
Sean Callananf4b9bd32010-10-05 20:18:48 +00002154
Andrew Kaylor60cdeb62013-03-06 19:35:33 +00002155 if (!reg_info)
Sean Callanan92adcac2011-01-13 08:53:35 +00002156 {
Andrew Kaylor60cdeb62013-03-06 19:35:33 +00002157 err.SetErrorStringWithFormat ("Couldn't get the register information for %s",
2158 name.GetCString());
Sean Callanan92adcac2011-01-13 08:53:35 +00002159 return false;
2160 }
2161
Sean Callanan98298012011-10-27 19:41:13 +00002162 RegisterValue reg_value;
Andrew Kaylor60cdeb62013-03-06 19:35:33 +00002163
2164 RegisterContext *reg_ctx = m_parser_vars->m_exe_ctx.GetRegisterContext();
Sean Callanan98298012011-10-27 19:41:13 +00002165
Andrew Kaylor60cdeb62013-03-06 19:35:33 +00002166 if (!reg_ctx)
Sean Callanan98298012011-10-27 19:41:13 +00002167 {
Andrew Kaylor60cdeb62013-03-06 19:35:33 +00002168 err.SetErrorStringWithFormat ("Couldn't read register context to read %s from %s",
Sean Callanan98298012011-10-27 19:41:13 +00002169 name.GetCString(),
2170 reg_info->name);
2171 return false;
2172 }
Andrew Kaylor60cdeb62013-03-06 19:35:33 +00002173
2174 uint32_t register_byte_size = reg_info->byte_size;
2175
2176 if (dematerialize)
Sean Callanan98298012011-10-27 19:41:13 +00002177 {
Andrew Kaylor60cdeb62013-03-06 19:35:33 +00002178 if (is_reference)
2179 return true; // reference types don't need demateralizing
Sean Callanan98298012011-10-27 19:41:13 +00002180
Andrew Kaylor60cdeb62013-03-06 19:35:33 +00002181 // Get the location of the spare memory area out of the variable's live data.
2182
2183 if (!expr_var->m_live_sp)
Sean Callanan98298012011-10-27 19:41:13 +00002184 {
Andrew Kaylor60cdeb62013-03-06 19:35:33 +00002185 err.SetErrorStringWithFormat("Couldn't find the memory area used to store %s", name.GetCString());
2186 return false;
2187 }
2188
2189 if (expr_var->m_live_sp->GetValue().GetValueAddressType() != eAddressTypeLoad)
2190 {
2191 err.SetErrorStringWithFormat("The address of the memory area for %s is in an incorrect format", name.GetCString());
2192 return false;
2193 }
2194
2195 Scalar &reg_addr = expr_var->m_live_sp->GetValue().GetScalar();
2196
2197 err = reg_ctx->ReadRegisterValueFromMemory (reg_info,
2198 reg_addr.ULongLong(),
2199 value_byte_size,
2200 reg_value);
2201 if (err.Fail())
2202 return false;
2203
2204 if (!reg_ctx->WriteRegister (reg_info, reg_value))
2205 {
2206 err.SetErrorStringWithFormat ("Couldn't write %s to register %s",
2207 name.GetCString(),
2208 reg_info->name);
2209 return false;
2210 }
2211
2212 if (!DeleteLiveMemoryForExpressionVariable(*process, expr_var, err))
2213 return false;
2214 }
2215 else
2216 {
2217 Error write_error;
2218
2219 RegisterValue reg_value;
2220
2221 if (!reg_ctx->ReadRegister (reg_info, reg_value))
2222 {
2223 err.SetErrorStringWithFormat ("Couldn't read %s from %s",
2224 name.GetCString(),
2225 reg_info->name);
2226 return false;
2227 }
2228
2229 if (is_reference)
2230 {
2231 write_error = reg_ctx->WriteRegisterValueToMemory(reg_info,
2232 addr,
2233 process->GetAddressByteSize(),
2234 reg_value);
2235
2236 if (!write_error.Success())
2237 {
2238 err.SetErrorStringWithFormat ("Couldn't write %s from register %s to the target: %s",
2239 name.GetCString(),
2240 reg_info->name,
2241 write_error.AsCString());
2242 return false;
2243 }
2244
2245 return true;
2246 }
2247
2248 // Allocate a spare memory area to place the register's contents into. This memory area will be pointed to by the slot in the
2249 // struct.
2250
2251 if (!CreateLiveMemoryForExpressionVariable (*process, expr_var, err))
2252 return false;
2253
2254 // Now write the location of the area into the struct.
2255
2256 Scalar &reg_addr = expr_var->m_live_sp->GetValue().GetScalar();
2257
2258 if (!process->WriteScalarToMemory (addr,
2259 reg_addr,
2260 process->GetAddressByteSize(),
2261 write_error))
2262 {
2263 err.SetErrorStringWithFormat ("Couldn't write %s to the target: %s",
2264 name.GetCString(),
Sean Callanan98298012011-10-27 19:41:13 +00002265 write_error.AsCString());
2266 return false;
2267 }
2268
Andrew Kaylor60cdeb62013-03-06 19:35:33 +00002269 if (value_byte_size > register_byte_size)
2270 {
2271 err.SetErrorStringWithFormat ("%s is too big to store in %s",
2272 name.GetCString(),
2273 reg_info->name);
2274 return false;
2275 }
Greg Clayton7349bd92011-05-09 20:18:18 +00002276
Andrew Kaylor60cdeb62013-03-06 19:35:33 +00002277 if (!reg_ctx->ReadRegister (reg_info, reg_value))
2278 {
2279 err.SetErrorStringWithFormat ("Couldn't read %s from %s",
2280 name.GetCString(),
2281 reg_info->name);
2282 return false;
2283 }
2284
2285 err = reg_ctx->WriteRegisterValueToMemory (reg_info,
2286 reg_addr.ULongLong(),
2287 value_byte_size,
2288 reg_value);
2289 if (err.Fail())
2290 return false;
Sean Callananf4b9bd32010-10-05 20:18:48 +00002291 }
Andrew Kaylor60cdeb62013-03-06 19:35:33 +00002292 }
2293 else
2294 {
2295 // The location_value is a scalar. We need to make space for it
2296 // or delete the space we made previously.
2297 if (dematerialize)
2298 {
2299 if (!DeleteLiveMemoryForExpressionVariable(*process, expr_var, err))
2300 return false;
2301 }
2302 else
2303 {
2304 DataExtractor value_data_extractor;
2305
2306 if (location_value->GetData(value_data_extractor))
2307 {
2308 if (value_byte_size != value_data_extractor.GetByteSize())
2309 {
Matt Kopec787d1622013-03-12 17:45:38 +00002310 err.SetErrorStringWithFormat ("Size mismatch for %s: %" PRIu64 " versus %" PRIu64,
Andrew Kaylor60cdeb62013-03-06 19:35:33 +00002311 name.GetCString(),
2312 (uint64_t)value_data_extractor.GetByteSize(),
2313 (uint64_t)value_byte_size);
2314 return false;
2315 }
2316
2317 if (!CreateLiveMemoryForExpressionVariable(*process, expr_var, err))
2318 return false;
2319
2320 Scalar &buf_addr = expr_var->m_live_sp->GetValue().GetScalar();
2321
2322 Error write_error;
2323
2324 if (!process->WriteMemory(buf_addr.ULongLong(),
2325 value_data_extractor.GetDataStart(),
2326 value_data_extractor.GetByteSize(),
2327 write_error))
2328 {
2329 err.SetErrorStringWithFormat ("Couldn't write %s to the target: %s",
2330 name.GetCString(),
2331 write_error.AsCString());
2332 return false;
2333 }
2334
2335 if (!process->WriteScalarToMemory(addr,
2336 buf_addr,
2337 process->GetAddressByteSize(),
2338 write_error))
2339 {
2340 err.SetErrorStringWithFormat ("Couldn't write the address of %s to the target: %s",
2341 name.GetCString(),
2342 write_error.AsCString());
2343 return false;
2344 }
2345 }
2346 else
2347 {
2348 err.SetErrorStringWithFormat ("%s is marked as a scalar value but doesn't contain any data",
2349 name.GetCString());
2350 return false;
2351 }
2352 }
Sean Callananf4b9bd32010-10-05 20:18:48 +00002353 }
2354 }
Sean Callanan1d180662010-07-20 23:31:16 +00002355 }
2356
2357 return true;
Sean Callananea22d422010-07-16 00:09:46 +00002358}
2359
Sean Callanan348b5892010-11-30 00:27:43 +00002360bool
2361ClangExpressionDeclMap::DoMaterializeOneRegister
2362(
2363 bool dematerialize,
Sean Callanan348b5892010-11-30 00:27:43 +00002364 RegisterContext &reg_ctx,
Greg Claytone0d378b2011-03-24 21:19:54 +00002365 const RegisterInfo &reg_info,
Sean Callanan348b5892010-11-30 00:27:43 +00002366 lldb::addr_t addr,
2367 Error &err
2368)
2369{
Sean Callanan348b5892010-11-30 00:27:43 +00002370 uint32_t register_byte_size = reg_info.byte_size;
Greg Clayton7349bd92011-05-09 20:18:18 +00002371 RegisterValue reg_value;
Sean Callanan348b5892010-11-30 00:27:43 +00002372 if (dematerialize)
2373 {
Greg Clayton7349bd92011-05-09 20:18:18 +00002374 Error read_error (reg_ctx.ReadRegisterValueFromMemory(&reg_info, addr, register_byte_size, reg_value));
2375 if (read_error.Fail())
Sean Callanan348b5892010-11-30 00:27:43 +00002376 {
Greg Clayton1a65ae12011-01-25 23:55:37 +00002377 err.SetErrorStringWithFormat ("Couldn't read %s from the target: %s", reg_info.name, read_error.AsCString());
Sean Callanan348b5892010-11-30 00:27:43 +00002378 return false;
2379 }
2380
Greg Clayton7349bd92011-05-09 20:18:18 +00002381 if (!reg_ctx.WriteRegister (&reg_info, reg_value))
Sean Callanan348b5892010-11-30 00:27:43 +00002382 {
Greg Clayton7349bd92011-05-09 20:18:18 +00002383 err.SetErrorStringWithFormat("Couldn't write register %s (dematerialize)", reg_info.name);
Sean Callanan348b5892010-11-30 00:27:43 +00002384 return false;
2385 }
2386 }
2387 else
2388 {
Sean Callanan348b5892010-11-30 00:27:43 +00002389
Greg Clayton7349bd92011-05-09 20:18:18 +00002390 if (!reg_ctx.ReadRegister(&reg_info, reg_value))
Sean Callanan348b5892010-11-30 00:27:43 +00002391 {
Greg Clayton7349bd92011-05-09 20:18:18 +00002392 err.SetErrorStringWithFormat("Couldn't read %s (materialize)", reg_info.name);
Sean Callanan348b5892010-11-30 00:27:43 +00002393 return false;
2394 }
2395
Greg Clayton7349bd92011-05-09 20:18:18 +00002396 Error write_error (reg_ctx.WriteRegisterValueToMemory(&reg_info, addr, register_byte_size, reg_value));
2397 if (write_error.Fail())
Sean Callanan348b5892010-11-30 00:27:43 +00002398 {
Jason Molenda7e589a62011-09-20 00:26:08 +00002399 err.SetErrorStringWithFormat ("Couldn't write %s to the target: %s", reg_info.name, write_error.AsCString());
Sean Callanan348b5892010-11-30 00:27:43 +00002400 return false;
2401 }
2402 }
2403
2404 return true;
2405}
2406
Sean Callanan63697e52011-05-07 01:06:41 +00002407lldb::VariableSP
Greg Clayton7b462cc2010-10-15 22:48:33 +00002408ClangExpressionDeclMap::FindVariableInScope
2409(
2410 StackFrame &frame,
2411 const ConstString &name,
Sean Callanan5056ab02012-02-18 02:01:03 +00002412 TypeFromUser *type,
Sean Callanan0259e512012-05-21 21:29:52 +00002413 bool object_pointer
Greg Clayton7b462cc2010-10-15 22:48:33 +00002414)
Sean Callanan979f74d2010-12-03 01:38:59 +00002415{
Greg Clayton2d4edfb2010-11-06 01:53:30 +00002416 lldb::LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_EXPRESSIONS));
Sean Callanan44096b12010-09-14 21:59:34 +00002417
Sean Callanan69b53412011-08-06 00:28:14 +00002418 ValueObjectSP valobj;
2419 VariableSP var_sp;
2420 Error err;
Sean Callanan44096b12010-09-14 21:59:34 +00002421
Sean Callananaf776172013-02-12 07:56:36 +00002422 valobj = frame.GetValueForVariableExpressionPath(name.GetCString(),
Sean Callanan69b53412011-08-06 00:28:14 +00002423 eNoDynamicValues,
Sean Callananaf776172013-02-12 07:56:36 +00002424 StackFrame::eExpressionPathOptionCheckPtrVsMember ||
2425 StackFrame::eExpressionPathOptionsAllowDirectIVarAccess ||
2426 StackFrame::eExpressionPathOptionsNoFragileObjcIvar ||
2427 StackFrame::eExpressionPathOptionsNoSyntheticChildren ||
2428 StackFrame::eExpressionPathOptionsNoSyntheticArrayRange,
Sean Callanan69b53412011-08-06 00:28:14 +00002429 var_sp,
2430 err);
Greg Clayton83c5cd92010-11-14 22:13:40 +00002431
Sean Callanan69b53412011-08-06 00:28:14 +00002432 if (!err.Success() ||
2433 !var_sp ||
Sean Callananc6466fc2011-07-07 23:05:43 +00002434 !var_sp->IsInScope(&frame) ||
2435 !var_sp->LocationIsValidForFrame (&frame))
2436 return lldb::VariableSP();
Greg Clayton83c5cd92010-11-14 22:13:40 +00002437
Sean Callanan3e606ea2012-05-21 22:25:52 +00002438 if (var_sp)
Greg Clayton83c5cd92010-11-14 22:13:40 +00002439 {
Sean Callanan3e606ea2012-05-21 22:25:52 +00002440 if (!type)
2441 return var_sp;
2442
Sean Callanan0259e512012-05-21 21:29:52 +00002443 TypeFromUser candidate_type(var_sp->GetType()->GetClangFullType(),
2444 var_sp->GetType()->GetClangAST());
2445
2446 if (candidate_type.GetASTContext() != type->GetASTContext())
Greg Clayton83c5cd92010-11-14 22:13:40 +00002447 {
2448 if (log)
2449 log->PutCString("Skipping a candidate variable because of different AST contexts");
Sean Callanan63697e52011-05-07 01:06:41 +00002450 return lldb::VariableSP();
Greg Clayton83c5cd92010-11-14 22:13:40 +00002451 }
Sean Callanan0259e512012-05-21 21:29:52 +00002452
2453 if (object_pointer)
2454 {
2455 clang::QualType desired_qual_type = clang::QualType::getFromOpaquePtr(type->GetOpaqueQualType());
2456 clang::QualType candidate_qual_type = clang::QualType::getFromOpaquePtr(candidate_type.GetOpaqueQualType());
2457
Sean Callanan3e606ea2012-05-21 22:25:52 +00002458 const clang::ObjCObjectPointerType *desired_objc_ptr_type = desired_qual_type->getAs<clang::ObjCObjectPointerType>();
2459 const clang::ObjCObjectPointerType *candidate_objc_ptr_type = desired_qual_type->getAs<clang::ObjCObjectPointerType>();
2460
2461 if (desired_objc_ptr_type && candidate_objc_ptr_type) {
2462 clang::QualType desired_target_type = desired_objc_ptr_type->getPointeeType().getUnqualifiedType();
2463 clang::QualType candidate_target_type = candidate_objc_ptr_type->getPointeeType().getUnqualifiedType();
2464
2465 if (ClangASTContext::AreTypesSame(type->GetASTContext(),
2466 desired_target_type.getAsOpaquePtr(),
2467 candidate_target_type.getAsOpaquePtr()))
2468 return var_sp;
2469 }
2470
Sean Callanan0259e512012-05-21 21:29:52 +00002471 const clang::PointerType *desired_ptr_type = desired_qual_type->getAs<clang::PointerType>();
2472 const clang::PointerType *candidate_ptr_type = candidate_qual_type->getAs<clang::PointerType>();
2473
Sean Callanan3e606ea2012-05-21 22:25:52 +00002474 if (desired_ptr_type && candidate_ptr_type) {
2475 clang::QualType desired_target_type = desired_ptr_type->getPointeeType().getUnqualifiedType();
2476 clang::QualType candidate_target_type = candidate_ptr_type->getPointeeType().getUnqualifiedType();
2477
2478 if (ClangASTContext::AreTypesSame(type->GetASTContext(),
2479 desired_target_type.getAsOpaquePtr(),
2480 candidate_target_type.getAsOpaquePtr()))
2481 return var_sp;
2482 }
Sean Callanan0259e512012-05-21 21:29:52 +00002483
Sean Callanan3e606ea2012-05-21 22:25:52 +00002484 return lldb::VariableSP();
Sean Callanan0259e512012-05-21 21:29:52 +00002485 }
2486 else
2487 {
Sean Callanan3e606ea2012-05-21 22:25:52 +00002488 if (ClangASTContext::AreTypesSame(type->GetASTContext(),
Sean Callanan0259e512012-05-21 21:29:52 +00002489 type->GetOpaqueQualType(),
2490 var_sp->GetType()->GetClangFullType()))
Sean Callanan3e606ea2012-05-21 22:25:52 +00002491 return var_sp;
Sean Callanan0259e512012-05-21 21:29:52 +00002492 }
Sean Callanan44096b12010-09-14 21:59:34 +00002493 }
Greg Clayton83c5cd92010-11-14 22:13:40 +00002494
Sean Callanan3e606ea2012-05-21 22:25:52 +00002495 return lldb::VariableSP();
Sean Callanan44096b12010-09-14 21:59:34 +00002496}
Sean Callanan6b4067c2010-07-17 00:43:37 +00002497
Greg Clayton3d51b9f2012-11-27 01:52:16 +00002498const Symbol *
2499ClangExpressionDeclMap::FindGlobalDataSymbol (Target &target,
2500 const ConstString &name)
Sean Callanand9ca42a2011-05-08 02:21:26 +00002501{
2502 SymbolContextList sc_list;
2503
Greg Clayton3d51b9f2012-11-27 01:52:16 +00002504 target.GetImages().FindSymbolsWithNameAndType(name, eSymbolTypeAny, sc_list);
Sean Callanand9ca42a2011-05-08 02:21:26 +00002505
Greg Clayton3d51b9f2012-11-27 01:52:16 +00002506 const uint32_t matches = sc_list.GetSize();
2507 for (uint32_t i=0; i<matches; ++i)
Sean Callanand9ca42a2011-05-08 02:21:26 +00002508 {
2509 SymbolContext sym_ctx;
Greg Clayton3d51b9f2012-11-27 01:52:16 +00002510 sc_list.GetContextAtIndex(i, sym_ctx);
2511 if (sym_ctx.symbol)
2512 {
2513 const Symbol *symbol = sym_ctx.symbol;
2514 const Address *sym_address = &symbol->GetAddress();
2515
2516 if (sym_address && sym_address->IsValid())
2517 {
2518 switch (symbol->GetType())
2519 {
2520 case eSymbolTypeData:
2521 case eSymbolTypeRuntime:
2522 case eSymbolTypeAbsolute:
2523 case eSymbolTypeObjCClass:
2524 case eSymbolTypeObjCMetaClass:
2525 case eSymbolTypeObjCIVar:
2526 if (symbol->GetDemangledNameIsSynthesized())
2527 {
2528 // If the demangled name was synthesized, then don't use it
2529 // for expressions. Only let the symbol match if the mangled
2530 // named matches for these symbols.
2531 if (symbol->GetMangled().GetMangledName() != name)
2532 break;
2533 }
2534 return symbol;
2535
2536 case eSymbolTypeCode: // We already lookup functions elsewhere
2537 case eSymbolTypeVariable:
2538 case eSymbolTypeLocal:
2539 case eSymbolTypeParam:
2540 case eSymbolTypeTrampoline:
2541 case eSymbolTypeInvalid:
2542 case eSymbolTypeException:
2543 case eSymbolTypeSourceFile:
2544 case eSymbolTypeHeaderFile:
2545 case eSymbolTypeObjectFile:
2546 case eSymbolTypeCommonBlock:
2547 case eSymbolTypeBlock:
2548 case eSymbolTypeVariableType:
2549 case eSymbolTypeLineEntry:
2550 case eSymbolTypeLineHeader:
2551 case eSymbolTypeScopeBegin:
2552 case eSymbolTypeScopeEnd:
2553 case eSymbolTypeAdditional:
2554 case eSymbolTypeCompiler:
2555 case eSymbolTypeInstrumentation:
2556 case eSymbolTypeUndefined:
Matt Kopec00049b82013-02-27 20:13:38 +00002557 case eSymbolTypeResolver:
Greg Clayton3d51b9f2012-11-27 01:52:16 +00002558 break;
2559 }
2560 }
2561 }
Sean Callanand9ca42a2011-05-08 02:21:26 +00002562 }
2563
2564 return NULL;
2565}
2566
Sean Callanan3bfdaa22011-09-15 02:13:07 +00002567lldb::VariableSP
2568ClangExpressionDeclMap::FindGlobalVariable
2569(
2570 Target &target,
Sean Callanan1fd3f4f2011-10-12 16:59:31 +00002571 ModuleSP &module,
2572 const ConstString &name,
2573 ClangNamespaceDecl *namespace_decl,
Sean Callanan3bfdaa22011-09-15 02:13:07 +00002574 TypeFromUser *type
2575)
2576{
2577 VariableList vars;
Sean Callanan3bfdaa22011-09-15 02:13:07 +00002578
Sean Callanan1fd3f4f2011-10-12 16:59:31 +00002579 if (module && namespace_decl)
2580 module->FindGlobalVariables (name, namespace_decl, true, -1, vars);
2581 else
2582 target.GetImages().FindGlobalVariables(name, true, -1, vars);
Sean Callanan3bfdaa22011-09-15 02:13:07 +00002583
2584 if (vars.GetSize())
2585 {
2586 if (type)
2587 {
2588 for (size_t i = 0; i < vars.GetSize(); ++i)
2589 {
2590 VariableSP var_sp = vars.GetVariableAtIndex(i);
2591
2592 if (type->GetASTContext() == var_sp->GetType()->GetClangAST())
2593 {
2594 if (ClangASTContext::AreTypesSame(type->GetASTContext(), type->GetOpaqueQualType(), var_sp->GetType()->GetClangFullType()))
2595 return var_sp;
2596 }
2597 }
2598 }
2599 else
2600 {
2601 return vars.GetVariableAtIndex(0);
2602 }
2603 }
2604
2605 return VariableSP();
2606}
2607
Chris Lattner30fdc8d2010-06-08 16:52:24 +00002608// Interface for ClangASTSource
Sean Callanan3bfdaa22011-09-15 02:13:07 +00002609
Sean Callanan503aa522011-10-12 00:12:34 +00002610void
Sean Callananeddeb3b2011-10-28 23:38:38 +00002611ClangExpressionDeclMap::FindExternalVisibleDecls (NameSearchContext &context)
Chris Lattner30fdc8d2010-06-08 16:52:24 +00002612{
Sean Callananeddeb3b2011-10-28 23:38:38 +00002613 assert (m_ast_context);
2614
Sean Callanan8106d802013-03-08 20:04:57 +00002615 ClangASTMetrics::RegisterVisibleQuery();
2616
Sean Callananeddeb3b2011-10-28 23:38:38 +00002617 const ConstString name(context.m_decl_name.getAsString().c_str());
2618
Greg Clayton2d4edfb2010-11-06 01:53:30 +00002619 lldb::LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_EXPRESSIONS));
Chris Lattner30fdc8d2010-06-08 16:52:24 +00002620
Sean Callananfb3e4302011-10-29 19:50:43 +00002621 if (GetImportInProgress())
Sean Callanan6abfabf2010-11-19 20:20:02 +00002622 {
Sean Callanan7dd98122011-10-14 20:34:21 +00002623 if (log && log->GetVerbose())
Sean Callanan6abfabf2010-11-19 20:20:02 +00002624 log->Printf("Ignoring a query during an import");
2625 return;
2626 }
Greg Claytona2721472011-06-25 00:44:06 +00002627
Sean Callanan7dd98122011-10-14 20:34:21 +00002628 static unsigned int invocation_id = 0;
2629 unsigned int current_id = invocation_id++;
2630
Sean Callanan503aa522011-10-12 00:12:34 +00002631 if (log)
2632 {
2633 if (!context.m_decl_context)
Sean Callananfb3e4302011-10-29 19:50:43 +00002634 log->Printf("ClangExpressionDeclMap::FindExternalVisibleDecls[%u] for '%s' in a NULL DeclContext", current_id, name.GetCString());
Sean Callanan503aa522011-10-12 00:12:34 +00002635 else if (const NamedDecl *context_named_decl = dyn_cast<NamedDecl>(context.m_decl_context))
Sean Callananfb3e4302011-10-29 19:50:43 +00002636 log->Printf("ClangExpressionDeclMap::FindExternalVisibleDecls[%u] for '%s' in '%s'", current_id, name.GetCString(), context_named_decl->getNameAsString().c_str());
Sean Callanan503aa522011-10-12 00:12:34 +00002637 else
Sean Callananfb3e4302011-10-29 19:50:43 +00002638 log->Printf("ClangExpressionDeclMap::FindExternalVisibleDecls[%u] for '%s' in a '%s'", current_id, name.GetCString(), context.m_decl_context->getDeclKindName());
Sean Callanan503aa522011-10-12 00:12:34 +00002639 }
Sean Callananfb3e4302011-10-29 19:50:43 +00002640
Sean Callanan503aa522011-10-12 00:12:34 +00002641 if (const NamespaceDecl *namespace_context = dyn_cast<NamespaceDecl>(context.m_decl_context))
2642 {
Sean Callanan1ee44b72011-10-29 01:58:46 +00002643 ClangASTImporter::NamespaceMapSP namespace_map = m_ast_importer->GetNamespaceMap(namespace_context);
Sean Callananc41e68b2011-10-13 21:08:11 +00002644
Sean Callanan7dd98122011-10-14 20:34:21 +00002645 if (log && log->GetVerbose())
Sean Callanan00f43622011-11-18 03:28:09 +00002646 log->Printf(" CEDM::FEVD[%u] Inspecting (NamespaceMap*)%p (%d entries)",
Sean Callanan7dd98122011-10-14 20:34:21 +00002647 current_id,
2648 namespace_map.get(),
2649 (int)namespace_map->size());
Sean Callananc41e68b2011-10-13 21:08:11 +00002650
Sean Callananb2269162011-10-21 22:18:07 +00002651 if (!namespace_map)
2652 return;
2653
Sean Callanan503aa522011-10-12 00:12:34 +00002654 for (ClangASTImporter::NamespaceMap::iterator i = namespace_map->begin(), e = namespace_map->end();
2655 i != e;
2656 ++i)
2657 {
2658 if (log)
Sean Callananfb3e4302011-10-29 19:50:43 +00002659 log->Printf(" CEDM::FEVD[%u] Searching namespace %s in module %s",
Sean Callanan7dd98122011-10-14 20:34:21 +00002660 current_id,
Sean Callanan503aa522011-10-12 00:12:34 +00002661 i->second.GetNamespaceDecl()->getNameAsString().c_str(),
2662 i->first->GetFileSpec().GetFilename().GetCString());
2663
Sean Callananebe60672011-10-13 21:50:33 +00002664 FindExternalVisibleDecls(context,
2665 i->first,
2666 i->second,
Sean Callanan7dd98122011-10-14 20:34:21 +00002667 current_id);
Sean Callanan503aa522011-10-12 00:12:34 +00002668 }
2669 }
Sean Callanand5c17ed2011-11-15 02:11:17 +00002670 else if (isa<TranslationUnitDecl>(context.m_decl_context))
Sean Callanan503aa522011-10-12 00:12:34 +00002671 {
2672 ClangNamespaceDecl namespace_decl;
2673
2674 if (log)
Sean Callananfb3e4302011-10-29 19:50:43 +00002675 log->Printf(" CEDM::FEVD[%u] Searching the root namespace", current_id);
Sean Callanan503aa522011-10-12 00:12:34 +00002676
2677 FindExternalVisibleDecls(context,
2678 lldb::ModuleSP(),
2679 namespace_decl,
Sean Callanan7dd98122011-10-14 20:34:21 +00002680 current_id);
Sean Callanan503aa522011-10-12 00:12:34 +00002681 }
Sean Callananc41e68b2011-10-13 21:08:11 +00002682
Sean Callananfb3e4302011-10-29 19:50:43 +00002683 if (!context.m_found.variable)
2684 ClangASTSource::FindExternalVisibleDecls(context);
Sean Callanan503aa522011-10-12 00:12:34 +00002685}
2686
2687void
2688ClangExpressionDeclMap::FindExternalVisibleDecls (NameSearchContext &context,
Sean Callanan1a2c5382011-10-12 18:44:30 +00002689 lldb::ModuleSP module_sp,
Sean Callanan88972242011-10-12 01:39:28 +00002690 ClangNamespaceDecl &namespace_decl,
Sean Callanan7dd98122011-10-14 20:34:21 +00002691 unsigned int current_id)
Sean Callanan503aa522011-10-12 00:12:34 +00002692{
Sean Callananeddeb3b2011-10-28 23:38:38 +00002693 assert (m_ast_context);
Sean Callanan503aa522011-10-12 00:12:34 +00002694
2695 lldb::LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_EXPRESSIONS));
Sean Callananfb3e4302011-10-29 19:50:43 +00002696
Greg Clayton7a345282010-11-09 23:46:37 +00002697 SymbolContextList sc_list;
Chris Lattner30fdc8d2010-06-08 16:52:24 +00002698
Sean Callananfb3e4302011-10-29 19:50:43 +00002699 const ConstString name(context.m_decl_name.getAsString().c_str());
2700
Greg Clayton83c5cd92010-11-14 22:13:40 +00002701 const char *name_unique_cstr = name.GetCString();
2702
2703 if (name_unique_cstr == NULL)
2704 return;
Sean Callananfb3e4302011-10-29 19:50:43 +00002705
Sean Callanan5b26f272012-02-04 08:49:35 +00002706 static ConstString id_name("id");
2707 static ConstString Class_name("Class");
2708
2709 if (name == id_name || name == Class_name)
2710 return;
2711
Greg Clayton7b462cc2010-10-15 22:48:33 +00002712 // Only look for functions by name out in our symbols if the function
2713 // doesn't start with our phony prefix of '$'
Sean Callanan933693b2012-02-10 01:22:05 +00002714 Target *target = m_parser_vars->m_exe_ctx.GetTargetPtr();
2715 StackFrame *frame = m_parser_vars->m_exe_ctx.GetFramePtr();
Sean Callanan88972242011-10-12 01:39:28 +00002716 if (name_unique_cstr[0] == '$' && !namespace_decl)
2717 {
2718 static ConstString g_lldb_class_name ("$__lldb_class");
2719
2720 if (name == g_lldb_class_name)
2721 {
2722 // Clang is looking for the type of "this"
Sean Callananc03bdd92012-02-08 03:45:08 +00002723
2724 if (frame == NULL)
Sean Callanan88972242011-10-12 01:39:28 +00002725 return;
2726
Sean Callananc03bdd92012-02-08 03:45:08 +00002727 SymbolContext sym_ctx = frame->GetSymbolContext(lldb::eSymbolContextFunction);
Sean Callanan88972242011-10-12 01:39:28 +00002728
Sean Callananc03bdd92012-02-08 03:45:08 +00002729 if (!sym_ctx.function)
Sean Callanan88972242011-10-12 01:39:28 +00002730 return;
2731
Greg Clayton685c88c2012-07-14 00:53:55 +00002732 // Get the block that defines the function
2733 Block *function_block = sym_ctx.GetFunctionBlock();
2734
2735 if (!function_block)
2736 return;
2737
2738 clang::DeclContext *decl_context = function_block->GetClangDeclContext();
Sean Callananc03bdd92012-02-08 03:45:08 +00002739
2740 if (!decl_context)
Sean Callanan88972242011-10-12 01:39:28 +00002741 return;
2742
Sean Callananc03bdd92012-02-08 03:45:08 +00002743 clang::CXXMethodDecl *method_decl = llvm::dyn_cast<clang::CXXMethodDecl>(decl_context);
Sean Callanan88972242011-10-12 01:39:28 +00002744
Jim Ingham5fdeed42012-10-30 23:35:54 +00002745 if (method_decl)
Sean Callanan88972242011-10-12 01:39:28 +00002746 {
Jim Ingham5fdeed42012-10-30 23:35:54 +00002747 clang::CXXRecordDecl *class_decl = method_decl->getParent();
2748
2749 QualType class_qual_type(class_decl->getTypeForDecl(), 0);
2750
2751 TypeFromUser class_user_type (class_qual_type.getAsOpaquePtr(),
2752 &class_decl->getASTContext());
2753
2754 if (log)
2755 {
2756 ASTDumper ast_dumper(class_qual_type);
2757 log->Printf(" CEDM::FEVD[%u] Adding type for $__lldb_class: %s", current_id, ast_dumper.GetCString());
2758 }
2759
Sean Callananfa4fab72013-02-01 06:55:48 +00002760 TypeFromParser class_type = CopyClassType(class_user_type, current_id);
2761
2762 if (!class_type.IsValid())
2763 return;
2764
2765 TypeSourceInfo *type_source_info = m_ast_context->CreateTypeSourceInfo(QualType::getFromOpaquePtr(class_type.GetOpaqueQualType()));
2766
2767 if (!type_source_info)
2768 return;
2769
2770 TypedefDecl *typedef_decl = TypedefDecl::Create(*m_ast_context,
2771 m_ast_context->getTranslationUnitDecl(),
2772 SourceLocation(),
2773 SourceLocation(),
2774 context.m_decl_name.getAsIdentifierInfo(),
2775 type_source_info);
2776
2777
2778 if (!typedef_decl)
2779 return;
2780
2781 context.AddNamedDecl(typedef_decl);
Jim Ingham5fdeed42012-10-30 23:35:54 +00002782
2783 if (method_decl->isInstance())
2784 {
2785 // self is a pointer to the object
2786
2787 QualType class_pointer_type = method_decl->getASTContext().getPointerType(class_qual_type);
2788
2789 TypeFromUser self_user_type(class_pointer_type.getAsOpaquePtr(),
2790 &method_decl->getASTContext());
2791
2792 m_struct_vars->m_object_pointer_type = self_user_type;
2793 }
Sean Callanan88972242011-10-12 01:39:28 +00002794 }
Jim Ingham5fdeed42012-10-30 23:35:54 +00002795 else
Sean Callananbb6e7ed2012-03-05 22:08:20 +00002796 {
Jim Ingham5fdeed42012-10-30 23:35:54 +00002797 // This branch will get hit if we are executing code in the context of a function that
2798 // claims to have an object pointer (through DW_AT_object_pointer?) but is not formally a
2799 // method of the class. In that case, just look up the "this" variable in the the current
2800 // scope and use its type.
2801 // FIXME: This code is formally correct, but clang doesn't currently emit DW_AT_object_pointer
2802 // for C++ so it hasn't actually been tested.
Sean Callananbb6e7ed2012-03-05 22:08:20 +00002803
Jim Ingham5fdeed42012-10-30 23:35:54 +00002804 VariableList *vars = frame->GetVariableList(false);
Sean Callananbb6e7ed2012-03-05 22:08:20 +00002805
Jim Ingham5fdeed42012-10-30 23:35:54 +00002806 lldb::VariableSP this_var = vars->FindVariable(ConstString("this"));
Sean Callananbb6e7ed2012-03-05 22:08:20 +00002807
Jim Ingham5fdeed42012-10-30 23:35:54 +00002808 if (this_var &&
2809 this_var->IsInScope(frame) &&
2810 this_var->LocationIsValidForFrame (frame))
2811 {
2812 Type *this_type = this_var->GetType();
2813
2814 if (!this_type)
2815 return;
2816
2817 QualType this_qual_type = QualType::getFromOpaquePtr(this_type->GetClangFullType());
2818 const PointerType *class_pointer_type = this_qual_type->getAs<PointerType>();
2819
2820 if (class_pointer_type)
2821 {
2822 QualType class_type = class_pointer_type->getPointeeType();
2823
2824 if (log)
2825 {
2826 ASTDumper ast_dumper(this_type->GetClangFullType());
2827 log->Printf(" FEVD[%u] Adding type for $__lldb_objc_class: %s", current_id, ast_dumper.GetCString());
2828 }
2829
2830 TypeFromUser class_user_type (class_type.getAsOpaquePtr(),
2831 this_type->GetClangAST());
Sean Callananfa4fab72013-02-01 06:55:48 +00002832 AddOneType(context, class_user_type, current_id);
Jim Ingham5fdeed42012-10-30 23:35:54 +00002833
2834
2835 TypeFromUser this_user_type(this_type->GetClangFullType(),
2836 this_type->GetClangAST());
2837
2838 m_struct_vars->m_object_pointer_type = this_user_type;
2839 return;
2840 }
2841 }
Sean Callananbb6e7ed2012-03-05 22:08:20 +00002842 }
2843
Sean Callanan88972242011-10-12 01:39:28 +00002844 return;
2845 }
2846
2847 static ConstString g_lldb_objc_class_name ("$__lldb_objc_class");
2848 if (name == g_lldb_objc_class_name)
2849 {
2850 // Clang is looking for the type of "*self"
2851
2852 if (!frame)
2853 return;
Sean Callanand5c17ed2011-11-15 02:11:17 +00002854
2855 SymbolContext sym_ctx = frame->GetSymbolContext(lldb::eSymbolContextFunction);
2856
2857 if (!sym_ctx.function)
2858 return;
2859
Greg Clayton685c88c2012-07-14 00:53:55 +00002860 // Get the block that defines the function
2861 Block *function_block = sym_ctx.GetFunctionBlock();
Sean Callanand5c17ed2011-11-15 02:11:17 +00002862
Greg Clayton685c88c2012-07-14 00:53:55 +00002863 if (!function_block)
2864 return;
2865
2866 clang::DeclContext *decl_context = function_block->GetClangDeclContext();
Sean Callanand5c17ed2011-11-15 02:11:17 +00002867
2868 if (!decl_context)
2869 return;
2870
2871 clang::ObjCMethodDecl *method_decl = llvm::dyn_cast<clang::ObjCMethodDecl>(decl_context);
2872
Jim Ingham5fdeed42012-10-30 23:35:54 +00002873 if (method_decl)
Sean Callanand5c17ed2011-11-15 02:11:17 +00002874 {
Jim Ingham5fdeed42012-10-30 23:35:54 +00002875 ObjCInterfaceDecl* self_interface = method_decl->getClassInterface();
Sean Callanand5c17ed2011-11-15 02:11:17 +00002876
Jim Ingham5fdeed42012-10-30 23:35:54 +00002877 if (!self_interface)
Sean Callananc03bdd92012-02-08 03:45:08 +00002878 return;
2879
Jim Ingham5fdeed42012-10-30 23:35:54 +00002880 const clang::Type *interface_type = self_interface->getTypeForDecl();
2881
2882 TypeFromUser class_user_type(QualType(interface_type, 0).getAsOpaquePtr(),
2883 &method_decl->getASTContext());
Sean Callananc03bdd92012-02-08 03:45:08 +00002884
Jim Ingham5fdeed42012-10-30 23:35:54 +00002885 if (log)
2886 {
2887 ASTDumper ast_dumper(interface_type);
2888 log->Printf(" FEVD[%u] Adding type for $__lldb_objc_class: %s", current_id, ast_dumper.GetCString());
2889 }
2890
Sean Callananfa4fab72013-02-01 06:55:48 +00002891 AddOneType(context, class_user_type, current_id);
Jim Ingham5fdeed42012-10-30 23:35:54 +00002892
2893 if (method_decl->isInstanceMethod())
2894 {
2895 // self is a pointer to the object
2896
2897 QualType class_pointer_type = method_decl->getASTContext().getObjCObjectPointerType(QualType(interface_type, 0));
2898
2899 TypeFromUser self_user_type(class_pointer_type.getAsOpaquePtr(),
2900 &method_decl->getASTContext());
2901
2902 m_struct_vars->m_object_pointer_type = self_user_type;
2903 }
2904 else
2905 {
2906 // self is a Class pointer
2907 QualType class_type = method_decl->getASTContext().getObjCClassType();
2908
2909 TypeFromUser self_user_type(class_type.getAsOpaquePtr(),
2910 &method_decl->getASTContext());
2911
2912 m_struct_vars->m_object_pointer_type = self_user_type;
2913 }
2914
2915 return;
Sean Callananc03bdd92012-02-08 03:45:08 +00002916 }
2917 else
2918 {
Jim Ingham5fdeed42012-10-30 23:35:54 +00002919 // This branch will get hit if we are executing code in the context of a function that
2920 // claims to have an object pointer (through DW_AT_object_pointer?) but is not formally a
2921 // method of the class. In that case, just look up the "self" variable in the the current
2922 // scope and use its type.
Sean Callananc03bdd92012-02-08 03:45:08 +00002923
Jim Ingham5fdeed42012-10-30 23:35:54 +00002924 VariableList *vars = frame->GetVariableList(false);
Sean Callananc03bdd92012-02-08 03:45:08 +00002925
Jim Ingham5fdeed42012-10-30 23:35:54 +00002926 lldb::VariableSP self_var = vars->FindVariable(ConstString("self"));
2927
2928 if (self_var &&
2929 self_var->IsInScope(frame) &&
2930 self_var->LocationIsValidForFrame (frame))
2931 {
2932 Type *self_type = self_var->GetType();
2933
2934 if (!self_type)
2935 return;
2936
2937 QualType self_qual_type = QualType::getFromOpaquePtr(self_type->GetClangFullType());
Jim Ingham5fdeed42012-10-30 23:35:54 +00002938
Sean Callanana2868d42013-01-19 01:49:02 +00002939 if (self_qual_type->isObjCClassType())
Jim Ingham5fdeed42012-10-30 23:35:54 +00002940 {
Sean Callanana2868d42013-01-19 01:49:02 +00002941 return;
2942 }
2943 else if (self_qual_type->isObjCObjectPointerType())
2944 {
2945 const ObjCObjectPointerType *class_pointer_type = self_qual_type->getAs<ObjCObjectPointerType>();
2946
Jim Ingham5fdeed42012-10-30 23:35:54 +00002947 QualType class_type = class_pointer_type->getPointeeType();
2948
2949 if (log)
2950 {
2951 ASTDumper ast_dumper(self_type->GetClangFullType());
2952 log->Printf(" FEVD[%u] Adding type for $__lldb_objc_class: %s", current_id, ast_dumper.GetCString());
2953 }
2954
2955 TypeFromUser class_user_type (class_type.getAsOpaquePtr(),
Sean Callanana2868d42013-01-19 01:49:02 +00002956 self_type->GetClangAST());
2957
Sean Callananfa4fab72013-02-01 06:55:48 +00002958 AddOneType(context, class_user_type, current_id);
Jim Ingham5fdeed42012-10-30 23:35:54 +00002959
Jim Ingham5fdeed42012-10-30 23:35:54 +00002960 TypeFromUser self_user_type(self_type->GetClangFullType(),
2961 self_type->GetClangAST());
2962
2963 m_struct_vars->m_object_pointer_type = self_user_type;
2964 return;
2965 }
2966 }
Sean Callananc03bdd92012-02-08 03:45:08 +00002967 }
2968
Sean Callanan88972242011-10-12 01:39:28 +00002969 return;
2970 }
2971
2972 // any other $__lldb names should be weeded out now
2973 if (!::strncmp(name_unique_cstr, "$__lldb", sizeof("$__lldb") - 1))
2974 return;
2975
2976 do
2977 {
2978 if (!target)
2979 break;
2980
2981 ClangASTContext *scratch_clang_ast_context = target->GetScratchClangASTContext();
2982
2983 if (!scratch_clang_ast_context)
2984 break;
2985
2986 ASTContext *scratch_ast_context = scratch_clang_ast_context->getASTContext();
2987
2988 if (!scratch_ast_context)
2989 break;
2990
2991 TypeDecl *ptype_type_decl = m_parser_vars->m_persistent_vars->GetPersistentType(name);
2992
2993 if (!ptype_type_decl)
2994 break;
2995
Sean Callanan0eed0d42011-12-06 03:41:14 +00002996 Decl *parser_ptype_decl = m_ast_importer->CopyDecl(m_ast_context, scratch_ast_context, ptype_type_decl);
Sean Callanan88972242011-10-12 01:39:28 +00002997
2998 if (!parser_ptype_decl)
2999 break;
3000
3001 TypeDecl *parser_ptype_type_decl = dyn_cast<TypeDecl>(parser_ptype_decl);
3002
3003 if (!parser_ptype_type_decl)
3004 break;
3005
3006 if (log)
Sean Callananfb3e4302011-10-29 19:50:43 +00003007 log->Printf(" CEDM::FEVD[%u] Found persistent type %s", current_id, name.GetCString());
Sean Callanan88972242011-10-12 01:39:28 +00003008
3009 context.AddNamedDecl(parser_ptype_type_decl);
3010 } while (0);
3011
3012 ClangExpressionVariableSP pvar_sp(m_parser_vars->m_persistent_vars->GetVariable(name));
3013
3014 if (pvar_sp)
3015 {
Sean Callanan7dd98122011-10-14 20:34:21 +00003016 AddOneVariable(context, pvar_sp, current_id);
Sean Callanan88972242011-10-12 01:39:28 +00003017 return;
3018 }
3019
3020 const char *reg_name(&name.GetCString()[1]);
3021
Sean Callanan933693b2012-02-10 01:22:05 +00003022 if (m_parser_vars->m_exe_ctx.GetRegisterContext())
Sean Callanan88972242011-10-12 01:39:28 +00003023 {
Sean Callanan933693b2012-02-10 01:22:05 +00003024 const RegisterInfo *reg_info(m_parser_vars->m_exe_ctx.GetRegisterContext()->GetRegisterInfoByName(reg_name));
Sean Callananfb3e4302011-10-29 19:50:43 +00003025
Sean Callanan88972242011-10-12 01:39:28 +00003026 if (reg_info)
Sean Callanan35c7f982011-10-18 16:46:55 +00003027 {
3028 if (log)
Sean Callananfb3e4302011-10-29 19:50:43 +00003029 log->Printf(" CEDM::FEVD[%u] Found register %s", current_id, reg_info->name);
Sean Callanan35c7f982011-10-18 16:46:55 +00003030
Sean Callanan7dd98122011-10-14 20:34:21 +00003031 AddOneRegister(context, reg_info, current_id);
Sean Callanan35c7f982011-10-18 16:46:55 +00003032 }
Sean Callanan88972242011-10-12 01:39:28 +00003033 }
3034 }
3035 else
Sean Callanan8ade1042010-07-27 00:55:47 +00003036 {
Sean Callanan69b53412011-08-06 00:28:14 +00003037 ValueObjectSP valobj;
3038 VariableSP var;
3039 Error err;
3040
Sean Callanan88972242011-10-12 01:39:28 +00003041 if (frame && !namespace_decl)
Greg Clayton7b462cc2010-10-15 22:48:33 +00003042 {
Greg Claytonc14ee322011-09-22 04:58:26 +00003043 valobj = frame->GetValueForVariableExpressionPath(name_unique_cstr,
Sean Callanan503aa522011-10-12 00:12:34 +00003044 eNoDynamicValues,
Sean Callananaf776172013-02-12 07:56:36 +00003045 StackFrame::eExpressionPathOptionCheckPtrVsMember ||
3046 StackFrame::eExpressionPathOptionsAllowDirectIVarAccess ||
3047 StackFrame::eExpressionPathOptionsNoFragileObjcIvar ||
3048 StackFrame::eExpressionPathOptionsNoSyntheticChildren ||
3049 StackFrame::eExpressionPathOptionsNoSyntheticArrayRange,
Sean Callanan503aa522011-10-12 00:12:34 +00003050 var,
3051 err);
Sean Callanan3bfdaa22011-09-15 02:13:07 +00003052
3053 // If we found a variable in scope, no need to pull up function names
Sean Callanan9a028512012-08-09 00:50:26 +00003054 if (err.Success() && var)
Sean Callanan3bfdaa22011-09-15 02:13:07 +00003055 {
Sean Callanan0712f462011-11-29 22:03:21 +00003056 AddOneVariable(context, var, valobj, current_id);
Sean Callananca4e0fd2011-10-12 20:29:25 +00003057 context.m_found.variable = true;
Sean Callananefa7d1f2011-10-25 20:36:57 +00003058 return;
Sean Callanan3bfdaa22011-09-15 02:13:07 +00003059 }
Greg Clayton7b462cc2010-10-15 22:48:33 +00003060 }
Sean Callananfd1ba912011-12-10 04:03:38 +00003061
3062 if (target)
Sean Callanan3bfdaa22011-09-15 02:13:07 +00003063 {
Sean Callanan1fd3f4f2011-10-12 16:59:31 +00003064 var = FindGlobalVariable (*target,
Sean Callanan1a2c5382011-10-12 18:44:30 +00003065 module_sp,
Sean Callanan1fd3f4f2011-10-12 16:59:31 +00003066 name,
3067 &namespace_decl,
Greg Claytonc14ee322011-09-22 04:58:26 +00003068 NULL);
Sean Callanan3bfdaa22011-09-15 02:13:07 +00003069
3070 if (var)
3071 {
Sean Callanan9b3569b2011-12-10 03:12:34 +00003072 valobj = ValueObjectVariable::Create(target, var);
Sean Callanan0712f462011-11-29 22:03:21 +00003073 AddOneVariable(context, var, valobj, current_id);
Sean Callananca4e0fd2011-10-12 20:29:25 +00003074 context.m_found.variable = true;
Sean Callananfd1ba912011-12-10 04:03:38 +00003075 return;
Sean Callanan3bfdaa22011-09-15 02:13:07 +00003076 }
3077 }
3078
Sean Callananca4e0fd2011-10-12 20:29:25 +00003079 if (!context.m_found.variable)
Greg Clayton7b462cc2010-10-15 22:48:33 +00003080 {
Sean Callanan9df05fb2012-02-10 22:52:19 +00003081 const bool include_inlines = false;
Greg Clayton931180e2011-01-27 06:44:37 +00003082 const bool append = false;
Sean Callanan25ea08e2011-10-12 17:38:09 +00003083
Sean Callanan1a2c5382011-10-12 18:44:30 +00003084 if (namespace_decl && module_sp)
Sean Callanan25ea08e2011-10-12 17:38:09 +00003085 {
Sean Callanan3ae61792012-02-15 17:14:49 +00003086 const bool include_symbols = false;
3087
Sean Callanan1a2c5382011-10-12 18:44:30 +00003088 module_sp->FindFunctions(name,
3089 &namespace_decl,
3090 eFunctionNameTypeBase,
3091 include_symbols,
Sean Callanan9df05fb2012-02-10 22:52:19 +00003092 include_inlines,
Sean Callanan1a2c5382011-10-12 18:44:30 +00003093 append,
3094 sc_list);
Sean Callanan25ea08e2011-10-12 17:38:09 +00003095 }
Jim Ingham28eb5712012-10-12 17:34:26 +00003096 else if (target && !namespace_decl)
Sean Callanan25ea08e2011-10-12 17:38:09 +00003097 {
Sean Callanan3ae61792012-02-15 17:14:49 +00003098 const bool include_symbols = true;
3099
Sean Callanan308a3c52012-07-28 00:21:01 +00003100 // TODO Fix FindFunctions so that it doesn't return
3101 // instance methods for eFunctionNameTypeBase.
3102
Sean Callanan25ea08e2011-10-12 17:38:09 +00003103 target->GetImages().FindFunctions(name,
3104 eFunctionNameTypeBase,
3105 include_symbols,
Sean Callanan9df05fb2012-02-10 22:52:19 +00003106 include_inlines,
Sean Callanan25ea08e2011-10-12 17:38:09 +00003107 append,
3108 sc_list);
3109 }
3110
Sean Callanand9ca42a2011-05-08 02:21:26 +00003111 if (sc_list.GetSize())
Greg Clayton7b462cc2010-10-15 22:48:33 +00003112 {
Sean Callanand9ca42a2011-05-08 02:21:26 +00003113 Symbol *generic_symbol = NULL;
3114 Symbol *non_extern_symbol = NULL;
3115
3116 for (uint32_t index = 0, num_indices = sc_list.GetSize();
3117 index < num_indices;
3118 ++index)
Greg Clayton7b462cc2010-10-15 22:48:33 +00003119 {
Sean Callanand9ca42a2011-05-08 02:21:26 +00003120 SymbolContext sym_ctx;
3121 sc_list.GetContextAtIndex(index, sym_ctx);
3122
3123 if (sym_ctx.function)
3124 {
Sean Callanan308a3c52012-07-28 00:21:01 +00003125 clang::DeclContext *decl_ctx = sym_ctx.function->GetClangDeclContext();
3126
3127 // Filter out class/instance methods.
3128 if (dyn_cast<clang::ObjCMethodDecl>(decl_ctx))
3129 continue;
3130 if (dyn_cast<clang::CXXMethodDecl>(decl_ctx))
3131 continue;
3132
Sean Callanand9ca42a2011-05-08 02:21:26 +00003133 // TODO only do this if it's a C function; C++ functions may be
3134 // overloaded
Sean Callananca4e0fd2011-10-12 20:29:25 +00003135 if (!context.m_found.function_with_type_info)
Sean Callanan7dd98122011-10-14 20:34:21 +00003136 AddOneFunction(context, sym_ctx.function, NULL, current_id);
Sean Callananca4e0fd2011-10-12 20:29:25 +00003137 context.m_found.function_with_type_info = true;
3138 context.m_found.function = true;
Sean Callanand9ca42a2011-05-08 02:21:26 +00003139 }
3140 else if (sym_ctx.symbol)
3141 {
3142 if (sym_ctx.symbol->IsExternal())
3143 generic_symbol = sym_ctx.symbol;
3144 else
3145 non_extern_symbol = sym_ctx.symbol;
3146 }
Greg Clayton7b462cc2010-10-15 22:48:33 +00003147 }
Sean Callanand9ca42a2011-05-08 02:21:26 +00003148
Sean Callananca4e0fd2011-10-12 20:29:25 +00003149 if (!context.m_found.function_with_type_info)
Greg Clayton7b462cc2010-10-15 22:48:33 +00003150 {
Sean Callanand9ca42a2011-05-08 02:21:26 +00003151 if (generic_symbol)
Sean Callanan3bfdaa22011-09-15 02:13:07 +00003152 {
Sean Callanan7dd98122011-10-14 20:34:21 +00003153 AddOneFunction (context, NULL, generic_symbol, current_id);
Sean Callananca4e0fd2011-10-12 20:29:25 +00003154 context.m_found.function = true;
Sean Callanan3bfdaa22011-09-15 02:13:07 +00003155 }
Sean Callanand9ca42a2011-05-08 02:21:26 +00003156 else if (non_extern_symbol)
Sean Callanan3bfdaa22011-09-15 02:13:07 +00003157 {
Sean Callanan7dd98122011-10-14 20:34:21 +00003158 AddOneFunction (context, NULL, non_extern_symbol, current_id);
Sean Callananca4e0fd2011-10-12 20:29:25 +00003159 context.m_found.function = true;
Sean Callanan3bfdaa22011-09-15 02:13:07 +00003160 }
Sean Callanand9ca42a2011-05-08 02:21:26 +00003161 }
Greg Clayton7b462cc2010-10-15 22:48:33 +00003162 }
Sean Callanan3bfdaa22011-09-15 02:13:07 +00003163
Sean Callanan20a33d52012-03-06 20:53:06 +00003164 if (!context.m_found.variable && !namespace_decl)
Greg Clayton7b462cc2010-10-15 22:48:33 +00003165 {
Sean Callananca4e0fd2011-10-12 20:29:25 +00003166 // We couldn't find a non-symbol variable for this. Now we'll hunt for a generic
Sean Callanand9ca42a2011-05-08 02:21:26 +00003167 // data symbol, and -- if it is found -- treat it as a variable.
3168
Greg Clayton3d51b9f2012-11-27 01:52:16 +00003169 const Symbol *data_symbol = FindGlobalDataSymbol(*target, name);
Sean Callanand9ca42a2011-05-08 02:21:26 +00003170
3171 if (data_symbol)
Sean Callanan3bfdaa22011-09-15 02:13:07 +00003172 {
Sean Callanan7dd98122011-10-14 20:34:21 +00003173 AddOneGenericVariable(context, *data_symbol, current_id);
Sean Callananca4e0fd2011-10-12 20:29:25 +00003174 context.m_found.variable = true;
Sean Callanan3bfdaa22011-09-15 02:13:07 +00003175 }
Greg Clayton526e5af2010-11-13 03:52:47 +00003176 }
Sean Callanan3883b5a2010-09-07 21:49:41 +00003177 }
Sean Callananfb40b0d2011-10-27 02:06:03 +00003178 }
Sean Callanan6b4067c2010-07-17 00:43:37 +00003179}
Greg Claytona2721472011-06-25 00:44:06 +00003180
Sean Callanan75383bf2012-03-06 21:56:33 +00003181static clang_type_t
3182MaybePromoteToBlockPointerType
3183(
3184 ASTContext *ast_context,
3185 clang_type_t candidate_type
3186)
3187{
3188 if (!candidate_type)
3189 return candidate_type;
3190
3191 QualType candidate_qual_type = QualType::getFromOpaquePtr(candidate_type);
3192
3193 const PointerType *candidate_pointer_type = dyn_cast<PointerType>(candidate_qual_type);
3194
3195 if (!candidate_pointer_type)
3196 return candidate_type;
3197
3198 QualType pointee_qual_type = candidate_pointer_type->getPointeeType();
3199
3200 const RecordType *pointee_record_type = dyn_cast<RecordType>(pointee_qual_type);
3201
3202 if (!pointee_record_type)
3203 return candidate_type;
3204
3205 RecordDecl *pointee_record_decl = pointee_record_type->getDecl();
3206
3207 if (!pointee_record_decl->isRecord())
3208 return candidate_type;
3209
3210 if (!pointee_record_decl->getName().startswith(llvm::StringRef("__block_literal_")))
3211 return candidate_type;
3212
3213 QualType generic_function_type = ast_context->getFunctionNoProtoType(ast_context->UnknownAnyTy);
3214 QualType block_pointer_type = ast_context->getBlockPointerType(generic_function_type);
3215
3216 return block_pointer_type.getAsOpaquePtr();
3217}
3218
Sean Callanan6b4067c2010-07-17 00:43:37 +00003219Value *
Greg Clayton7b462cc2010-10-15 22:48:33 +00003220ClangExpressionDeclMap::GetVariableValue
3221(
Sean Callanan8e5b8b92011-10-13 00:09:20 +00003222 VariableSP &var,
Sean Callanancc427fa2011-07-30 02:42:06 +00003223 ASTContext *parser_ast_context,
Greg Clayton7b462cc2010-10-15 22:48:33 +00003224 TypeFromUser *user_type,
3225 TypeFromParser *parser_type
3226)
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003227{
Greg Clayton2d4edfb2010-11-06 01:53:30 +00003228 lldb::LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_EXPRESSIONS));
Sean Callananf06ba8d2010-06-23 00:47:48 +00003229
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003230 Type *var_type = var->GetType();
3231
3232 if (!var_type)
3233 {
Sean Callananea22d422010-07-16 00:09:46 +00003234 if (log)
3235 log->PutCString("Skipped a definition because it has no type");
Sean Callanan6b4067c2010-07-17 00:43:37 +00003236 return NULL;
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003237 }
3238
Greg Claytonf4ecaa52011-02-16 23:00:21 +00003239 clang_type_t var_opaque_type = var_type->GetClangFullType();
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003240
3241 if (!var_opaque_type)
3242 {
Sean Callananea22d422010-07-16 00:09:46 +00003243 if (log)
3244 log->PutCString("Skipped a definition because it has no Clang type");
Sean Callanan6b4067c2010-07-17 00:43:37 +00003245 return NULL;
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003246 }
3247
Sean Callanancc427fa2011-07-30 02:42:06 +00003248 ASTContext *ast = var_type->GetClangASTContext().getASTContext();
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003249
Greg Clayton6beaaa62011-01-17 03:46:26 +00003250 if (!ast)
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003251 {
Sean Callananea22d422010-07-16 00:09:46 +00003252 if (log)
3253 log->PutCString("There is no AST context for the current execution context");
Sean Callanan6b4067c2010-07-17 00:43:37 +00003254 return NULL;
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003255 }
Sean Callanan75383bf2012-03-06 21:56:33 +00003256
Enrico Granata7f3296a2012-03-30 16:58:37 +00003257 // commented out because of <rdar://problem/11024417>
3258 //var_opaque_type = MaybePromoteToBlockPointerType (ast, var_opaque_type);
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003259
Sean Callanan6b4067c2010-07-17 00:43:37 +00003260 DWARFExpression &var_location_expr = var->LocationExpression();
3261
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003262 std::auto_ptr<Value> var_location(new Value);
3263
Greg Clayton016a95e2010-09-14 02:20:48 +00003264 lldb::addr_t loclist_base_load_addr = LLDB_INVALID_ADDRESS;
3265
Sean Callanan933693b2012-02-10 01:22:05 +00003266 Target *target = m_parser_vars->m_exe_ctx.GetTargetPtr();
Greg Claytonc14ee322011-09-22 04:58:26 +00003267
Greg Clayton016a95e2010-09-14 02:20:48 +00003268 if (var_location_expr.IsLocationList())
3269 {
3270 SymbolContext var_sc;
3271 var->CalculateSymbolContext (&var_sc);
Greg Claytonc14ee322011-09-22 04:58:26 +00003272 loclist_base_load_addr = var_sc.function->GetAddressRange().GetBaseAddress().GetLoadAddress (target);
Greg Clayton016a95e2010-09-14 02:20:48 +00003273 }
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003274 Error err;
3275
Sean Callanan7b5805d2013-01-18 21:20:51 +00003276 if (var->GetLocationIsConstantValueData())
3277 {
3278 DataExtractor const_value_extractor;
3279
3280 if (var_location_expr.GetExpressionData(const_value_extractor))
3281 {
3282 var_location->operator=(Value(const_value_extractor.GetDataStart(), const_value_extractor.GetByteSize()));
3283 var_location->SetValueType(Value::eValueTypeHostAddress);
3284 }
3285 else
3286 {
3287 if (log)
3288 log->Printf("Error evaluating constant variable: %s", err.AsCString());
3289 return NULL;
3290 }
3291 }
3292 else if (!var_location_expr.Evaluate(&m_parser_vars->m_exe_ctx, ast, NULL, NULL, NULL, loclist_base_load_addr, NULL, *var_location.get(), &err))
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003293 {
Sean Callananea22d422010-07-16 00:09:46 +00003294 if (log)
3295 log->Printf("Error evaluating location: %s", err.AsCString());
Sean Callanan6b4067c2010-07-17 00:43:37 +00003296 return NULL;
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003297 }
Greg Clayton6beaaa62011-01-17 03:46:26 +00003298
Sean Callanan77eaf442011-07-08 00:39:14 +00003299 void *type_to_use = NULL;
Sean Callanan6b4067c2010-07-17 00:43:37 +00003300
Sean Callanan1d180662010-07-20 23:31:16 +00003301 if (parser_ast_context)
3302 {
Greg Clayton6beaaa62011-01-17 03:46:26 +00003303 type_to_use = GuardedCopyType(parser_ast_context, ast, var_opaque_type);
Sean Callanan1d180662010-07-20 23:31:16 +00003304
Sean Callanana3aa0cf2010-11-20 02:19:29 +00003305 if (!type_to_use)
3306 {
3307 if (log)
3308 log->Printf("Couldn't copy a variable's type into the parser's AST context");
3309
3310 return NULL;
3311 }
3312
Sean Callanan1d180662010-07-20 23:31:16 +00003313 if (parser_type)
3314 *parser_type = TypeFromParser(type_to_use, parser_ast_context);
3315 }
Sean Callanan6b4067c2010-07-17 00:43:37 +00003316 else
3317 type_to_use = var_opaque_type;
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003318
3319 if (var_location.get()->GetContextType() == Value::eContextTypeInvalid)
Greg Clayton526e5af2010-11-13 03:52:47 +00003320 var_location.get()->SetContext(Value::eContextTypeClangType, type_to_use);
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003321
3322 if (var_location.get()->GetValueType() == Value::eValueTypeFileAddress)
3323 {
3324 SymbolContext var_sc;
3325 var->CalculateSymbolContext(&var_sc);
Sean Callanan6b4067c2010-07-17 00:43:37 +00003326
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003327 if (!var_sc.module_sp)
Sean Callanan6b4067c2010-07-17 00:43:37 +00003328 return NULL;
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003329
3330 ObjectFile *object_file = var_sc.module_sp->GetObjectFile();
3331
3332 if (!object_file)
Sean Callanan6b4067c2010-07-17 00:43:37 +00003333 return NULL;
3334
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003335 Address so_addr(var_location->GetScalar().ULongLong(), object_file->GetSectionList());
3336
Greg Claytonc14ee322011-09-22 04:58:26 +00003337 lldb::addr_t load_addr = so_addr.GetLoadAddress(target);
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003338
Sean Callanan3bfdaa22011-09-15 02:13:07 +00003339 if (load_addr != LLDB_INVALID_ADDRESS)
3340 {
3341 var_location->GetScalar() = load_addr;
3342 var_location->SetValueType(Value::eValueTypeLoadAddress);
3343 }
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003344 }
3345
Sean Callanan1d180662010-07-20 23:31:16 +00003346 if (user_type)
Greg Clayton6beaaa62011-01-17 03:46:26 +00003347 *user_type = TypeFromUser(var_opaque_type, ast);
Sean Callanan6b4067c2010-07-17 00:43:37 +00003348
3349 return var_location.release();
3350}
3351
3352void
Sean Callanan0712f462011-11-29 22:03:21 +00003353ClangExpressionDeclMap::AddOneVariable (NameSearchContext &context, VariableSP var, ValueObjectSP valobj, unsigned int current_id)
Sean Callanan6b4067c2010-07-17 00:43:37 +00003354{
Sean Callanan979f74d2010-12-03 01:38:59 +00003355 assert (m_parser_vars.get());
3356
Greg Clayton2d4edfb2010-11-06 01:53:30 +00003357 lldb::LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_EXPRESSIONS));
Sean Callanan3bfdaa22011-09-15 02:13:07 +00003358
Sean Callanan1d180662010-07-20 23:31:16 +00003359 TypeFromUser ut;
3360 TypeFromParser pt;
Sean Callanan6b4067c2010-07-17 00:43:37 +00003361
Sean Callanan933693b2012-02-10 01:22:05 +00003362 Value *var_location = GetVariableValue (var,
Sean Callananeddeb3b2011-10-28 23:38:38 +00003363 m_ast_context,
Greg Clayton7b462cc2010-10-15 22:48:33 +00003364 &ut,
3365 &pt);
Sean Callanan6b4067c2010-07-17 00:43:37 +00003366
Sean Callanancf128622012-03-15 01:53:17 +00003367 clang::QualType parser_opaque_type = QualType::getFromOpaquePtr(pt.GetOpaqueQualType());
3368
Sean Callanane2d47482012-03-21 17:13:20 +00003369 if (parser_opaque_type.isNull())
3370 return;
3371
Sean Callanancf128622012-03-15 01:53:17 +00003372 if (const clang::Type *parser_type = parser_opaque_type.getTypePtr())
3373 {
3374 if (const TagType *tag_type = dyn_cast<TagType>(parser_type))
3375 CompleteType(tag_type->getDecl());
3376 }
3377
Sean Callanana3aa0cf2010-11-20 02:19:29 +00003378 if (!var_location)
3379 return;
3380
Sean Callanan98298012011-10-27 19:41:13 +00003381 NamedDecl *var_decl;
3382
3383 bool is_reference = ClangASTContext::IsReferenceType(pt.GetOpaqueQualType());
3384
3385 if (is_reference)
3386 var_decl = context.AddVarDecl(pt.GetOpaqueQualType());
3387 else
3388 var_decl = context.AddVarDecl(ClangASTContext::CreateLValueReferenceType(pt.GetASTContext(), pt.GetOpaqueQualType()));
3389
Greg Clayton7b462cc2010-10-15 22:48:33 +00003390 std::string decl_name(context.m_decl_name.getAsString());
Greg Clayton8b2fe6d2010-12-14 02:59:59 +00003391 ConstString entity_name(decl_name.c_str());
Sean Callanan0712f462011-11-29 22:03:21 +00003392 ClangExpressionVariableSP entity(m_found_entities.CreateVariable (valobj));
3393
Greg Clayton8b2fe6d2010-12-14 02:59:59 +00003394 assert (entity.get());
Sean Callanan3c495c12013-01-15 23:29:36 +00003395 entity->EnableParserVars(GetParserID());
3396 ClangExpressionVariable::ParserVars *parser_vars = entity->GetParserVars(GetParserID());
3397 parser_vars->m_parser_type = pt;
3398 parser_vars->m_named_decl = var_decl;
3399 parser_vars->m_llvm_value = NULL;
3400 parser_vars->m_lldb_value = var_location;
3401 parser_vars->m_lldb_var = var;
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003402
Sean Callanan98298012011-10-27 19:41:13 +00003403 if (is_reference)
3404 entity->m_flags |= ClangExpressionVariable::EVTypeIsReference;
3405
Sean Callananea22d422010-07-16 00:09:46 +00003406 if (log)
Greg Clayton7b462cc2010-10-15 22:48:33 +00003407 {
Sean Callanan82695d62011-11-07 23:32:52 +00003408 ASTDumper orig_dumper(ut.GetOpaqueQualType());
Greg Clayton64bc6ca2011-10-20 00:47:21 +00003409 ASTDumper ast_dumper(var_decl);
Sean Callanan82695d62011-11-07 23:32:52 +00003410 log->Printf(" CEDM::FEVD[%u] Found variable %s, returned %s (original %s)", current_id, decl_name.c_str(), ast_dumper.GetCString(), orig_dumper.GetCString());
Greg Clayton7b462cc2010-10-15 22:48:33 +00003411 }
Sean Callanan468574b2010-06-22 23:46:24 +00003412}
3413
3414void
Sean Callanan2235f322010-08-11 03:57:18 +00003415ClangExpressionDeclMap::AddOneVariable(NameSearchContext &context,
Sean Callanan7dd98122011-10-14 20:34:21 +00003416 ClangExpressionVariableSP &pvar_sp,
3417 unsigned int current_id)
Sean Callanan2235f322010-08-11 03:57:18 +00003418{
Greg Clayton2d4edfb2010-11-06 01:53:30 +00003419 lldb::LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_EXPRESSIONS));
Sean Callanan823bb4c2010-08-30 22:17:16 +00003420
Greg Clayton8b2fe6d2010-12-14 02:59:59 +00003421 TypeFromUser user_type (pvar_sp->GetTypeFromUser());
Sean Callanan2235f322010-08-11 03:57:18 +00003422
Sean Callananeddeb3b2011-10-28 23:38:38 +00003423 TypeFromParser parser_type (GuardedCopyType(m_ast_context,
Greg Clayton8b2fe6d2010-12-14 02:59:59 +00003424 user_type.GetASTContext(),
3425 user_type.GetOpaqueQualType()),
Sean Callananeddeb3b2011-10-28 23:38:38 +00003426 m_ast_context);
Sean Callanan2235f322010-08-11 03:57:18 +00003427
Sean Callanane0a64f72011-12-01 21:04:37 +00003428 if (!parser_type.GetOpaqueQualType())
3429 {
3430 if (log)
3431 log->Printf(" CEDM::FEVD[%u] Couldn't import type for pvar %s", current_id, pvar_sp->GetName().GetCString());
3432 return;
3433 }
3434
Sean Callanan92adcac2011-01-13 08:53:35 +00003435 NamedDecl *var_decl = context.AddVarDecl(ClangASTContext::CreateLValueReferenceType(parser_type.GetASTContext(), parser_type.GetOpaqueQualType()));
Sean Callanan64dfc9a2010-08-23 23:09:38 +00003436
Sean Callanan3c495c12013-01-15 23:29:36 +00003437 pvar_sp->EnableParserVars(GetParserID());
3438 ClangExpressionVariable::ParserVars *parser_vars = pvar_sp->GetParserVars(GetParserID());
3439 parser_vars->m_parser_type = parser_type;
3440 parser_vars->m_named_decl = var_decl;
3441 parser_vars->m_llvm_value = NULL;
3442 parser_vars->m_lldb_value = NULL;
Sean Callanan823bb4c2010-08-30 22:17:16 +00003443
3444 if (log)
Sean Callanan530782942010-11-01 23:22:47 +00003445 {
Greg Clayton64bc6ca2011-10-20 00:47:21 +00003446 ASTDumper ast_dumper(var_decl);
Sean Callananfb3e4302011-10-29 19:50:43 +00003447 log->Printf(" CEDM::FEVD[%u] Added pvar %s, returned %s", current_id, pvar_sp->GetName().GetCString(), ast_dumper.GetCString());
Sean Callanan530782942010-11-01 23:22:47 +00003448 }
Sean Callanan2235f322010-08-11 03:57:18 +00003449}
3450
Sean Callanan348b5892010-11-30 00:27:43 +00003451void
Sean Callanand9ca42a2011-05-08 02:21:26 +00003452ClangExpressionDeclMap::AddOneGenericVariable(NameSearchContext &context,
Greg Clayton3d51b9f2012-11-27 01:52:16 +00003453 const Symbol &symbol,
Sean Callanan7dd98122011-10-14 20:34:21 +00003454 unsigned int current_id)
Sean Callanand9ca42a2011-05-08 02:21:26 +00003455{
3456 assert(m_parser_vars.get());
3457
3458 lldb::LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_EXPRESSIONS));
3459
Sean Callanan933693b2012-02-10 01:22:05 +00003460 Target *target = m_parser_vars->m_exe_ctx.GetTargetPtr();
Greg Claytonc14ee322011-09-22 04:58:26 +00003461
3462 if (target == NULL)
3463 return;
3464
3465 ASTContext *scratch_ast_context = target->GetScratchClangASTContext()->getASTContext();
Sean Callanand9ca42a2011-05-08 02:21:26 +00003466
Greg Clayton68510992012-12-14 00:26:21 +00003467 TypeFromUser user_type (ClangASTContext::CreateLValueReferenceType(scratch_ast_context, ClangASTContext::GetVoidPtrType(scratch_ast_context, false)),
Sean Callanand9ca42a2011-05-08 02:21:26 +00003468 scratch_ast_context);
3469
Greg Clayton68510992012-12-14 00:26:21 +00003470 TypeFromParser parser_type (ClangASTContext::CreateLValueReferenceType(m_ast_context, ClangASTContext::GetVoidPtrType(m_ast_context, false)),
Sean Callananeddeb3b2011-10-28 23:38:38 +00003471 m_ast_context);
Sean Callanand9ca42a2011-05-08 02:21:26 +00003472
Sean Callanan77502262011-05-12 23:54:16 +00003473 NamedDecl *var_decl = context.AddVarDecl(parser_type.GetOpaqueQualType());
Sean Callanand9ca42a2011-05-08 02:21:26 +00003474
3475 std::string decl_name(context.m_decl_name.getAsString());
3476 ConstString entity_name(decl_name.c_str());
Sean Callanan933693b2012-02-10 01:22:05 +00003477 ClangExpressionVariableSP entity(m_found_entities.CreateVariable (m_parser_vars->m_exe_ctx.GetBestExecutionContextScope (),
Sean Callanand9ca42a2011-05-08 02:21:26 +00003478 entity_name,
3479 user_type,
Sean Callanan3bfdaa22011-09-15 02:13:07 +00003480 m_parser_vars->m_target_info.byte_order,
3481 m_parser_vars->m_target_info.address_byte_size));
Sean Callanand9ca42a2011-05-08 02:21:26 +00003482 assert (entity.get());
Sean Callanand9ca42a2011-05-08 02:21:26 +00003483
3484 std::auto_ptr<Value> symbol_location(new Value);
3485
Greg Clayton3d51b9f2012-11-27 01:52:16 +00003486 const Address &symbol_address = symbol.GetAddress();
Greg Claytonc14ee322011-09-22 04:58:26 +00003487 lldb::addr_t symbol_load_addr = symbol_address.GetLoadAddress(target);
Sean Callanand9ca42a2011-05-08 02:21:26 +00003488
3489 symbol_location->SetContext(Value::eContextTypeClangType, user_type.GetOpaqueQualType());
3490 symbol_location->GetScalar() = symbol_load_addr;
3491 symbol_location->SetValueType(Value::eValueTypeLoadAddress);
3492
Sean Callanan3c495c12013-01-15 23:29:36 +00003493 entity->EnableParserVars(GetParserID());
3494 ClangExpressionVariable::ParserVars *parser_vars = entity->GetParserVars(GetParserID());
3495 parser_vars->m_parser_type = parser_type;
3496 parser_vars->m_named_decl = var_decl;
3497 parser_vars->m_llvm_value = NULL;
3498 parser_vars->m_lldb_value = symbol_location.release();
3499 parser_vars->m_lldb_sym = &symbol;
Sean Callanand9ca42a2011-05-08 02:21:26 +00003500
3501 if (log)
3502 {
Greg Clayton64bc6ca2011-10-20 00:47:21 +00003503 ASTDumper ast_dumper(var_decl);
Sean Callanand9ca42a2011-05-08 02:21:26 +00003504
Sean Callananfb3e4302011-10-29 19:50:43 +00003505 log->Printf(" CEDM::FEVD[%u] Found variable %s, returned %s", current_id, decl_name.c_str(), ast_dumper.GetCString());
Sean Callanand9ca42a2011-05-08 02:21:26 +00003506 }
3507}
3508
Sean Callanan77502262011-05-12 23:54:16 +00003509bool
3510ClangExpressionDeclMap::ResolveUnknownTypes()
3511{
3512 lldb::LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_EXPRESSIONS));
Sean Callanan933693b2012-02-10 01:22:05 +00003513 Target *target = m_parser_vars->m_exe_ctx.GetTargetPtr();
Greg Claytonc14ee322011-09-22 04:58:26 +00003514
3515 ASTContext *scratch_ast_context = target->GetScratchClangASTContext()->getASTContext();
Sean Callanan77502262011-05-12 23:54:16 +00003516
3517 for (size_t index = 0, num_entities = m_found_entities.GetSize();
3518 index < num_entities;
3519 ++index)
3520 {
3521 ClangExpressionVariableSP entity = m_found_entities.GetVariableAtIndex(index);
3522
Sean Callanan3c495c12013-01-15 23:29:36 +00003523 ClangExpressionVariable::ParserVars *parser_vars = entity->GetParserVars(GetParserID());
3524
Sean Callanan77502262011-05-12 23:54:16 +00003525 if (entity->m_flags & ClangExpressionVariable::EVUnknownType)
3526 {
Sean Callanan3c495c12013-01-15 23:29:36 +00003527 const NamedDecl *named_decl = parser_vars->m_named_decl;
Sean Callanan77502262011-05-12 23:54:16 +00003528 const VarDecl *var_decl = dyn_cast<VarDecl>(named_decl);
3529
3530 if (!var_decl)
3531 {
3532 if (log)
3533 log->Printf("Entity of unknown type does not have a VarDecl");
3534 return false;
3535 }
3536
3537 if (log)
3538 {
Greg Clayton64bc6ca2011-10-20 00:47:21 +00003539 ASTDumper ast_dumper(const_cast<VarDecl*>(var_decl));
3540 log->Printf("Variable of unknown type now has Decl %s", ast_dumper.GetCString());
Sean Callanan77502262011-05-12 23:54:16 +00003541 }
3542
3543 QualType var_type = var_decl->getType();
3544 TypeFromParser parser_type(var_type.getAsOpaquePtr(), &var_decl->getASTContext());
3545
Sean Callanan00f43622011-11-18 03:28:09 +00003546 lldb::clang_type_t copied_type = m_ast_importer->CopyType(scratch_ast_context, &var_decl->getASTContext(), var_type.getAsOpaquePtr());
Sean Callanan77502262011-05-12 23:54:16 +00003547
Sean Callanane0a64f72011-12-01 21:04:37 +00003548 if (!copied_type)
3549 {
3550 if (log)
3551 log->Printf("ClangExpressionDeclMap::ResolveUnknownType - Couldn't import the type for a variable");
3552
Jim Inghamf94e1792012-08-11 00:35:26 +00003553 return (bool) lldb::ClangExpressionVariableSP();
Sean Callanane0a64f72011-12-01 21:04:37 +00003554 }
3555
Sean Callanan77502262011-05-12 23:54:16 +00003556 TypeFromUser user_type(copied_type, scratch_ast_context);
3557
Sean Callanan3c495c12013-01-15 23:29:36 +00003558 parser_vars->m_lldb_value->SetContext(Value::eContextTypeClangType, user_type.GetOpaqueQualType());
3559 parser_vars->m_parser_type = parser_type;
Sean Callanan77502262011-05-12 23:54:16 +00003560
3561 entity->SetClangAST(user_type.GetASTContext());
3562 entity->SetClangType(user_type.GetOpaqueQualType());
3563
3564 entity->m_flags &= ~(ClangExpressionVariable::EVUnknownType);
3565 }
3566 }
3567
3568 return true;
3569}
3570
Sean Callanand9ca42a2011-05-08 02:21:26 +00003571void
Greg Clayton8b2fe6d2010-12-14 02:59:59 +00003572ClangExpressionDeclMap::AddOneRegister (NameSearchContext &context,
Sean Callanan7dd98122011-10-14 20:34:21 +00003573 const RegisterInfo *reg_info,
3574 unsigned int current_id)
Sean Callanan348b5892010-11-30 00:27:43 +00003575{
3576 lldb::LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_EXPRESSIONS));
3577
Sean Callananeddeb3b2011-10-28 23:38:38 +00003578 void *ast_type = ClangASTContext::GetBuiltinTypeForEncodingAndBitSize(m_ast_context,
Sean Callanan348b5892010-11-30 00:27:43 +00003579 reg_info->encoding,
3580 reg_info->byte_size * 8);
3581
3582 if (!ast_type)
3583 {
Johnny Chene95fcf72011-08-09 22:52:27 +00003584 if (log)
Sean Callanan7dd98122011-10-14 20:34:21 +00003585 log->Printf(" Tried to add a type for %s, but couldn't get one", context.m_decl_name.getAsString().c_str());
Sean Callanan348b5892010-11-30 00:27:43 +00003586 return;
3587 }
3588
Greg Clayton8b2fe6d2010-12-14 02:59:59 +00003589 TypeFromParser parser_type (ast_type,
Sean Callananeddeb3b2011-10-28 23:38:38 +00003590 m_ast_context);
Sean Callanan348b5892010-11-30 00:27:43 +00003591
3592 NamedDecl *var_decl = context.AddVarDecl(parser_type.GetOpaqueQualType());
3593
Sean Callanan933693b2012-02-10 01:22:05 +00003594 ClangExpressionVariableSP entity(m_found_entities.CreateVariable (m_parser_vars->m_exe_ctx.GetBestExecutionContextScope(),
Sean Callanan3bfdaa22011-09-15 02:13:07 +00003595 m_parser_vars->m_target_info.byte_order,
3596 m_parser_vars->m_target_info.address_byte_size));
Greg Clayton8b2fe6d2010-12-14 02:59:59 +00003597 assert (entity.get());
Sean Callanan348b5892010-11-30 00:27:43 +00003598 std::string decl_name(context.m_decl_name.getAsString());
Greg Clayton8b2fe6d2010-12-14 02:59:59 +00003599 entity->SetName (ConstString (decl_name.c_str()));
3600 entity->SetRegisterInfo (reg_info);
Sean Callanan3c495c12013-01-15 23:29:36 +00003601 entity->EnableParserVars(GetParserID());
3602 ClangExpressionVariable::ParserVars *parser_vars = entity->GetParserVars(GetParserID());
3603 parser_vars->m_parser_type = parser_type;
3604 parser_vars->m_named_decl = var_decl;
3605 parser_vars->m_llvm_value = NULL;
3606 parser_vars->m_lldb_value = NULL;
Sean Callananf673e762012-02-15 01:40:39 +00003607 entity->m_flags |= ClangExpressionVariable::EVBareRegister;
Sean Callanan348b5892010-11-30 00:27:43 +00003608
Sean Callananf673e762012-02-15 01:40:39 +00003609 if (log)
Sean Callanan348b5892010-11-30 00:27:43 +00003610 {
Greg Clayton64bc6ca2011-10-20 00:47:21 +00003611 ASTDumper ast_dumper(var_decl);
Sean Callananfb3e4302011-10-29 19:50:43 +00003612 log->Printf(" CEDM::FEVD[%d] Added register %s, returned %s", current_id, context.m_decl_name.getAsString().c_str(), ast_dumper.GetCString());
Sean Callanan348b5892010-11-30 00:27:43 +00003613 }
3614}
3615
Sean Callanan2235f322010-08-11 03:57:18 +00003616void
Greg Clayton3f5c08f2011-05-18 22:01:49 +00003617ClangExpressionDeclMap::AddOneFunction (NameSearchContext &context,
3618 Function* fun,
Sean Callanan7dd98122011-10-14 20:34:21 +00003619 Symbol* symbol,
3620 unsigned int current_id)
Sean Callanan468574b2010-06-22 23:46:24 +00003621{
Sean Callanan979f74d2010-12-03 01:38:59 +00003622 assert (m_parser_vars.get());
3623
Greg Clayton2d4edfb2010-11-06 01:53:30 +00003624 lldb::LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_EXPRESSIONS));
Sean Callanan468574b2010-06-22 23:46:24 +00003625
Sean Callanan77eaf442011-07-08 00:39:14 +00003626 NamedDecl *fun_decl = NULL;
Sean Callanan468574b2010-06-22 23:46:24 +00003627 std::auto_ptr<Value> fun_location(new Value);
Sean Callanan77eaf442011-07-08 00:39:14 +00003628 const Address *fun_address = NULL;
Sean Callanan468574b2010-06-22 23:46:24 +00003629
Sean Callanan8ade1042010-07-27 00:55:47 +00003630 // only valid for Functions, not for Symbols
3631 void *fun_opaque_type = NULL;
Sean Callanancc427fa2011-07-30 02:42:06 +00003632 ASTContext *fun_ast_context = NULL;
Matt Kopec00049b82013-02-27 20:13:38 +00003633
3634 bool is_indirect_function = false;
3635
Sean Callanan8ade1042010-07-27 00:55:47 +00003636 if (fun)
3637 {
3638 Type *fun_type = fun->GetType();
3639
3640 if (!fun_type)
3641 {
3642 if (log)
Sean Callanan7dd98122011-10-14 20:34:21 +00003643 log->PutCString(" Skipped a function because it has no type");
Sean Callanan8ade1042010-07-27 00:55:47 +00003644 return;
3645 }
3646
Greg Claytonf4ecaa52011-02-16 23:00:21 +00003647 fun_opaque_type = fun_type->GetClangFullType();
Sean Callanan8ade1042010-07-27 00:55:47 +00003648
3649 if (!fun_opaque_type)
3650 {
3651 if (log)
Sean Callanan7dd98122011-10-14 20:34:21 +00003652 log->PutCString(" Skipped a function because it has no Clang type");
Sean Callanan8ade1042010-07-27 00:55:47 +00003653 return;
3654 }
3655
3656 fun_address = &fun->GetAddressRange().GetBaseAddress();
3657
Greg Clayton6beaaa62011-01-17 03:46:26 +00003658 fun_ast_context = fun_type->GetClangASTContext().getASTContext();
Sean Callananeddeb3b2011-10-28 23:38:38 +00003659 void *copied_type = GuardedCopyType(m_ast_context, fun_ast_context, fun_opaque_type);
Greg Clayton64bc6ca2011-10-20 00:47:21 +00003660 if (copied_type)
3661 {
3662 fun_decl = context.AddFunDecl(copied_type);
3663 }
3664 else
3665 {
3666 // We failed to copy the type we found
3667 if (log)
3668 {
Daniel Malead01b2952012-11-29 21:49:15 +00003669 log->Printf (" Failed to import the function type '%s' {0x%8.8" PRIx64 "} into the expression parser AST contenxt",
Greg Clayton64bc6ca2011-10-20 00:47:21 +00003670 fun_type->GetName().GetCString(),
3671 fun_type->GetID());
3672 }
Sean Callananed8d58f2011-11-16 00:40:13 +00003673
3674 return;
Greg Clayton64bc6ca2011-10-20 00:47:21 +00003675 }
Sean Callanan8ade1042010-07-27 00:55:47 +00003676 }
3677 else if (symbol)
3678 {
Greg Claytone7612132012-03-07 21:03:09 +00003679 fun_address = &symbol->GetAddress();
Sean Callanan8ade1042010-07-27 00:55:47 +00003680 fun_decl = context.AddGenericFunDecl();
Matt Kopec00049b82013-02-27 20:13:38 +00003681 is_indirect_function = symbol->IsIndirect();
Sean Callanan8ade1042010-07-27 00:55:47 +00003682 }
3683 else
3684 {
3685 if (log)
Sean Callanan7dd98122011-10-14 20:34:21 +00003686 log->PutCString(" AddOneFunction called with no function and no symbol");
Sean Callanan8ade1042010-07-27 00:55:47 +00003687 return;
3688 }
3689
Sean Callanan933693b2012-02-10 01:22:05 +00003690 Target *target = m_parser_vars->m_exe_ctx.GetTargetPtr();
Greg Claytonc14ee322011-09-22 04:58:26 +00003691
Matt Kopec00049b82013-02-27 20:13:38 +00003692 lldb::addr_t load_addr = fun_address->GetCallableLoadAddress(target, is_indirect_function);
Sean Callanan468574b2010-06-22 23:46:24 +00003693 fun_location->SetValueType(Value::eValueTypeLoadAddress);
3694 fun_location->GetScalar() = load_addr;
3695
Sean Callanan933693b2012-02-10 01:22:05 +00003696 ClangExpressionVariableSP entity(m_found_entities.CreateVariable (m_parser_vars->m_exe_ctx.GetBestExecutionContextScope (),
Sean Callanan3bfdaa22011-09-15 02:13:07 +00003697 m_parser_vars->m_target_info.byte_order,
3698 m_parser_vars->m_target_info.address_byte_size));
Greg Clayton8b2fe6d2010-12-14 02:59:59 +00003699 assert (entity.get());
Greg Clayton7b462cc2010-10-15 22:48:33 +00003700 std::string decl_name(context.m_decl_name.getAsString());
Greg Clayton8b2fe6d2010-12-14 02:59:59 +00003701 entity->SetName(ConstString(decl_name.c_str()));
3702 entity->SetClangType (fun_opaque_type);
3703 entity->SetClangAST (fun_ast_context);
Sean Callanan468574b2010-06-22 23:46:24 +00003704
Sean Callanan3c495c12013-01-15 23:29:36 +00003705 entity->EnableParserVars(GetParserID());
3706 ClangExpressionVariable::ParserVars *parser_vars = entity->GetParserVars(GetParserID());
3707 parser_vars->m_named_decl = fun_decl;
3708 parser_vars->m_llvm_value = NULL;
3709 parser_vars->m_lldb_value = fun_location.release();
Sean Callanan64dfc9a2010-08-23 23:09:38 +00003710
Sean Callananea22d422010-07-16 00:09:46 +00003711 if (log)
Greg Clayton7b462cc2010-10-15 22:48:33 +00003712 {
Greg Clayton64bc6ca2011-10-20 00:47:21 +00003713 ASTDumper ast_dumper(fun_decl);
Sean Callanan530782942010-11-01 23:22:47 +00003714
Sean Callanan308a3c52012-07-28 00:21:01 +00003715 StreamString ss;
3716
3717 fun_address->Dump(&ss, m_parser_vars->m_exe_ctx.GetBestExecutionContextScope(), Address::DumpStyleResolvedDescription);
3718
3719 log->Printf(" CEDM::FEVD[%u] Found %s function %s (description %s), returned %s",
Sean Callanan7dd98122011-10-14 20:34:21 +00003720 current_id,
3721 (fun ? "specific" : "generic"),
Sean Callanan308a3c52012-07-28 00:21:01 +00003722 decl_name.c_str(),
3723 ss.GetData(),
Greg Clayton64bc6ca2011-10-20 00:47:21 +00003724 ast_dumper.GetCString());
Greg Clayton7b462cc2010-10-15 22:48:33 +00003725 }
Chris Lattner30fdc8d2010-06-08 16:52:24 +00003726}
Sean Callanan5666b672010-08-04 01:02:13 +00003727
Sean Callananfa4fab72013-02-01 06:55:48 +00003728TypeFromParser
3729ClangExpressionDeclMap::CopyClassType(TypeFromUser &ut,
3730 unsigned int current_id)
Sean Callanan5666b672010-08-04 01:02:13 +00003731{
Sean Callananeddeb3b2011-10-28 23:38:38 +00003732 ASTContext *parser_ast_context = m_ast_context;
Sean Callanancc427fa2011-07-30 02:42:06 +00003733 ASTContext *user_ast_context = ut.GetASTContext();
Sean Callananfa4fab72013-02-01 06:55:48 +00003734
Sean Callanan6abfabf2010-11-19 20:20:02 +00003735 void *copied_type = GuardedCopyType(parser_ast_context, user_ast_context, ut.GetOpaqueQualType());
Sean Callanane0a64f72011-12-01 21:04:37 +00003736
3737 if (!copied_type)
3738 {
3739 lldb::LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_EXPRESSIONS));
Sean Callanane0a64f72011-12-01 21:04:37 +00003740
Sean Callananfa4fab72013-02-01 06:55:48 +00003741 if (log)
3742 log->Printf("ClangExpressionDeclMap::CopyClassType - Couldn't import the type");
3743
3744 return TypeFromParser();
Sean Callanane0a64f72011-12-01 21:04:37 +00003745 }
Sean Callananfa4fab72013-02-01 06:55:48 +00003746
3747 if (ClangASTContext::IsAggregateType(copied_type) && ClangASTContext::GetCompleteType (parser_ast_context, copied_type))
Sean Callananfc55f5d2010-09-21 00:44:12 +00003748 {
3749 void *args[1];
3750
3751 args[0] = ClangASTContext::GetVoidPtrType(parser_ast_context, false);
3752
Sean Callananc1b732d2011-11-01 18:07:13 +00003753 clang_type_t method_type = ClangASTContext::CreateFunctionType (parser_ast_context,
3754 ClangASTContext::GetBuiltInType_void(parser_ast_context),
3755 args,
3756 1,
3757 false,
3758 ClangASTContext::GetTypeQualifiers(copied_type));
3759
Greg Clayton0fffff52010-09-24 05:15:53 +00003760 const bool is_virtual = false;
3761 const bool is_static = false;
3762 const bool is_inline = false;
Greg Claytonf51de672010-10-01 02:31:07 +00003763 const bool is_explicit = false;
Sean Callananc8324752011-11-02 18:09:01 +00003764 const bool is_attr_used = true;
Sean Callanandbb58392011-11-02 01:38:59 +00003765 const bool is_artificial = false;
Greg Claytonf51de672010-10-01 02:31:07 +00003766
Greg Clayton0fffff52010-09-24 05:15:53 +00003767 ClangASTContext::AddMethodToCXXRecordType (parser_ast_context,
3768 copied_type,
Greg Clayton7b462cc2010-10-15 22:48:33 +00003769 "$__lldb_expr",
Greg Clayton0fffff52010-09-24 05:15:53 +00003770 method_type,
3771 lldb::eAccessPublic,
3772 is_virtual,
3773 is_static,
Greg Claytonf51de672010-10-01 02:31:07 +00003774 is_inline,
Sean Callananc1b732d2011-11-01 18:07:13 +00003775 is_explicit,
Sean Callanandbb58392011-11-02 01:38:59 +00003776 is_attr_used,
3777 is_artificial);
Sean Callananfc55f5d2010-09-21 00:44:12 +00003778 }
Sean Callanan5666b672010-08-04 01:02:13 +00003779
Sean Callananfa4fab72013-02-01 06:55:48 +00003780 return TypeFromParser(copied_type, parser_ast_context);
3781}
3782
3783void
3784ClangExpressionDeclMap::AddOneType(NameSearchContext &context,
3785 TypeFromUser &ut,
3786 unsigned int current_id)
3787{
3788 ASTContext *parser_ast_context = m_ast_context;
3789 ASTContext *user_ast_context = ut.GetASTContext();
3790
3791 void *copied_type = GuardedCopyType(parser_ast_context, user_ast_context, ut.GetOpaqueQualType());
3792
3793 if (!copied_type)
3794 {
3795 lldb::LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_EXPRESSIONS));
3796
3797 if (log)
3798 log->Printf("ClangExpressionDeclMap::AddOneType - Couldn't import the type");
3799
3800 return;
3801 }
3802
Sean Callanan5666b672010-08-04 01:02:13 +00003803 context.AddTypeDecl(copied_type);
3804}