blob: 6e4ee9b58bfe40ee325642c3063dace0e9b150f0 [file] [log] [blame]
Chris Lattner24943d22010-06-08 16:52:24 +00001//===-- ObjectFile.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/lldb-private.h"
Greg Claytone40b6422011-09-18 18:59:15 +000011#include "lldb/lldb-private-log.h"
Greg Claytondb2dc2b2012-01-12 05:25:17 +000012#include "lldb/Core/DataBuffer.h"
Greg Claytonb5a8f142012-02-05 02:38:54 +000013#include "lldb/Core/DataBufferHeap.h"
Greg Claytone40b6422011-09-18 18:59:15 +000014#include "lldb/Core/Log.h"
Chris Lattner24943d22010-06-08 16:52:24 +000015#include "lldb/Core/Module.h"
16#include "lldb/Core/PluginManager.h"
17#include "lldb/Core/RegularExpression.h"
Greg Clayton49ce8962012-08-29 21:13:06 +000018#include "lldb/Core/Section.h"
Chris Lattner24943d22010-06-08 16:52:24 +000019#include "lldb/Core/Timer.h"
20#include "lldb/Symbol/ObjectFile.h"
21#include "lldb/Symbol/ObjectContainer.h"
22#include "lldb/Symbol/SymbolFile.h"
Greg Claytonb5a8f142012-02-05 02:38:54 +000023#include "lldb/Target/Process.h"
Greg Clayton49ce8962012-08-29 21:13:06 +000024#include "Plugins/ObjectContainer/BSD-Archive/ObjectContainerBSDArchive.h"
Chris Lattner24943d22010-06-08 16:52:24 +000025
26using namespace lldb;
27using namespace lldb_private;
28
Greg Claytone40b6422011-09-18 18:59:15 +000029ObjectFileSP
Greg Clayton3508c382012-02-24 01:59:29 +000030ObjectFile::FindPlugin (const lldb::ModuleSP &module_sp, const FileSpec* file, addr_t file_offset, addr_t file_size, DataBufferSP &file_data_sp)
Chris Lattner24943d22010-06-08 16:52:24 +000031{
Greg Claytone40b6422011-09-18 18:59:15 +000032 ObjectFileSP object_file_sp;
Chris Lattner24943d22010-06-08 16:52:24 +000033
Greg Clayton3508c382012-02-24 01:59:29 +000034 if (module_sp)
Chris Lattner24943d22010-06-08 16:52:24 +000035 {
Greg Clayton3508c382012-02-24 01:59:29 +000036 Timer scoped_timer (__PRETTY_FUNCTION__,
Daniel Malea5f35a4b2012-11-29 21:49:15 +000037 "ObjectFile::FindPlugin (module = %s/%s, file = %p, file_offset = 0x%8.8" PRIx64 ", file_size = 0x%8.8" PRIx64 ")",
Greg Clayton3508c382012-02-24 01:59:29 +000038 module_sp->GetFileSpec().GetDirectory().AsCString(),
39 module_sp->GetFileSpec().GetFilename().AsCString(),
Jason Molendaef9eb802012-09-11 06:35:15 +000040 file, (uint64_t) file_offset, (uint64_t) file_size);
Chris Lattner24943d22010-06-08 16:52:24 +000041 if (file)
42 {
Greg Claytondb2dc2b2012-01-12 05:25:17 +000043 // Memory map the entire file contents
Greg Clayton49ce8962012-08-29 21:13:06 +000044 if (!file_data_sp && file_size > 0)
Greg Claytondb2dc2b2012-01-12 05:25:17 +000045 {
46 assert (file_offset == 0);
47 file_data_sp = file->MemoryMapFileContents(file_offset, file_size);
48 }
Chris Lattner24943d22010-06-08 16:52:24 +000049
Greg Claytondb2dc2b2012-01-12 05:25:17 +000050 if (!file_data_sp || file_data_sp->GetByteSize() == 0)
Chris Lattner24943d22010-06-08 16:52:24 +000051 {
52 // Check for archive file with format "/path/to/archive.a(object.o)"
53 char path_with_object[PATH_MAX*2];
Greg Clayton3508c382012-02-24 01:59:29 +000054 module_sp->GetFileSpec().GetPath(path_with_object, sizeof(path_with_object));
Chris Lattner24943d22010-06-08 16:52:24 +000055
Greg Clayton49ce8962012-08-29 21:13:06 +000056 FileSpec archive_file;
57 ConstString archive_object;
58 if (ObjectFile::SplitArchivePathWithObject (path_with_object, archive_file, archive_object))
Chris Lattner24943d22010-06-08 16:52:24 +000059 {
Greg Clayton49ce8962012-08-29 21:13:06 +000060 file_size = archive_file.GetByteSize();
61 if (file_size > 0)
Chris Lattner24943d22010-06-08 16:52:24 +000062 {
Greg Clayton49ce8962012-08-29 21:13:06 +000063 module_sp->SetFileSpecAndObjectName (archive_file, archive_object);
64 file_data_sp = archive_file.MemoryMapFileContents(file_offset, file_size);
Chris Lattner24943d22010-06-08 16:52:24 +000065 }
66 }
67 }
68
Greg Claytondb2dc2b2012-01-12 05:25:17 +000069 if (file_data_sp && file_data_sp->GetByteSize() > 0)
Chris Lattner24943d22010-06-08 16:52:24 +000070 {
Greg Claytondb2dc2b2012-01-12 05:25:17 +000071 uint32_t idx;
Chris Lattner24943d22010-06-08 16:52:24 +000072
Greg Claytondb2dc2b2012-01-12 05:25:17 +000073 // Check if this is a normal object file by iterating through
74 // all object file plugin instances.
75 ObjectFileCreateInstance create_object_file_callback;
76 for (idx = 0; (create_object_file_callback = PluginManager::GetObjectFileCreateCallbackAtIndex(idx)) != NULL; ++idx)
77 {
Greg Clayton3508c382012-02-24 01:59:29 +000078 object_file_sp.reset (create_object_file_callback(module_sp, file_data_sp, file, file_offset, file_size));
Greg Claytondb2dc2b2012-01-12 05:25:17 +000079 if (object_file_sp.get())
80 return object_file_sp;
81 }
Chris Lattner24943d22010-06-08 16:52:24 +000082
Greg Claytondb2dc2b2012-01-12 05:25:17 +000083 // Check if this is a object container by iterating through
84 // all object container plugin instances and then trying to get
85 // an object file from the container.
86 ObjectContainerCreateInstance create_object_container_callback;
87 for (idx = 0; (create_object_container_callback = PluginManager::GetObjectContainerCreateCallbackAtIndex(idx)) != NULL; ++idx)
88 {
Greg Clayton3508c382012-02-24 01:59:29 +000089 std::auto_ptr<ObjectContainer> object_container_ap(create_object_container_callback(module_sp, file_data_sp, file, file_offset, file_size));
Chris Lattner24943d22010-06-08 16:52:24 +000090
Greg Claytondb2dc2b2012-01-12 05:25:17 +000091 if (object_container_ap.get())
92 object_file_sp = object_container_ap->GetObjectFile(file);
93
94 if (object_file_sp.get())
95 return object_file_sp;
96 }
Chris Lattner24943d22010-06-08 16:52:24 +000097 }
98 }
99 }
Greg Claytone40b6422011-09-18 18:59:15 +0000100 // We didn't find it, so clear our shared pointer in case it
101 // contains anything and return an empty shared pointer
102 object_file_sp.reset();
103 return object_file_sp;
104}
105
Greg Claytonb5a8f142012-02-05 02:38:54 +0000106ObjectFileSP
Greg Clayton3508c382012-02-24 01:59:29 +0000107ObjectFile::FindPlugin (const lldb::ModuleSP &module_sp,
Greg Claytonb5a8f142012-02-05 02:38:54 +0000108 const ProcessSP &process_sp,
109 lldb::addr_t header_addr,
110 DataBufferSP &file_data_sp)
111{
Greg Claytonb5a8f142012-02-05 02:38:54 +0000112 ObjectFileSP object_file_sp;
113
Greg Clayton3508c382012-02-24 01:59:29 +0000114 if (module_sp)
Greg Claytonb5a8f142012-02-05 02:38:54 +0000115 {
Greg Clayton3508c382012-02-24 01:59:29 +0000116 Timer scoped_timer (__PRETTY_FUNCTION__,
Daniel Malea5f35a4b2012-11-29 21:49:15 +0000117 "ObjectFile::FindPlugin (module = %s/%s, process = %p, header_addr = 0x%" PRIx64 ")",
Greg Clayton3508c382012-02-24 01:59:29 +0000118 module_sp->GetFileSpec().GetDirectory().AsCString(),
119 module_sp->GetFileSpec().GetFilename().AsCString(),
120 process_sp.get(), header_addr);
Greg Claytonb5a8f142012-02-05 02:38:54 +0000121 uint32_t idx;
122
123 // Check if this is a normal object file by iterating through
124 // all object file plugin instances.
125 ObjectFileCreateMemoryInstance create_callback;
126 for (idx = 0; (create_callback = PluginManager::GetObjectFileCreateMemoryCallbackAtIndex(idx)) != NULL; ++idx)
127 {
Greg Clayton3508c382012-02-24 01:59:29 +0000128 object_file_sp.reset (create_callback(module_sp, file_data_sp, process_sp, header_addr));
Greg Claytonb5a8f142012-02-05 02:38:54 +0000129 if (object_file_sp.get())
130 return object_file_sp;
131 }
132
133 }
134 // We didn't find it, so clear our shared pointer in case it
135 // contains anything and return an empty shared pointer
136 object_file_sp.reset();
137 return object_file_sp;
138}
139
Greg Clayton3508c382012-02-24 01:59:29 +0000140ObjectFile::ObjectFile (const lldb::ModuleSP &module_sp,
Greg Claytone40b6422011-09-18 18:59:15 +0000141 const FileSpec *file_spec_ptr,
Greg Claytondb2dc2b2012-01-12 05:25:17 +0000142 addr_t file_offset,
143 addr_t file_size,
144 DataBufferSP& file_data_sp) :
Greg Clayton3508c382012-02-24 01:59:29 +0000145 ModuleChild (module_sp),
Greg Claytone40b6422011-09-18 18:59:15 +0000146 m_file (), // This file could be different from the original module's file
147 m_type (eTypeInvalid),
148 m_strata (eStrataInvalid),
Greg Claytondb2dc2b2012-01-12 05:25:17 +0000149 m_offset (file_offset),
150 m_length (file_size),
151 m_data (),
Greg Claytonb5a8f142012-02-05 02:38:54 +0000152 m_unwind_table (*this),
153 m_process_wp(),
Greg Clayton46c9a352012-02-09 06:16:32 +0000154 m_memory_addr (LLDB_INVALID_ADDRESS)
Greg Claytone40b6422011-09-18 18:59:15 +0000155{
156 if (file_spec_ptr)
157 m_file = *file_spec_ptr;
Greg Claytondb2dc2b2012-01-12 05:25:17 +0000158 if (file_data_sp)
159 m_data.SetData (file_data_sp, file_offset, file_size);
Greg Claytone40b6422011-09-18 18:59:15 +0000160 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_OBJECT));
161 if (log)
162 {
163 if (m_file)
164 {
Daniel Malea5f35a4b2012-11-29 21:49:15 +0000165 log->Printf ("%p ObjectFile::ObjectFile () module = %s/%s, file = %s/%s, offset = 0x%8.8" PRIx64 ", size = %" PRIu64 "\n",
Greg Claytone40b6422011-09-18 18:59:15 +0000166 this,
Greg Clayton3508c382012-02-24 01:59:29 +0000167 module_sp->GetFileSpec().GetDirectory().AsCString(),
168 module_sp->GetFileSpec().GetFilename().AsCString(),
Greg Claytone40b6422011-09-18 18:59:15 +0000169 m_file.GetDirectory().AsCString(),
170 m_file.GetFilename().AsCString(),
171 m_offset,
172 m_length);
173 }
174 else
175 {
Daniel Malea5f35a4b2012-11-29 21:49:15 +0000176 log->Printf ("%p ObjectFile::ObjectFile () module = %s/%s, file = <NULL>, offset = 0x%8.8" PRIx64 ", size = %" PRIu64 "\n",
Greg Claytone40b6422011-09-18 18:59:15 +0000177 this,
Greg Clayton3508c382012-02-24 01:59:29 +0000178 module_sp->GetFileSpec().GetDirectory().AsCString(),
179 module_sp->GetFileSpec().GetFilename().AsCString(),
Greg Claytone40b6422011-09-18 18:59:15 +0000180 m_offset,
181 m_length);
182 }
183 }
184}
185
Greg Claytonb5a8f142012-02-05 02:38:54 +0000186
Greg Clayton3508c382012-02-24 01:59:29 +0000187ObjectFile::ObjectFile (const lldb::ModuleSP &module_sp,
Greg Claytonb5a8f142012-02-05 02:38:54 +0000188 const ProcessSP &process_sp,
189 lldb::addr_t header_addr,
190 DataBufferSP& header_data_sp) :
Greg Clayton3508c382012-02-24 01:59:29 +0000191 ModuleChild (module_sp),
Greg Claytonb5a8f142012-02-05 02:38:54 +0000192 m_file (),
193 m_type (eTypeInvalid),
194 m_strata (eStrataInvalid),
195 m_offset (header_addr),
196 m_length (0),
197 m_data (),
198 m_unwind_table (*this),
199 m_process_wp (process_sp),
Greg Clayton46c9a352012-02-09 06:16:32 +0000200 m_memory_addr (header_addr)
Greg Claytonb5a8f142012-02-05 02:38:54 +0000201{
202 if (header_data_sp)
203 m_data.SetData (header_data_sp, 0, header_data_sp->GetByteSize());
204 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_OBJECT));
205 if (log)
206 {
Daniel Malea5f35a4b2012-11-29 21:49:15 +0000207 log->Printf ("%p ObjectFile::ObjectFile () module = %s/%s, process = %p, header_addr = 0x%" PRIx64 "\n",
Greg Claytonb5a8f142012-02-05 02:38:54 +0000208 this,
Greg Clayton3508c382012-02-24 01:59:29 +0000209 module_sp->GetFileSpec().GetDirectory().AsCString(),
210 module_sp->GetFileSpec().GetFilename().AsCString(),
Greg Claytonb5a8f142012-02-05 02:38:54 +0000211 process_sp.get(),
212 m_offset);
213 }
214}
215
216
Greg Claytone40b6422011-09-18 18:59:15 +0000217ObjectFile::~ObjectFile()
218{
219 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_OBJECT));
220 if (log)
Greg Claytonc9b798c2012-11-28 00:44:24 +0000221 log->Printf ("%p ObjectFile::~ObjectFile ()\n", this);
Chris Lattner24943d22010-06-08 16:52:24 +0000222}
Jim Ingham7508e732010-08-09 23:31:02 +0000223
224bool
225ObjectFile::SetModulesArchitecture (const ArchSpec &new_arch)
226{
Greg Clayton3508c382012-02-24 01:59:29 +0000227 ModuleSP module_sp (GetModule());
228 if (module_sp)
229 return module_sp->SetArchitecture (new_arch);
230 return false;
Jim Ingham7508e732010-08-09 23:31:02 +0000231}
232
Greg Claytonb3448432011-03-24 21:19:54 +0000233AddressClass
Greg Claytone40b6422011-09-18 18:59:15 +0000234ObjectFile::GetAddressClass (addr_t file_addr)
Greg Claytonb1888f22011-03-19 01:12:21 +0000235{
236 Symtab *symtab = GetSymtab();
237 if (symtab)
238 {
239 Symbol *symbol = symtab->FindSymbolContainingFileAddress(file_addr);
240 if (symbol)
241 {
Greg Clayton0c31d3d2012-03-07 21:03:09 +0000242 if (symbol->ValueIsAddress())
Greg Claytonb1888f22011-03-19 01:12:21 +0000243 {
Greg Clayton0c31d3d2012-03-07 21:03:09 +0000244 const SectionSP section_sp (symbol->GetAddress().GetSection());
Greg Clayton3508c382012-02-24 01:59:29 +0000245 if (section_sp)
Greg Claytonb1888f22011-03-19 01:12:21 +0000246 {
Greg Clayton3508c382012-02-24 01:59:29 +0000247 const SectionType section_type = section_sp->GetType();
Greg Claytonb1888f22011-03-19 01:12:21 +0000248 switch (section_type)
249 {
250 case eSectionTypeInvalid: return eAddressClassUnknown;
251 case eSectionTypeCode: return eAddressClassCode;
252 case eSectionTypeContainer: return eAddressClassUnknown;
Greg Clayton24a6bd92011-10-27 17:55:14 +0000253 case eSectionTypeData:
254 case eSectionTypeDataCString:
255 case eSectionTypeDataCStringPointers:
256 case eSectionTypeDataSymbolAddress:
257 case eSectionTypeData4:
258 case eSectionTypeData8:
259 case eSectionTypeData16:
260 case eSectionTypeDataPointers:
261 case eSectionTypeZeroFill:
262 case eSectionTypeDataObjCMessageRefs:
263 case eSectionTypeDataObjCCFStrings:
264 return eAddressClassData;
265 case eSectionTypeDebug:
266 case eSectionTypeDWARFDebugAbbrev:
267 case eSectionTypeDWARFDebugAranges:
268 case eSectionTypeDWARFDebugFrame:
269 case eSectionTypeDWARFDebugInfo:
270 case eSectionTypeDWARFDebugLine:
271 case eSectionTypeDWARFDebugLoc:
272 case eSectionTypeDWARFDebugMacInfo:
273 case eSectionTypeDWARFDebugPubNames:
274 case eSectionTypeDWARFDebugPubTypes:
275 case eSectionTypeDWARFDebugRanges:
276 case eSectionTypeDWARFDebugStr:
277 case eSectionTypeDWARFAppleNames:
278 case eSectionTypeDWARFAppleTypes:
279 case eSectionTypeDWARFAppleNamespaces:
280 case eSectionTypeDWARFAppleObjC:
281 return eAddressClassDebug;
Greg Claytonb1888f22011-03-19 01:12:21 +0000282 case eSectionTypeEHFrame: return eAddressClassRuntime;
283 case eSectionTypeOther: return eAddressClassUnknown;
284 }
285 }
286 }
287
Greg Claytonb3448432011-03-24 21:19:54 +0000288 const SymbolType symbol_type = symbol->GetType();
Greg Claytonb1888f22011-03-19 01:12:21 +0000289 switch (symbol_type)
290 {
291 case eSymbolTypeAny: return eAddressClassUnknown;
292 case eSymbolTypeAbsolute: return eAddressClassUnknown;
Greg Claytonb1888f22011-03-19 01:12:21 +0000293 case eSymbolTypeCode: return eAddressClassCode;
294 case eSymbolTypeTrampoline: return eAddressClassCode;
295 case eSymbolTypeData: return eAddressClassData;
296 case eSymbolTypeRuntime: return eAddressClassRuntime;
297 case eSymbolTypeException: return eAddressClassRuntime;
298 case eSymbolTypeSourceFile: return eAddressClassDebug;
299 case eSymbolTypeHeaderFile: return eAddressClassDebug;
300 case eSymbolTypeObjectFile: return eAddressClassDebug;
301 case eSymbolTypeCommonBlock: return eAddressClassDebug;
302 case eSymbolTypeBlock: return eAddressClassDebug;
303 case eSymbolTypeLocal: return eAddressClassData;
304 case eSymbolTypeParam: return eAddressClassData;
305 case eSymbolTypeVariable: return eAddressClassData;
306 case eSymbolTypeVariableType: return eAddressClassDebug;
307 case eSymbolTypeLineEntry: return eAddressClassDebug;
308 case eSymbolTypeLineHeader: return eAddressClassDebug;
309 case eSymbolTypeScopeBegin: return eAddressClassDebug;
310 case eSymbolTypeScopeEnd: return eAddressClassDebug;
311 case eSymbolTypeAdditional: return eAddressClassUnknown;
312 case eSymbolTypeCompiler: return eAddressClassDebug;
313 case eSymbolTypeInstrumentation:return eAddressClassDebug;
314 case eSymbolTypeUndefined: return eAddressClassUnknown;
Greg Clayton3f69eac2011-12-03 02:30:59 +0000315 case eSymbolTypeObjCClass: return eAddressClassRuntime;
316 case eSymbolTypeObjCMetaClass: return eAddressClassRuntime;
317 case eSymbolTypeObjCIVar: return eAddressClassRuntime;
Greg Claytonb1888f22011-03-19 01:12:21 +0000318 }
319 }
320 }
321 return eAddressClassUnknown;
322}
323
Greg Claytonb5a8f142012-02-05 02:38:54 +0000324DataBufferSP
325ObjectFile::ReadMemory (const ProcessSP &process_sp, lldb::addr_t addr, size_t byte_size)
326{
327 DataBufferSP data_sp;
328 if (process_sp)
329 {
330 std::auto_ptr<DataBufferHeap> data_ap (new DataBufferHeap (byte_size, 0));
331 Error error;
332 const size_t bytes_read = process_sp->ReadMemory (addr,
333 data_ap->GetBytes(),
334 data_ap->GetByteSize(),
335 error);
336 if (bytes_read == byte_size)
337 data_sp.reset (data_ap.release());
338 }
339 return data_sp;
340}
341
Greg Claytondb2dc2b2012-01-12 05:25:17 +0000342size_t
343ObjectFile::GetData (off_t offset, size_t length, DataExtractor &data) const
344{
345 // The entire file has already been mmap'ed into m_data, so just copy from there
346 // as the back mmap buffer will be shared with shared pointers.
347 return data.SetData (m_data, offset, length);
348}
349
350size_t
351ObjectFile::CopyData (off_t offset, size_t length, void *dst) const
352{
353 // The entire file has already been mmap'ed into m_data, so just copy from there
354 return m_data.CopyByteOrderedData (offset, length, dst, length, lldb::endian::InlHostByteOrder());
355}
Greg Claytonb1888f22011-03-19 01:12:21 +0000356
Greg Claytonb5a8f142012-02-05 02:38:54 +0000357
358size_t
359ObjectFile::ReadSectionData (const Section *section, off_t section_offset, void *dst, size_t dst_len) const
360{
Greg Clayton46c9a352012-02-09 06:16:32 +0000361 if (IsInMemory())
Greg Claytonb5a8f142012-02-05 02:38:54 +0000362 {
363 ProcessSP process_sp (m_process_wp.lock());
364 if (process_sp)
365 {
366 Error error;
367 return process_sp->ReadMemory (section->GetLoadBaseAddress (&process_sp->GetTarget()) + section_offset, dst, dst_len, error);
368 }
369 }
370 else
371 {
Greg Clayton3383c172012-02-21 17:34:25 +0000372 const uint64_t section_file_size = section->GetFileSize();
373 if (section_offset < section_file_size)
374 {
375 const uint64_t section_bytes_left = section_file_size - section_offset;
376 uint64_t section_dst_len = dst_len;
377 if (section_dst_len > section_bytes_left)
378 section_dst_len = section_bytes_left;
379 return CopyData (section->GetFileOffset() + section_offset, section_dst_len, dst);
380 }
Greg Claytonb5a8f142012-02-05 02:38:54 +0000381 }
382 return 0;
383}
384
385//----------------------------------------------------------------------
386// Get the section data the file on disk
387//----------------------------------------------------------------------
388size_t
389ObjectFile::ReadSectionData (const Section *section, DataExtractor& section_data) const
390{
Greg Clayton46c9a352012-02-09 06:16:32 +0000391 if (IsInMemory())
Greg Claytonb5a8f142012-02-05 02:38:54 +0000392 {
393 ProcessSP process_sp (m_process_wp.lock());
394 if (process_sp)
395 {
396 DataBufferSP data_sp (ReadMemory (process_sp, section->GetLoadBaseAddress (&process_sp->GetTarget()), section->GetByteSize()));
397 if (data_sp)
398 {
399 section_data.SetData (data_sp, 0, data_sp->GetByteSize());
400 section_data.SetByteOrder (process_sp->GetByteOrder());
401 section_data.SetAddressByteSize (process_sp->GetAddressByteSize());
402 return section_data.GetByteSize();
403 }
404 }
405 }
406 else
407 {
408 // The object file now contains a full mmap'ed copy of the object file data, so just use this
409 return MemoryMapSectionData (section, section_data);
410 }
411 section_data.Clear();
412 return 0;
413}
414
415size_t
416ObjectFile::MemoryMapSectionData (const Section *section, DataExtractor& section_data) const
417{
Greg Clayton46c9a352012-02-09 06:16:32 +0000418 if (IsInMemory())
Greg Claytonb5a8f142012-02-05 02:38:54 +0000419 {
420 return ReadSectionData (section, section_data);
421 }
422 else
423 {
424 // The object file now contains a full mmap'ed copy of the object file data, so just use this
Greg Clayton23d90ae2012-03-27 02:40:46 +0000425 return GetData(section->GetFileOffset(), section->GetFileSize(), section_data);
Greg Claytonb5a8f142012-02-05 02:38:54 +0000426 }
427 section_data.Clear();
428 return 0;
429}
430
Greg Clayton49ce8962012-08-29 21:13:06 +0000431
432bool
433ObjectFile::SplitArchivePathWithObject (const char *path_with_object, FileSpec &archive_file, ConstString &archive_object)
434{
435 RegularExpression g_object_regex("(.*)\\(([^\\)]+)\\)$");
436 if (g_object_regex.Execute (path_with_object, 2))
437 {
438 std::string path;
439 std::string obj;
440 if (g_object_regex.GetMatchAtIndex (path_with_object, 1, path) &&
441 g_object_regex.GetMatchAtIndex (path_with_object, 2, obj))
442 {
443 archive_file.SetFile (path.c_str(), false);
444 archive_object.SetCString(obj.c_str());
445 return true;
446 }
447 }
448 return false;
449}
450