SBValue.cpp revision 3d656c729a1ed0abad4e5a2d76f6e8a6904f66aa
1//===-- SBValue.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/API/SBValue.h" 11 12#include "lldb/API/SBDeclaration.h" 13#include "lldb/API/SBStream.h" 14#include "lldb/API/SBTypeFilter.h" 15#include "lldb/API/SBTypeFormat.h" 16#include "lldb/API/SBTypeSummary.h" 17#include "lldb/API/SBTypeSynthetic.h" 18 19#include "lldb/Breakpoint/Watchpoint.h" 20#include "lldb/Core/DataExtractor.h" 21#include "lldb/Core/DataVisualization.h" 22#include "lldb/Core/Log.h" 23#include "lldb/Core/Module.h" 24#include "lldb/Core/Scalar.h" 25#include "lldb/Core/Section.h" 26#include "lldb/Core/Stream.h" 27#include "lldb/Core/StreamFile.h" 28#include "lldb/Core/Value.h" 29#include "lldb/Core/ValueObject.h" 30#include "lldb/Core/ValueObjectConstResult.h" 31#include "lldb/Symbol/Block.h" 32#include "lldb/Symbol/Declaration.h" 33#include "lldb/Symbol/ObjectFile.h" 34#include "lldb/Symbol/Type.h" 35#include "lldb/Symbol/Variable.h" 36#include "lldb/Symbol/VariableList.h" 37#include "lldb/Target/ExecutionContext.h" 38#include "lldb/Target/Process.h" 39#include "lldb/Target/StackFrame.h" 40#include "lldb/Target/Target.h" 41#include "lldb/Target/Thread.h" 42 43#include "lldb/API/SBDebugger.h" 44#include "lldb/API/SBExpressionOptions.h" 45#include "lldb/API/SBFrame.h" 46#include "lldb/API/SBProcess.h" 47#include "lldb/API/SBTarget.h" 48#include "lldb/API/SBThread.h" 49 50using namespace lldb; 51using namespace lldb_private; 52 53namespace { 54 class ValueImpl 55 { 56 public: 57 ValueImpl () 58 { 59 } 60 61 ValueImpl (lldb::ValueObjectSP opaque_sp, 62 lldb::DynamicValueType use_dynamic, 63 bool use_synthetic) : 64 m_opaque_sp(opaque_sp), 65 m_use_dynamic(use_dynamic), 66 m_use_synthetic(use_synthetic) 67 { 68 } 69 70 ValueImpl (const ValueImpl& rhs) : 71 m_opaque_sp(rhs.m_opaque_sp), 72 m_use_dynamic(rhs.m_use_dynamic), 73 m_use_synthetic(rhs.m_use_synthetic) 74 { 75 } 76 77 ValueImpl & 78 operator = (const ValueImpl &rhs) 79 { 80 if (this != &rhs) 81 { 82 m_opaque_sp = rhs.m_opaque_sp; 83 m_use_dynamic = rhs.m_use_dynamic; 84 m_use_synthetic = rhs.m_use_synthetic; 85 } 86 return *this; 87 } 88 89 bool 90 IsValid () 91 { 92 return m_opaque_sp.get() != NULL; 93 } 94 95 lldb::ValueObjectSP 96 GetRootSP () 97 { 98 return m_opaque_sp; 99 } 100 101 lldb::ValueObjectSP 102 GetSP () 103 { 104 if (!m_opaque_sp) 105 return m_opaque_sp; 106 lldb::ValueObjectSP value_sp = m_opaque_sp; 107 if (value_sp->GetDynamicValue(m_use_dynamic)) 108 value_sp = value_sp->GetDynamicValue(m_use_dynamic); 109 if (value_sp->GetSyntheticValue(m_use_synthetic)) 110 value_sp = value_sp->GetSyntheticValue(m_use_synthetic); 111 return value_sp; 112 } 113 114 void 115 SetUseDynamic (lldb::DynamicValueType use_dynamic) 116 { 117 m_use_dynamic = use_dynamic; 118 } 119 120 void 121 SetUseSynthetic (bool use_synthetic) 122 { 123 m_use_synthetic = use_synthetic; 124 } 125 126 lldb::DynamicValueType 127 GetUseDynamic () 128 { 129 return m_use_dynamic; 130 } 131 132 bool 133 GetUseSynthetic () 134 { 135 return m_use_synthetic; 136 } 137 138 private: 139 lldb::ValueObjectSP m_opaque_sp; 140 lldb::DynamicValueType m_use_dynamic; 141 bool m_use_synthetic; 142 }; 143} 144 145SBValue::SBValue () : 146 m_opaque_sp () 147{ 148} 149 150SBValue::SBValue (const lldb::ValueObjectSP &value_sp) 151{ 152 SetSP(value_sp); 153} 154 155SBValue::SBValue(const SBValue &rhs) 156{ 157 SetSP(rhs.m_opaque_sp); 158} 159 160SBValue & 161SBValue::operator = (const SBValue &rhs) 162{ 163 if (this != &rhs) 164 { 165 SetSP(rhs.m_opaque_sp); 166 } 167 return *this; 168} 169 170SBValue::~SBValue() 171{ 172} 173 174bool 175SBValue::IsValid () 176{ 177 // If this function ever changes to anything that does more than just 178 // check if the opaque shared pointer is non NULL, then we need to update 179 // all "if (m_opaque_sp)" code in this file. 180 return m_opaque_sp.get() != NULL && m_opaque_sp->GetRootSP().get() != NULL; 181} 182 183void 184SBValue::Clear() 185{ 186 m_opaque_sp.reset(); 187} 188 189SBError 190SBValue::GetError() 191{ 192 SBError sb_error; 193 194 lldb::ValueObjectSP value_sp(GetSP()); 195 if (value_sp) 196 sb_error.SetError(value_sp->GetError()); 197 else 198 sb_error.SetErrorString("error: invalid value"); 199 200 return sb_error; 201} 202 203user_id_t 204SBValue::GetID() 205{ 206 lldb::ValueObjectSP value_sp(GetSP()); 207 if (value_sp) 208 return value_sp->GetID(); 209 return LLDB_INVALID_UID; 210} 211 212const char * 213SBValue::GetName() 214{ 215 216 const char *name = NULL; 217 lldb::ValueObjectSP value_sp(GetSP()); 218 if (value_sp) 219 name = value_sp->GetName().GetCString(); 220 221 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); 222 if (log) 223 { 224 if (name) 225 log->Printf ("SBValue(%p)::GetName () => \"%s\"", value_sp.get(), name); 226 else 227 log->Printf ("SBValue(%p)::GetName () => NULL", value_sp.get()); 228 } 229 230 return name; 231} 232 233const char * 234SBValue::GetTypeName () 235{ 236 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); 237 const char *name = NULL; 238 lldb::ValueObjectSP value_sp(GetSP()); 239 if (value_sp) 240 { 241 // For a dynamic type we might have to run code to determine the type we are going to report, 242 // and we might not have updated the type before we get asked this. So make sure to get the API lock. 243 244 ProcessSP process_sp(value_sp->GetProcessSP()); 245 Process::StopLocker stop_locker; 246 if (process_sp && !stop_locker.TryLock(&process_sp->GetRunLock())) 247 { 248 if (log) 249 log->Printf ("SBValue(%p)::GetTypeName() => error: process is running", value_sp.get()); 250 } 251 else 252 { 253 TargetSP target_sp(value_sp->GetTargetSP()); 254 if (target_sp) 255 { 256 Mutex::Locker api_locker (target_sp->GetAPIMutex()); 257 name = value_sp->GetQualifiedTypeName().GetCString(); 258 } 259 } 260 } 261 262 if (log) 263 { 264 if (name) 265 log->Printf ("SBValue(%p)::GetTypeName () => \"%s\"", value_sp.get(), name); 266 else 267 log->Printf ("SBValue(%p)::GetTypeName () => NULL", value_sp.get()); 268 } 269 270 return name; 271} 272 273size_t 274SBValue::GetByteSize () 275{ 276 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); 277 size_t result = 0; 278 279 lldb::ValueObjectSP value_sp(GetSP()); 280 if (value_sp) 281 { 282 // For a dynamic type we might have to run code to determine the type we are going to report, 283 // and we might not have updated the type before we get asked this. So make sure to get the API lock. 284 285 ProcessSP process_sp(value_sp->GetProcessSP()); 286 Process::StopLocker stop_locker; 287 if (process_sp && !stop_locker.TryLock(&process_sp->GetRunLock())) 288 { 289 if (log) 290 log->Printf ("SBValue(%p)::GetTypeName() => error: process is running", value_sp.get()); 291 } 292 else 293 { 294 TargetSP target_sp(value_sp->GetTargetSP()); 295 if (target_sp) 296 { 297 Mutex::Locker api_locker (target_sp->GetAPIMutex()); 298 result = value_sp->GetByteSize(); 299 } 300 } 301 } 302 303 if (log) 304 log->Printf ("SBValue(%p)::GetByteSize () => %llu", value_sp.get(), (uint64_t)result); 305 306 return result; 307} 308 309bool 310SBValue::IsInScope () 311{ 312 bool result = false; 313 314 lldb::ValueObjectSP value_sp(GetSP()); 315 if (value_sp) 316 { 317 TargetSP target_sp(value_sp->GetTargetSP()); 318 if (target_sp) 319 { 320 Mutex::Locker api_locker (target_sp->GetAPIMutex()); 321 result = value_sp->IsInScope (); 322 } 323 } 324 325 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); 326 if (log) 327 log->Printf ("SBValue(%p)::IsInScope () => %i", value_sp.get(), result); 328 329 return result; 330} 331 332const char * 333SBValue::GetValue () 334{ 335 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); 336 337 const char *cstr = NULL; 338 lldb::ValueObjectSP value_sp(GetSP()); 339 if (value_sp) 340 { 341 ProcessSP process_sp(value_sp->GetProcessSP()); 342 Process::StopLocker stop_locker; 343 if (process_sp && !stop_locker.TryLock(&process_sp->GetRunLock())) 344 { 345 if (log) 346 log->Printf ("SBValue(%p)::GetValue() => error: process is running", value_sp.get()); 347 } 348 else 349 { 350 TargetSP target_sp(value_sp->GetTargetSP()); 351 if (target_sp) 352 { 353 Mutex::Locker api_locker (target_sp->GetAPIMutex()); 354 cstr = value_sp->GetValueAsCString (); 355 } 356 } 357 } 358 if (log) 359 { 360 if (cstr) 361 log->Printf ("SBValue(%p)::GetValue() => \"%s\"", value_sp.get(), cstr); 362 else 363 log->Printf ("SBValue(%p)::GetValue() => NULL", value_sp.get()); 364 } 365 366 return cstr; 367} 368 369ValueType 370SBValue::GetValueType () 371{ 372 ValueType result = eValueTypeInvalid; 373 lldb::ValueObjectSP value_sp(GetSP()); 374 if (value_sp) 375 result = value_sp->GetValueType(); 376 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); 377 if (log) 378 { 379 switch (result) 380 { 381 case eValueTypeInvalid: log->Printf ("SBValue(%p)::GetValueType () => eValueTypeInvalid", value_sp.get()); break; 382 case eValueTypeVariableGlobal: log->Printf ("SBValue(%p)::GetValueType () => eValueTypeVariableGlobal", value_sp.get()); break; 383 case eValueTypeVariableStatic: log->Printf ("SBValue(%p)::GetValueType () => eValueTypeVariableStatic", value_sp.get()); break; 384 case eValueTypeVariableArgument:log->Printf ("SBValue(%p)::GetValueType () => eValueTypeVariableArgument", value_sp.get()); break; 385 case eValueTypeVariableLocal: log->Printf ("SBValue(%p)::GetValueType () => eValueTypeVariableLocal", value_sp.get()); break; 386 case eValueTypeRegister: log->Printf ("SBValue(%p)::GetValueType () => eValueTypeRegister", value_sp.get()); break; 387 case eValueTypeRegisterSet: log->Printf ("SBValue(%p)::GetValueType () => eValueTypeRegisterSet", value_sp.get()); break; 388 case eValueTypeConstResult: log->Printf ("SBValue(%p)::GetValueType () => eValueTypeConstResult", value_sp.get()); break; 389 default: log->Printf ("SBValue(%p)::GetValueType () => %i ???", value_sp.get(), result); break; 390 } 391 } 392 return result; 393} 394 395const char * 396SBValue::GetObjectDescription () 397{ 398 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); 399 const char *cstr = NULL; 400 lldb::ValueObjectSP value_sp(GetSP()); 401 if (value_sp) 402 { 403 ProcessSP process_sp(value_sp->GetProcessSP()); 404 Process::StopLocker stop_locker; 405 if (process_sp && !stop_locker.TryLock(&process_sp->GetRunLock())) 406 { 407 if (log) 408 log->Printf ("SBValue(%p)::GetObjectDescription() => error: process is running", value_sp.get()); 409 } 410 else 411 { 412 TargetSP target_sp(value_sp->GetTargetSP()); 413 if (target_sp) 414 { 415 Mutex::Locker api_locker (target_sp->GetAPIMutex()); 416 cstr = value_sp->GetObjectDescription (); 417 } 418 } 419 } 420 if (log) 421 { 422 if (cstr) 423 log->Printf ("SBValue(%p)::GetObjectDescription() => \"%s\"", value_sp.get(), cstr); 424 else 425 log->Printf ("SBValue(%p)::GetObjectDescription() => NULL", value_sp.get()); 426 } 427 return cstr; 428} 429 430SBType 431SBValue::GetType() 432{ 433 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); 434 SBType sb_type; 435 lldb::ValueObjectSP value_sp(GetSP()); 436 TypeImplSP type_sp; 437 if (value_sp) 438 { 439 ProcessSP process_sp(value_sp->GetProcessSP()); 440 Process::StopLocker stop_locker; 441 if (process_sp && !stop_locker.TryLock(&process_sp->GetRunLock())) 442 { 443 if (log) 444 log->Printf ("SBValue(%p)::GetType() => error: process is running", value_sp.get()); 445 } 446 else 447 { 448 TargetSP target_sp(value_sp->GetTargetSP()); 449 if (target_sp) 450 { 451 Mutex::Locker api_locker (target_sp->GetAPIMutex()); 452 type_sp.reset (new TypeImpl(ClangASTType (value_sp->GetClangAST(), value_sp->GetClangType()))); 453 sb_type.SetSP(type_sp); 454 } 455 } 456 } 457 if (log) 458 { 459 if (type_sp) 460 log->Printf ("SBValue(%p)::GetType => SBType(%p)", value_sp.get(), type_sp.get()); 461 else 462 log->Printf ("SBValue(%p)::GetType => NULL", value_sp.get()); 463 } 464 return sb_type; 465} 466 467bool 468SBValue::GetValueDidChange () 469{ 470 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); 471 bool result = false; 472 lldb::ValueObjectSP value_sp(GetSP()); 473 if (value_sp) 474 { 475 ProcessSP process_sp(value_sp->GetProcessSP()); 476 Process::StopLocker stop_locker; 477 if (process_sp && !stop_locker.TryLock(&process_sp->GetRunLock())) 478 { 479 if (log) 480 log->Printf ("SBValue(%p)::GetValueDidChange() => error: process is running", value_sp.get()); 481 } 482 else 483 { 484 TargetSP target_sp(value_sp->GetTargetSP()); 485 if (target_sp) 486 { 487 Mutex::Locker api_locker (target_sp->GetAPIMutex()); 488 result = value_sp->GetValueDidChange (); 489 } 490 } 491 } 492 if (log) 493 log->Printf ("SBValue(%p)::GetValueDidChange() => %i", value_sp.get(), result); 494 495 return result; 496} 497 498#ifndef LLDB_DISABLE_PYTHON 499const char * 500SBValue::GetSummary () 501{ 502 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); 503 const char *cstr = NULL; 504 lldb::ValueObjectSP value_sp(GetSP()); 505 if (value_sp) 506 { 507 ProcessSP process_sp(value_sp->GetProcessSP()); 508 Process::StopLocker stop_locker; 509 if (process_sp && !stop_locker.TryLock(&process_sp->GetRunLock())) 510 { 511 if (log) 512 log->Printf ("SBValue(%p)::GetSummary() => error: process is running", value_sp.get()); 513 } 514 else 515 { 516 TargetSP target_sp(value_sp->GetTargetSP()); 517 if (target_sp) 518 { 519 Mutex::Locker api_locker (target_sp->GetAPIMutex()); 520 cstr = value_sp->GetSummaryAsCString(); 521 } 522 } 523 } 524 if (log) 525 { 526 if (cstr) 527 log->Printf ("SBValue(%p)::GetSummary() => \"%s\"", value_sp.get(), cstr); 528 else 529 log->Printf ("SBValue(%p)::GetSummary() => NULL", value_sp.get()); 530 } 531 return cstr; 532} 533#endif // LLDB_DISABLE_PYTHON 534 535const char * 536SBValue::GetLocation () 537{ 538 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); 539 const char *cstr = NULL; 540 lldb::ValueObjectSP value_sp(GetSP()); 541 if (value_sp) 542 { 543 ProcessSP process_sp(value_sp->GetProcessSP()); 544 Process::StopLocker stop_locker; 545 if (process_sp && !stop_locker.TryLock(&process_sp->GetRunLock())) 546 { 547 if (log) 548 log->Printf ("SBValue(%p)::GetLocation() => error: process is running", value_sp.get()); 549 } 550 else 551 { 552 TargetSP target_sp(value_sp->GetTargetSP()); 553 if (target_sp) 554 { 555 Mutex::Locker api_locker (target_sp->GetAPIMutex()); 556 cstr = value_sp->GetLocationAsCString(); 557 } 558 } 559 } 560 if (log) 561 { 562 if (cstr) 563 log->Printf ("SBValue(%p)::GetLocation() => \"%s\"", value_sp.get(), cstr); 564 else 565 log->Printf ("SBValue(%p)::GetLocation() => NULL", value_sp.get()); 566 } 567 return cstr; 568} 569 570// Deprecated - use the one that takes an lldb::SBError 571bool 572SBValue::SetValueFromCString (const char *value_str) 573{ 574 lldb::SBError dummy; 575 return SetValueFromCString(value_str,dummy); 576} 577 578bool 579SBValue::SetValueFromCString (const char *value_str, lldb::SBError& error) 580{ 581 bool success = false; 582 lldb::ValueObjectSP value_sp(GetSP()); 583 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); 584 if (value_sp) 585 { 586 ProcessSP process_sp(value_sp->GetProcessSP()); 587 Process::StopLocker stop_locker; 588 if (process_sp && !stop_locker.TryLock(&process_sp->GetRunLock())) 589 { 590 if (log) 591 log->Printf ("SBValue(%p)::SetValueFromCString() => error: process is running", value_sp.get()); 592 } 593 else 594 { 595 TargetSP target_sp(value_sp->GetTargetSP()); 596 if (target_sp) 597 { 598 Mutex::Locker api_locker (target_sp->GetAPIMutex()); 599 success = value_sp->SetValueFromCString (value_str,error.ref()); 600 } 601 } 602 } 603 if (log) 604 log->Printf ("SBValue(%p)::SetValueFromCString(\"%s\") => %i", value_sp.get(), value_str, success); 605 606 return success; 607} 608 609lldb::SBTypeFormat 610SBValue::GetTypeFormat () 611{ 612 lldb::SBTypeFormat format; 613 lldb::ValueObjectSP value_sp(GetSP()); 614 if (value_sp) 615 { 616 ProcessSP process_sp(value_sp->GetProcessSP()); 617 Process::StopLocker stop_locker; 618 if (process_sp && !stop_locker.TryLock(&process_sp->GetRunLock())) 619 { 620 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); 621 if (log) 622 log->Printf ("SBValue(%p)::GetTypeFormat() => error: process is running", value_sp.get()); 623 } 624 else 625 { 626 TargetSP target_sp(value_sp->GetTargetSP()); 627 if (target_sp) 628 { 629 Mutex::Locker api_locker (target_sp->GetAPIMutex()); 630 if (value_sp->UpdateValueIfNeeded(true)) 631 { 632 lldb::TypeFormatImplSP format_sp = value_sp->GetValueFormat(); 633 if (format_sp) 634 format.SetSP(format_sp); 635 } 636 } 637 } 638 } 639 return format; 640} 641 642#ifndef LLDB_DISABLE_PYTHON 643lldb::SBTypeSummary 644SBValue::GetTypeSummary () 645{ 646 lldb::SBTypeSummary summary; 647 lldb::ValueObjectSP value_sp(GetSP()); 648 if (value_sp) 649 { 650 ProcessSP process_sp(value_sp->GetProcessSP()); 651 Process::StopLocker stop_locker; 652 if (process_sp && !stop_locker.TryLock(&process_sp->GetRunLock())) 653 { 654 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); 655 if (log) 656 log->Printf ("SBValue(%p)::GetTypeSummary() => error: process is running", value_sp.get()); 657 } 658 else 659 { 660 TargetSP target_sp(value_sp->GetTargetSP()); 661 if (target_sp) 662 { 663 Mutex::Locker api_locker (target_sp->GetAPIMutex()); 664 if (value_sp->UpdateValueIfNeeded(true)) 665 { 666 lldb::TypeSummaryImplSP summary_sp = value_sp->GetSummaryFormat(); 667 if (summary_sp) 668 summary.SetSP(summary_sp); 669 } 670 } 671 } 672 } 673 return summary; 674} 675#endif // LLDB_DISABLE_PYTHON 676 677lldb::SBTypeFilter 678SBValue::GetTypeFilter () 679{ 680 lldb::SBTypeFilter filter; 681 lldb::ValueObjectSP value_sp(GetSP()); 682 if (value_sp) 683 { 684 ProcessSP process_sp(value_sp->GetProcessSP()); 685 Process::StopLocker stop_locker; 686 if (process_sp && !stop_locker.TryLock(&process_sp->GetRunLock())) 687 { 688 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); 689 if (log) 690 log->Printf ("SBValue(%p)::GetTypeFilter() => error: process is running", value_sp.get()); 691 } 692 else 693 { 694 TargetSP target_sp(value_sp->GetTargetSP()); 695 if (target_sp) 696 { 697 Mutex::Locker api_locker (target_sp->GetAPIMutex()); 698 if (value_sp->UpdateValueIfNeeded(true)) 699 { 700 lldb::SyntheticChildrenSP synthetic_sp = value_sp->GetSyntheticChildren(); 701 702 if (synthetic_sp && !synthetic_sp->IsScripted()) 703 { 704 TypeFilterImplSP filter_sp = STD_STATIC_POINTER_CAST(TypeFilterImpl,synthetic_sp); 705 filter.SetSP(filter_sp); 706 } 707 } 708 } 709 } 710 } 711 return filter; 712} 713 714#ifndef LLDB_DISABLE_PYTHON 715lldb::SBTypeSynthetic 716SBValue::GetTypeSynthetic () 717{ 718 lldb::SBTypeSynthetic synthetic; 719 lldb::ValueObjectSP value_sp(GetSP()); 720 if (value_sp) 721 { 722 ProcessSP process_sp(value_sp->GetProcessSP()); 723 Process::StopLocker stop_locker; 724 if (process_sp && !stop_locker.TryLock(&process_sp->GetRunLock())) 725 { 726 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); 727 if (log) 728 log->Printf ("SBValue(%p)::GetTypeSynthetic() => error: process is running", value_sp.get()); 729 } 730 else 731 { 732 TargetSP target_sp(value_sp->GetTargetSP()); 733 if (target_sp) 734 { 735 Mutex::Locker api_locker (target_sp->GetAPIMutex()); 736 if (value_sp->UpdateValueIfNeeded(true)) 737 { 738 lldb::SyntheticChildrenSP children_sp = value_sp->GetSyntheticChildren(); 739 740 if (children_sp && children_sp->IsScripted()) 741 { 742 TypeSyntheticImplSP synth_sp = STD_STATIC_POINTER_CAST(TypeSyntheticImpl,children_sp); 743 synthetic.SetSP(synth_sp); 744 } 745 } 746 } 747 } 748 } 749 return synthetic; 750} 751#endif 752 753lldb::SBValue 754SBValue::CreateChildAtOffset (const char *name, uint32_t offset, SBType type) 755{ 756 lldb::SBValue sb_value; 757 lldb::ValueObjectSP value_sp(GetSP()); 758 lldb::ValueObjectSP new_value_sp; 759 if (value_sp) 760 { 761 ProcessSP process_sp(value_sp->GetProcessSP()); 762 Process::StopLocker stop_locker; 763 if (process_sp && !stop_locker.TryLock(&process_sp->GetRunLock())) 764 { 765 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); 766 if (log) 767 log->Printf ("SBValue(%p)::CreateChildAtOffset() => error: process is running", value_sp.get()); 768 } 769 else 770 { 771 TargetSP target_sp(value_sp->GetTargetSP()); 772 if (target_sp) 773 { 774 Mutex::Locker api_locker (target_sp->GetAPIMutex()); 775 TypeImplSP type_sp (type.GetSP()); 776 if (type.IsValid()) 777 { 778 sb_value.SetSP(value_sp->GetSyntheticChildAtOffset(offset, type_sp->GetClangASTType(), true),GetPreferDynamicValue(),GetPreferSyntheticValue()); 779 new_value_sp = sb_value.GetSP(); 780 if (new_value_sp) 781 new_value_sp->SetName(ConstString(name)); 782 } 783 } 784 } 785 } 786 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); 787 if (log) 788 { 789 if (new_value_sp) 790 log->Printf ("SBValue(%p)::CreateChildAtOffset => \"%s\"", 791 value_sp.get(), 792 new_value_sp->GetName().AsCString()); 793 else 794 log->Printf ("SBValue(%p)::CreateChildAtOffset => NULL", 795 value_sp.get()); 796 } 797 return sb_value; 798} 799 800lldb::SBValue 801SBValue::Cast (SBType type) 802{ 803 lldb::SBValue sb_value; 804 lldb::ValueObjectSP value_sp(GetSP()); 805 TypeImplSP type_sp (type.GetSP()); 806 if (value_sp && type_sp) 807 sb_value.SetSP(value_sp->Cast(type_sp->GetClangASTType()),GetPreferDynamicValue(),GetPreferSyntheticValue()); 808 return sb_value; 809} 810 811lldb::SBValue 812SBValue::CreateValueFromExpression (const char *name, const char* expression) 813{ 814 SBExpressionOptions options; 815 options.ref().SetKeepInMemory(true); 816 return CreateValueFromExpression (name, expression, options); 817} 818 819lldb::SBValue 820SBValue::CreateValueFromExpression (const char *name, const char *expression, SBExpressionOptions &options) 821{ 822 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); 823 lldb::SBValue sb_value; 824 lldb::ValueObjectSP value_sp(GetSP()); 825 lldb::ValueObjectSP new_value_sp; 826 if (value_sp) 827 { 828 ExecutionContext exe_ctx (value_sp->GetExecutionContextRef()); 829 ProcessSP process_sp(exe_ctx.GetProcessSP()); 830 Process::StopLocker stop_locker; 831 if (process_sp && !stop_locker.TryLock(&process_sp->GetRunLock())) 832 { 833 if (log) 834 log->Printf ("SBValue(%p)::CreateValueFromExpression() => error: process is running", value_sp.get()); 835 } 836 else 837 { 838 Target* target = exe_ctx.GetTargetPtr(); 839 if (target) 840 { 841 options.ref().SetKeepInMemory(true); 842 target->EvaluateExpression (expression, 843 exe_ctx.GetFramePtr(), 844 new_value_sp, 845 options.ref()); 846 if (new_value_sp) 847 { 848 new_value_sp->SetName(ConstString(name)); 849 sb_value.SetSP(new_value_sp); 850 } 851 } 852 } 853 } 854 if (log) 855 { 856 if (new_value_sp) 857 log->Printf ("SBValue(%p)::CreateValueFromExpression(name=\"%s\", expression=\"%s\") => SBValue (%p)", 858 value_sp.get(), 859 name, 860 expression, 861 new_value_sp.get()); 862 else 863 log->Printf ("SBValue(%p)::CreateValueFromExpression(name=\"%s\", expression=\"%s\") => NULL", 864 value_sp.get(), 865 name, 866 expression); 867 } 868 return sb_value; 869} 870 871lldb::SBValue 872SBValue::CreateValueFromAddress(const char* name, lldb::addr_t address, SBType sb_type) 873{ 874 lldb::SBValue sb_value; 875 lldb::ValueObjectSP value_sp(GetSP()); 876 lldb::ValueObjectSP new_value_sp; 877 lldb::TypeImplSP type_impl_sp (sb_type.GetSP()); 878 if (value_sp && type_impl_sp) 879 { 880 ClangASTType pointee_ast_type(type_impl_sp->GetASTContext(), type_impl_sp->GetClangASTType().GetPointerType ()); 881 lldb::TypeImplSP pointee_type_impl_sp (new TypeImpl(pointee_ast_type)); 882 if (pointee_type_impl_sp) 883 { 884 885 lldb::DataBufferSP buffer(new lldb_private::DataBufferHeap(&address,sizeof(lldb::addr_t))); 886 887 ExecutionContext exe_ctx (value_sp->GetExecutionContextRef()); 888 ValueObjectSP ptr_result_valobj_sp(ValueObjectConstResult::Create (exe_ctx.GetBestExecutionContextScope(), 889 pointee_type_impl_sp->GetASTContext(), 890 pointee_type_impl_sp->GetOpaqueQualType(), 891 ConstString(name), 892 buffer, 893 lldb::endian::InlHostByteOrder(), 894 exe_ctx.GetAddressByteSize())); 895 896 if (ptr_result_valobj_sp) 897 { 898 ptr_result_valobj_sp->GetValue().SetValueType(Value::eValueTypeLoadAddress); 899 Error err; 900 new_value_sp = ptr_result_valobj_sp->Dereference(err); 901 if (new_value_sp) 902 new_value_sp->SetName(ConstString(name)); 903 } 904 sb_value.SetSP(new_value_sp); 905 } 906 } 907 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); 908 if (log) 909 { 910 if (new_value_sp) 911 log->Printf ("SBValue(%p)::CreateValueFromAddress => \"%s\"", value_sp.get(), new_value_sp->GetName().AsCString()); 912 else 913 log->Printf ("SBValue(%p)::CreateValueFromAddress => NULL", value_sp.get()); 914 } 915 return sb_value; 916} 917 918lldb::SBValue 919SBValue::CreateValueFromData (const char* name, SBData data, SBType type) 920{ 921 lldb::SBValue sb_value; 922 lldb::ValueObjectSP new_value_sp; 923 lldb::ValueObjectSP value_sp(GetSP()); 924 if (value_sp) 925 { 926 ExecutionContext exe_ctx (value_sp->GetExecutionContextRef()); 927 928 new_value_sp = ValueObjectConstResult::Create (exe_ctx.GetBestExecutionContextScope(), 929 type.m_opaque_sp->GetASTContext() , 930 type.m_opaque_sp->GetOpaqueQualType(), 931 ConstString(name), 932 *data.m_opaque_sp, 933 LLDB_INVALID_ADDRESS); 934 new_value_sp->SetAddressTypeOfChildren(eAddressTypeLoad); 935 sb_value.SetSP(new_value_sp); 936 } 937 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); 938 if (log) 939 { 940 if (new_value_sp) 941 log->Printf ("SBValue(%p)::CreateValueFromData => \"%s\"", value_sp.get(), new_value_sp->GetName().AsCString()); 942 else 943 log->Printf ("SBValue(%p)::CreateValueFromData => NULL", value_sp.get()); 944 } 945 return sb_value; 946} 947 948SBValue 949SBValue::GetChildAtIndex (uint32_t idx) 950{ 951 const bool can_create_synthetic = false; 952 lldb::DynamicValueType use_dynamic = eNoDynamicValues; 953 lldb::ValueObjectSP value_sp(GetSP()); 954 if (value_sp) 955 { 956 TargetSP target_sp(value_sp->GetTargetSP()); 957 if (target_sp) 958 use_dynamic = target_sp->GetPreferDynamicValue(); 959 } 960 return GetChildAtIndex (idx, use_dynamic, can_create_synthetic); 961} 962 963SBValue 964SBValue::GetChildAtIndex (uint32_t idx, lldb::DynamicValueType use_dynamic, bool can_create_synthetic) 965{ 966 lldb::ValueObjectSP child_sp; 967 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); 968 969 lldb::ValueObjectSP value_sp(GetSP()); 970 if (value_sp) 971 { 972 ProcessSP process_sp(value_sp->GetProcessSP()); 973 Process::StopLocker stop_locker; 974 if (process_sp && !stop_locker.TryLock(&process_sp->GetRunLock())) 975 { 976 if (log) 977 log->Printf ("SBValue(%p)::GetChildAtIndex() => error: process is running", value_sp.get()); 978 } 979 else 980 { 981 TargetSP target_sp(value_sp->GetTargetSP()); 982 if (target_sp) 983 { 984 Mutex::Locker api_locker (target_sp->GetAPIMutex()); 985 const bool can_create = true; 986 child_sp = value_sp->GetChildAtIndex (idx, can_create); 987 if (can_create_synthetic && !child_sp) 988 { 989 if (value_sp->IsPointerType()) 990 { 991 child_sp = value_sp->GetSyntheticArrayMemberFromPointer(idx, can_create); 992 } 993 else if (value_sp->IsArrayType()) 994 { 995 child_sp = value_sp->GetSyntheticArrayMemberFromArray(idx, can_create); 996 } 997 } 998 999 } 1000 } 1001 } 1002 1003 SBValue sb_value; 1004 sb_value.SetSP (child_sp, use_dynamic, GetPreferSyntheticValue()); 1005 if (log) 1006 log->Printf ("SBValue(%p)::GetChildAtIndex (%u) => SBValue(%p)", value_sp.get(), idx, value_sp.get()); 1007 1008 return sb_value; 1009} 1010 1011uint32_t 1012SBValue::GetIndexOfChildWithName (const char *name) 1013{ 1014 uint32_t idx = UINT32_MAX; 1015 lldb::ValueObjectSP value_sp(GetSP()); 1016 if (value_sp) 1017 { 1018 TargetSP target_sp(value_sp->GetTargetSP()); 1019 if (target_sp) 1020 { 1021 Mutex::Locker api_locker (target_sp->GetAPIMutex()); 1022 1023 idx = value_sp->GetIndexOfChildWithName (ConstString(name)); 1024 } 1025 } 1026 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); 1027 if (log) 1028 { 1029 if (idx == UINT32_MAX) 1030 log->Printf ("SBValue(%p)::GetIndexOfChildWithName (name=\"%s\") => NOT FOUND", value_sp.get(), name); 1031 else 1032 log->Printf ("SBValue(%p)::GetIndexOfChildWithName (name=\"%s\") => %u", value_sp.get(), name, idx); 1033 } 1034 return idx; 1035} 1036 1037SBValue 1038SBValue::GetChildMemberWithName (const char *name) 1039{ 1040 lldb::ValueObjectSP value_sp(GetSP()); 1041 if (value_sp) 1042 { 1043 lldb::DynamicValueType use_dynamic_value = eNoDynamicValues; 1044 TargetSP target_sp(value_sp->GetTargetSP()); 1045 if (target_sp) 1046 { 1047 Mutex::Locker api_locker (target_sp->GetAPIMutex()); 1048 use_dynamic_value = target_sp->GetPreferDynamicValue(); 1049 } 1050 return GetChildMemberWithName (name, use_dynamic_value); 1051 } 1052 return SBValue(); 1053} 1054 1055SBValue 1056SBValue::GetChildMemberWithName (const char *name, lldb::DynamicValueType use_dynamic_value) 1057{ 1058 lldb::ValueObjectSP child_sp; 1059 const ConstString str_name (name); 1060 1061 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); 1062 1063 lldb::ValueObjectSP value_sp(GetSP()); 1064 if (value_sp) 1065 { 1066 ProcessSP process_sp(value_sp->GetProcessSP()); 1067 Process::StopLocker stop_locker; 1068 if (process_sp && !stop_locker.TryLock(&process_sp->GetRunLock())) 1069 { 1070 if (log) 1071 log->Printf ("SBValue(%p)::GetChildMemberWithName() => error: process is running", value_sp.get()); 1072 } 1073 else 1074 { 1075 TargetSP target_sp(value_sp->GetTargetSP()); 1076 if (target_sp) 1077 { 1078 Mutex::Locker api_locker (target_sp->GetAPIMutex()); 1079 child_sp = value_sp->GetChildMemberWithName (str_name, true); 1080 } 1081 } 1082 } 1083 1084 SBValue sb_value; 1085 sb_value.SetSP(child_sp, use_dynamic_value, GetPreferSyntheticValue()); 1086 1087 if (log) 1088 log->Printf ("SBValue(%p)::GetChildMemberWithName (name=\"%s\") => SBValue(%p)", value_sp.get(), name, value_sp.get()); 1089 1090 return sb_value; 1091} 1092 1093lldb::SBValue 1094SBValue::GetDynamicValue (lldb::DynamicValueType use_dynamic) 1095{ 1096 SBValue value_sb; 1097 if (IsValid()) 1098 { 1099 ValueImplSP proxy_sp(new ValueImpl(m_opaque_sp->GetRootSP(),use_dynamic,m_opaque_sp->GetUseSynthetic())); 1100 value_sb.SetSP(proxy_sp); 1101 } 1102 return value_sb; 1103} 1104 1105lldb::SBValue 1106SBValue::GetStaticValue () 1107{ 1108 SBValue value_sb; 1109 if (IsValid()) 1110 { 1111 ValueImplSP proxy_sp(new ValueImpl(m_opaque_sp->GetRootSP(),eNoDynamicValues,m_opaque_sp->GetUseSynthetic())); 1112 value_sb.SetSP(proxy_sp); 1113 } 1114 return value_sb; 1115} 1116 1117lldb::SBValue 1118SBValue::GetNonSyntheticValue () 1119{ 1120 SBValue value_sb; 1121 if (IsValid()) 1122 { 1123 ValueImplSP proxy_sp(new ValueImpl(m_opaque_sp->GetRootSP(),m_opaque_sp->GetUseDynamic(),false)); 1124 value_sb.SetSP(proxy_sp); 1125 } 1126 return value_sb; 1127} 1128 1129lldb::DynamicValueType 1130SBValue::GetPreferDynamicValue () 1131{ 1132 if (!IsValid()) 1133 return eNoDynamicValues; 1134 return m_opaque_sp->GetUseDynamic(); 1135} 1136 1137void 1138SBValue::SetPreferDynamicValue (lldb::DynamicValueType use_dynamic) 1139{ 1140 if (IsValid()) 1141 return m_opaque_sp->SetUseDynamic (use_dynamic); 1142} 1143 1144bool 1145SBValue::GetPreferSyntheticValue () 1146{ 1147 if (!IsValid()) 1148 return false; 1149 return m_opaque_sp->GetUseSynthetic(); 1150} 1151 1152void 1153SBValue::SetPreferSyntheticValue (bool use_synthetic) 1154{ 1155 if (IsValid()) 1156 return m_opaque_sp->SetUseSynthetic (use_synthetic); 1157} 1158 1159bool 1160SBValue::IsDynamic() 1161{ 1162 lldb::ValueObjectSP value_sp(GetSP()); 1163 if (value_sp) 1164 { 1165 TargetSP target_sp(value_sp->GetTargetSP()); 1166 if (target_sp) 1167 { 1168 Mutex::Locker api_locker (target_sp->GetAPIMutex()); 1169 return value_sp->IsDynamic(); 1170 } 1171 } 1172 return false; 1173} 1174 1175bool 1176SBValue::IsSynthetic () 1177{ 1178 lldb::ValueObjectSP value_sp(GetSP()); 1179 if (value_sp) 1180 { 1181 TargetSP target_sp(value_sp->GetTargetSP()); 1182 if (target_sp) 1183 { 1184 Mutex::Locker api_locker (target_sp->GetAPIMutex()); 1185 return value_sp->IsSynthetic(); 1186 } 1187 } 1188 return false; 1189} 1190 1191lldb::SBValue 1192SBValue::GetValueForExpressionPath(const char* expr_path) 1193{ 1194 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); 1195 lldb::ValueObjectSP child_sp; 1196 lldb::ValueObjectSP value_sp(GetSP()); 1197 if (value_sp) 1198 { 1199 ProcessSP process_sp(value_sp->GetProcessSP()); 1200 Process::StopLocker stop_locker; 1201 if (process_sp && !stop_locker.TryLock(&process_sp->GetRunLock())) 1202 { 1203 if (log) 1204 log->Printf ("SBValue(%p)::GetValueForExpressionPath() => error: process is running", value_sp.get()); 1205 } 1206 else 1207 { 1208 TargetSP target_sp(value_sp->GetTargetSP()); 1209 if (target_sp) 1210 { 1211 Mutex::Locker api_locker (target_sp->GetAPIMutex()); 1212 // using default values for all the fancy options, just do it if you can 1213 child_sp = value_sp->GetValueForExpressionPath(expr_path); 1214 } 1215 } 1216 } 1217 1218 SBValue sb_value; 1219 sb_value.SetSP(child_sp,GetPreferDynamicValue(),GetPreferSyntheticValue()); 1220 1221 if (log) 1222 log->Printf ("SBValue(%p)::GetValueForExpressionPath (expr_path=\"%s\") => SBValue(%p)", value_sp.get(), expr_path, value_sp.get()); 1223 1224 return sb_value; 1225} 1226 1227int64_t 1228SBValue::GetValueAsSigned(SBError& error, int64_t fail_value) 1229{ 1230 error.Clear(); 1231 lldb::ValueObjectSP value_sp(GetSP()); 1232 if (value_sp) 1233 { 1234 ProcessSP process_sp(value_sp->GetProcessSP()); 1235 Process::StopLocker stop_locker; 1236 if (process_sp && !stop_locker.TryLock(&process_sp->GetRunLock())) 1237 { 1238 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); 1239 if (log) 1240 log->Printf ("SBValue(%p)::GetValueAsSigned() => error: process is running", value_sp.get()); 1241 error.SetErrorString("process is running"); 1242 } 1243 else 1244 { 1245 TargetSP target_sp(value_sp->GetTargetSP()); 1246 if (target_sp) 1247 { 1248 Mutex::Locker api_locker (target_sp->GetAPIMutex()); 1249 Scalar scalar; 1250 if (value_sp->ResolveValue (scalar)) 1251 return scalar.GetRawBits64(fail_value); 1252 else 1253 error.SetErrorString("could not get value"); 1254 } 1255 else 1256 error.SetErrorString("could not get target"); 1257 } 1258 } 1259 error.SetErrorString("invalid SBValue"); 1260 return fail_value; 1261} 1262 1263uint64_t 1264SBValue::GetValueAsUnsigned(SBError& error, uint64_t fail_value) 1265{ 1266 error.Clear(); 1267 lldb::ValueObjectSP value_sp(GetSP()); 1268 if (value_sp) 1269 { 1270 ProcessSP process_sp(value_sp->GetProcessSP()); 1271 Process::StopLocker stop_locker; 1272 if (process_sp && !stop_locker.TryLock(&process_sp->GetRunLock())) 1273 { 1274 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); 1275 if (log) 1276 log->Printf ("SBValue(%p)::GetValueAsUnsigned() => error: process is running", value_sp.get()); 1277 error.SetErrorString("process is running"); 1278 } 1279 else 1280 { 1281 TargetSP target_sp(value_sp->GetTargetSP()); 1282 if (target_sp) 1283 { 1284 Mutex::Locker api_locker (target_sp->GetAPIMutex()); 1285 Scalar scalar; 1286 if (value_sp->ResolveValue (scalar)) 1287 return scalar.GetRawBits64(fail_value); 1288 else 1289 error.SetErrorString("could not get value"); 1290 } 1291 else 1292 error.SetErrorString("could not get target"); 1293 } 1294 } 1295 error.SetErrorString("invalid SBValue"); 1296 return fail_value; 1297} 1298 1299int64_t 1300SBValue::GetValueAsSigned(int64_t fail_value) 1301{ 1302 lldb::ValueObjectSP value_sp(GetSP()); 1303 if (value_sp) 1304 { 1305 ProcessSP process_sp(value_sp->GetProcessSP()); 1306 Process::StopLocker stop_locker; 1307 if (process_sp && !stop_locker.TryLock(&process_sp->GetRunLock())) 1308 { 1309 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); 1310 if (log) 1311 log->Printf ("SBValue(%p)::GetValueAsSigned() => error: process is running", value_sp.get()); 1312 } 1313 else 1314 { 1315 TargetSP target_sp(value_sp->GetTargetSP()); 1316 if (target_sp) 1317 { 1318 Mutex::Locker api_locker (target_sp->GetAPIMutex()); 1319 Scalar scalar; 1320 if (value_sp->ResolveValue (scalar)) 1321 return scalar.GetRawBits64(fail_value); 1322 } 1323 } 1324 } 1325 return fail_value; 1326} 1327 1328uint64_t 1329SBValue::GetValueAsUnsigned(uint64_t fail_value) 1330{ 1331 lldb::ValueObjectSP value_sp(GetSP()); 1332 if (value_sp) 1333 { 1334 ProcessSP process_sp(value_sp->GetProcessSP()); 1335 Process::StopLocker stop_locker; 1336 if (process_sp && !stop_locker.TryLock(&process_sp->GetRunLock())) 1337 { 1338 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); 1339 if (log) 1340 log->Printf ("SBValue(%p)::GetValueAsUnsigned() => error: process is running", value_sp.get()); 1341 } 1342 else 1343 { 1344 TargetSP target_sp(value_sp->GetTargetSP()); 1345 if (target_sp) 1346 { 1347 Mutex::Locker api_locker (target_sp->GetAPIMutex()); 1348 Scalar scalar; 1349 if (value_sp->ResolveValue (scalar)) 1350 return scalar.GetRawBits64(fail_value); 1351 } 1352 } 1353 } 1354 return fail_value; 1355} 1356 1357uint32_t 1358SBValue::GetNumChildren () 1359{ 1360 uint32_t num_children = 0; 1361 1362 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); 1363 lldb::ValueObjectSP value_sp(GetSP()); 1364 if (value_sp) 1365 { 1366 ProcessSP process_sp(value_sp->GetProcessSP()); 1367 Process::StopLocker stop_locker; 1368 if (process_sp && !stop_locker.TryLock(&process_sp->GetRunLock())) 1369 { 1370 if (log) 1371 log->Printf ("SBValue(%p)::GetNumChildren() => error: process is running", value_sp.get()); 1372 } 1373 else 1374 { 1375 TargetSP target_sp(value_sp->GetTargetSP()); 1376 if (target_sp) 1377 { 1378 Mutex::Locker api_locker (target_sp->GetAPIMutex()); 1379 1380 num_children = value_sp->GetNumChildren(); 1381 } 1382 } 1383 } 1384 1385 if (log) 1386 log->Printf ("SBValue(%p)::GetNumChildren () => %u", value_sp.get(), num_children); 1387 1388 return num_children; 1389} 1390 1391 1392SBValue 1393SBValue::Dereference () 1394{ 1395 SBValue sb_value; 1396 lldb::ValueObjectSP value_sp(GetSP()); 1397 if (value_sp) 1398 { 1399 TargetSP target_sp(value_sp->GetTargetSP()); 1400 if (target_sp) 1401 { 1402 Mutex::Locker api_locker (target_sp->GetAPIMutex()); 1403 1404 Error error; 1405 sb_value = value_sp->Dereference (error); 1406 } 1407 } 1408 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); 1409 if (log) 1410 log->Printf ("SBValue(%p)::Dereference () => SBValue(%p)", value_sp.get(), value_sp.get()); 1411 1412 return sb_value; 1413} 1414 1415bool 1416SBValue::TypeIsPointerType () 1417{ 1418 bool is_ptr_type = false; 1419 1420 lldb::ValueObjectSP value_sp(GetSP()); 1421 if (value_sp) 1422 { 1423 TargetSP target_sp(value_sp->GetTargetSP()); 1424 if (target_sp) 1425 { 1426 Mutex::Locker api_locker (target_sp->GetAPIMutex()); 1427 1428 is_ptr_type = value_sp->IsPointerType(); 1429 } 1430 } 1431 1432 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); 1433 if (log) 1434 log->Printf ("SBValue(%p)::TypeIsPointerType () => %i", value_sp.get(), is_ptr_type); 1435 1436 1437 return is_ptr_type; 1438} 1439 1440void * 1441SBValue::GetOpaqueType() 1442{ 1443 lldb::ValueObjectSP value_sp(GetSP()); 1444 if (value_sp) 1445 { 1446 TargetSP target_sp(value_sp->GetTargetSP()); 1447 if (target_sp) 1448 { 1449 Mutex::Locker api_locker (target_sp->GetAPIMutex()); 1450 1451 return value_sp->GetClangType(); 1452 } 1453 } 1454 return NULL; 1455} 1456 1457lldb::SBTarget 1458SBValue::GetTarget() 1459{ 1460 SBTarget sb_target; 1461 TargetSP target_sp; 1462 lldb::ValueObjectSP value_sp(GetSP()); 1463 if (value_sp) 1464 { 1465 target_sp = value_sp->GetTargetSP(); 1466 sb_target.SetSP (target_sp); 1467 } 1468 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); 1469 if (log) 1470 { 1471 if (target_sp.get() == NULL) 1472 log->Printf ("SBValue(%p)::GetTarget () => NULL", value_sp.get()); 1473 else 1474 log->Printf ("SBValue(%p)::GetTarget () => %p", value_sp.get(), target_sp.get()); 1475 } 1476 return sb_target; 1477} 1478 1479lldb::SBProcess 1480SBValue::GetProcess() 1481{ 1482 SBProcess sb_process; 1483 ProcessSP process_sp; 1484 lldb::ValueObjectSP value_sp(GetSP()); 1485 if (value_sp) 1486 { 1487 process_sp = value_sp->GetProcessSP(); 1488 if (process_sp) 1489 sb_process.SetSP (process_sp); 1490 } 1491 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); 1492 if (log) 1493 { 1494 if (process_sp.get() == NULL) 1495 log->Printf ("SBValue(%p)::GetProcess () => NULL", value_sp.get()); 1496 else 1497 log->Printf ("SBValue(%p)::GetProcess () => %p", value_sp.get(), process_sp.get()); 1498 } 1499 return sb_process; 1500} 1501 1502lldb::SBThread 1503SBValue::GetThread() 1504{ 1505 SBThread sb_thread; 1506 ThreadSP thread_sp; 1507 lldb::ValueObjectSP value_sp(GetSP()); 1508 if (value_sp) 1509 { 1510 thread_sp = value_sp->GetThreadSP(); 1511 sb_thread.SetThread(thread_sp); 1512 } 1513 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); 1514 if (log) 1515 { 1516 if (thread_sp.get() == NULL) 1517 log->Printf ("SBValue(%p)::GetThread () => NULL", value_sp.get()); 1518 else 1519 log->Printf ("SBValue(%p)::GetThread () => %p", value_sp.get(), thread_sp.get()); 1520 } 1521 return sb_thread; 1522} 1523 1524lldb::SBFrame 1525SBValue::GetFrame() 1526{ 1527 SBFrame sb_frame; 1528 StackFrameSP frame_sp; 1529 lldb::ValueObjectSP value_sp(GetSP()); 1530 if (value_sp) 1531 { 1532 frame_sp = value_sp->GetFrameSP(); 1533 sb_frame.SetFrameSP (frame_sp); 1534 } 1535 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); 1536 if (log) 1537 { 1538 if (frame_sp.get() == NULL) 1539 log->Printf ("SBValue(%p)::GetFrame () => NULL", value_sp.get()); 1540 else 1541 log->Printf ("SBValue(%p)::GetFrame () => %p", value_sp.get(), frame_sp.get()); 1542 } 1543 return sb_frame; 1544} 1545 1546 1547lldb::ValueObjectSP 1548SBValue::GetSP () const 1549{ 1550 if (!m_opaque_sp || !m_opaque_sp->IsValid()) 1551 return ValueObjectSP(); 1552 return m_opaque_sp->GetSP(); 1553} 1554 1555void 1556SBValue::SetSP (ValueImplSP impl_sp) 1557{ 1558 m_opaque_sp = impl_sp; 1559} 1560 1561void 1562SBValue::SetSP (const lldb::ValueObjectSP &sp) 1563{ 1564 if (sp) 1565 { 1566 lldb::TargetSP target_sp(sp->GetTargetSP()); 1567 if (target_sp) 1568 { 1569 lldb::DynamicValueType use_dynamic = target_sp->GetPreferDynamicValue(); 1570 bool use_synthetic = target_sp->TargetProperties::GetEnableSyntheticValue(); 1571 m_opaque_sp = ValueImplSP(new ValueImpl(sp, use_dynamic, use_synthetic)); 1572 } 1573 else 1574 m_opaque_sp = ValueImplSP(new ValueImpl(sp,eNoDynamicValues,true)); 1575 } 1576 else 1577 m_opaque_sp = ValueImplSP(new ValueImpl(sp,eNoDynamicValues,false)); 1578} 1579 1580void 1581SBValue::SetSP (const lldb::ValueObjectSP &sp, lldb::DynamicValueType use_dynamic) 1582{ 1583 if (sp) 1584 { 1585 lldb::TargetSP target_sp(sp->GetTargetSP()); 1586 if (target_sp) 1587 { 1588 bool use_synthetic = target_sp->TargetProperties::GetEnableSyntheticValue(); 1589 SetSP (sp, use_dynamic, use_synthetic); 1590 } 1591 else 1592 SetSP (sp, use_dynamic, true); 1593 } 1594 else 1595 SetSP (sp, use_dynamic, false); 1596} 1597 1598void 1599SBValue::SetSP (const lldb::ValueObjectSP &sp, bool use_synthetic) 1600{ 1601 if (sp) 1602 { 1603 lldb::TargetSP target_sp(sp->GetTargetSP()); 1604 if (target_sp) 1605 { 1606 lldb::DynamicValueType use_dynamic = target_sp->GetPreferDynamicValue(); 1607 SetSP (sp, use_dynamic, use_synthetic); 1608 } 1609 else 1610 SetSP (sp, eNoDynamicValues, use_synthetic); 1611 } 1612 else 1613 SetSP (sp, eNoDynamicValues, use_synthetic); 1614} 1615 1616void 1617SBValue::SetSP (const lldb::ValueObjectSP &sp, lldb::DynamicValueType use_dynamic, bool use_synthetic) 1618{ 1619 m_opaque_sp = ValueImplSP(new ValueImpl(sp,use_dynamic,use_synthetic)); 1620} 1621 1622bool 1623SBValue::GetExpressionPath (SBStream &description) 1624{ 1625 lldb::ValueObjectSP value_sp(GetSP()); 1626 if (value_sp) 1627 { 1628 value_sp->GetExpressionPath (description.ref(), false); 1629 return true; 1630 } 1631 return false; 1632} 1633 1634bool 1635SBValue::GetExpressionPath (SBStream &description, bool qualify_cxx_base_classes) 1636{ 1637 lldb::ValueObjectSP value_sp(GetSP()); 1638 if (value_sp) 1639 { 1640 value_sp->GetExpressionPath (description.ref(), qualify_cxx_base_classes); 1641 return true; 1642 } 1643 return false; 1644} 1645 1646bool 1647SBValue::GetDescription (SBStream &description) 1648{ 1649 Stream &strm = description.ref(); 1650 1651 lldb::ValueObjectSP value_sp(GetSP()); 1652 if (value_sp) 1653 { 1654 ProcessSP process_sp(value_sp->GetProcessSP()); 1655 Process::StopLocker stop_locker; 1656 if (process_sp && !stop_locker.TryLock(&process_sp->GetRunLock())) 1657 { 1658 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); 1659 if (log) 1660 log->Printf ("SBValue(%p)::GetDescription() => error: process is running", value_sp.get()); 1661 } 1662 else 1663 { 1664 ValueObject::DumpValueObject (strm, value_sp.get()); 1665 } 1666 } 1667 else 1668 strm.PutCString ("No value"); 1669 1670 return true; 1671} 1672 1673lldb::Format 1674SBValue::GetFormat () 1675{ 1676 lldb::ValueObjectSP value_sp(GetSP()); 1677 if (value_sp) 1678 return value_sp->GetFormat(); 1679 return eFormatDefault; 1680} 1681 1682void 1683SBValue::SetFormat (lldb::Format format) 1684{ 1685 lldb::ValueObjectSP value_sp(GetSP()); 1686 if (value_sp) 1687 value_sp->SetFormat(format); 1688} 1689 1690lldb::SBValue 1691SBValue::AddressOf() 1692{ 1693 SBValue sb_value; 1694 lldb::ValueObjectSP value_sp(GetSP()); 1695 if (value_sp) 1696 { 1697 TargetSP target_sp (value_sp->GetTargetSP()); 1698 if (target_sp) 1699 { 1700 Mutex::Locker api_locker (target_sp->GetAPIMutex()); 1701 Error error; 1702 sb_value.SetSP(value_sp->AddressOf (error),GetPreferDynamicValue(), GetPreferSyntheticValue()); 1703 } 1704 } 1705 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); 1706 if (log) 1707 log->Printf ("SBValue(%p)::AddressOf () => SBValue(%p)", value_sp.get(), value_sp.get()); 1708 1709 return sb_value; 1710} 1711 1712lldb::addr_t 1713SBValue::GetLoadAddress() 1714{ 1715 lldb::addr_t value = LLDB_INVALID_ADDRESS; 1716 lldb::ValueObjectSP value_sp(GetSP()); 1717 if (value_sp) 1718 { 1719 TargetSP target_sp (value_sp->GetTargetSP()); 1720 if (target_sp) 1721 { 1722 Mutex::Locker api_locker (target_sp->GetAPIMutex()); 1723 const bool scalar_is_load_address = true; 1724 AddressType addr_type; 1725 value = value_sp->GetAddressOf(scalar_is_load_address, &addr_type); 1726 if (addr_type == eAddressTypeFile) 1727 { 1728 ModuleSP module_sp (value_sp->GetModule()); 1729 if (!module_sp) 1730 value = LLDB_INVALID_ADDRESS; 1731 else 1732 { 1733 Address addr; 1734 module_sp->ResolveFileAddress(value, addr); 1735 value = addr.GetLoadAddress(target_sp.get()); 1736 } 1737 } 1738 else if (addr_type == eAddressTypeHost || addr_type == eAddressTypeInvalid) 1739 value = LLDB_INVALID_ADDRESS; 1740 } 1741 } 1742 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); 1743 if (log) 1744 log->Printf ("SBValue(%p)::GetLoadAddress () => (%llu)", value_sp.get(), value); 1745 1746 return value; 1747} 1748 1749lldb::SBAddress 1750SBValue::GetAddress() 1751{ 1752 Address addr; 1753 lldb::ValueObjectSP value_sp(GetSP()); 1754 if (value_sp) 1755 { 1756 TargetSP target_sp (value_sp->GetTargetSP()); 1757 if (target_sp) 1758 { 1759 lldb::addr_t value = LLDB_INVALID_ADDRESS; 1760 Mutex::Locker api_locker (target_sp->GetAPIMutex()); 1761 const bool scalar_is_load_address = true; 1762 AddressType addr_type; 1763 value = value_sp->GetAddressOf(scalar_is_load_address, &addr_type); 1764 if (addr_type == eAddressTypeFile) 1765 { 1766 ModuleSP module_sp (value_sp->GetModule()); 1767 if (module_sp) 1768 module_sp->ResolveFileAddress(value, addr); 1769 } 1770 else if (addr_type == eAddressTypeLoad) 1771 { 1772 // no need to check the return value on this.. if it can actually do the resolve 1773 // addr will be in the form (section,offset), otherwise it will simply be returned 1774 // as (NULL, value) 1775 addr.SetLoadAddress(value, target_sp.get()); 1776 } 1777 } 1778 } 1779 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); 1780 if (log) 1781 log->Printf ("SBValue(%p)::GetAddress () => (%s,%llu)", value_sp.get(), 1782 (addr.GetSection() ? addr.GetSection()->GetName().GetCString() : "NULL"), 1783 addr.GetOffset()); 1784 return SBAddress(new Address(addr)); 1785} 1786 1787lldb::SBData 1788SBValue::GetPointeeData (uint32_t item_idx, 1789 uint32_t item_count) 1790{ 1791 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); 1792 lldb::SBData sb_data; 1793 lldb::ValueObjectSP value_sp(GetSP()); 1794 if (value_sp) 1795 { 1796 ProcessSP process_sp(value_sp->GetProcessSP()); 1797 Process::StopLocker stop_locker; 1798 if (process_sp && !stop_locker.TryLock(&process_sp->GetRunLock())) 1799 { 1800 if (log) 1801 log->Printf ("SBValue(%p)::GetPointeeData() => error: process is running", value_sp.get()); 1802 } 1803 else 1804 { 1805 TargetSP target_sp (value_sp->GetTargetSP()); 1806 if (target_sp) 1807 { 1808 DataExtractorSP data_sp(new DataExtractor()); 1809 Mutex::Locker api_locker (target_sp->GetAPIMutex()); 1810 value_sp->GetPointeeData(*data_sp, item_idx, item_count); 1811 if (data_sp->GetByteSize() > 0) 1812 *sb_data = data_sp; 1813 } 1814 } 1815 } 1816 if (log) 1817 log->Printf ("SBValue(%p)::GetPointeeData (%d, %d) => SBData(%p)", 1818 value_sp.get(), 1819 item_idx, 1820 item_count, 1821 sb_data.get()); 1822 1823 return sb_data; 1824} 1825 1826lldb::SBData 1827SBValue::GetData () 1828{ 1829 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); 1830 lldb::SBData sb_data; 1831 lldb::ValueObjectSP value_sp(GetSP()); 1832 if (value_sp) 1833 { 1834 ProcessSP process_sp(value_sp->GetProcessSP()); 1835 Process::StopLocker stop_locker; 1836 if (process_sp && !stop_locker.TryLock(&process_sp->GetRunLock())) 1837 { 1838 if (log) 1839 log->Printf ("SBValue(%p)::GetData() => error: process is running", value_sp.get()); 1840 } 1841 else 1842 { 1843 TargetSP target_sp (value_sp->GetTargetSP()); 1844 if (target_sp) 1845 { 1846 Mutex::Locker api_locker (target_sp->GetAPIMutex()); 1847 DataExtractorSP data_sp(new DataExtractor()); 1848 value_sp->GetData(*data_sp); 1849 if (data_sp->GetByteSize() > 0) 1850 *sb_data = data_sp; 1851 } 1852 } 1853 } 1854 if (log) 1855 log->Printf ("SBValue(%p)::GetData () => SBData(%p)", 1856 value_sp.get(), 1857 sb_data.get()); 1858 1859 return sb_data; 1860} 1861 1862lldb::SBDeclaration 1863SBValue::GetDeclaration () 1864{ 1865 lldb::ValueObjectSP value_sp(GetSP()); 1866 SBDeclaration decl_sb; 1867 if (value_sp) 1868 { 1869 Declaration decl; 1870 if (value_sp->GetDeclaration(decl)) 1871 decl_sb.SetDeclaration(decl); 1872 } 1873 return decl_sb; 1874} 1875 1876lldb::SBWatchpoint 1877SBValue::Watch (bool resolve_location, bool read, bool write, SBError &error) 1878{ 1879 SBWatchpoint sb_watchpoint; 1880 1881 // If the SBValue is not valid, there's no point in even trying to watch it. 1882 lldb::ValueObjectSP value_sp(GetSP()); 1883 TargetSP target_sp (GetTarget().GetSP()); 1884 if (value_sp && target_sp) 1885 { 1886 // Can't watch this if the process is running 1887 ProcessSP process_sp(value_sp->GetProcessSP()); 1888 Process::StopLocker stop_locker; 1889 if (process_sp && !stop_locker.TryLock(&process_sp->GetRunLock())) 1890 { 1891 LogSP log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API)); 1892 if (log) 1893 log->Printf ("SBValue(%p)::Watch() => error: process is running", value_sp.get()); 1894 return sb_watchpoint; 1895 } 1896 1897 // Read and Write cannot both be false. 1898 if (!read && !write) 1899 return sb_watchpoint; 1900 1901 // If the value is not in scope, don't try and watch and invalid value 1902 if (!IsInScope()) 1903 return sb_watchpoint; 1904 1905 addr_t addr = GetLoadAddress(); 1906 if (addr == LLDB_INVALID_ADDRESS) 1907 return sb_watchpoint; 1908 size_t byte_size = GetByteSize(); 1909 if (byte_size == 0) 1910 return sb_watchpoint; 1911 1912 uint32_t watch_type = 0; 1913 if (read) 1914 watch_type |= LLDB_WATCH_TYPE_READ; 1915 if (write) 1916 watch_type |= LLDB_WATCH_TYPE_WRITE; 1917 1918 Error rc; 1919 WatchpointSP watchpoint_sp = target_sp->CreateWatchpoint(addr, byte_size, watch_type, rc); 1920 error.SetError(rc); 1921 1922 if (watchpoint_sp) 1923 { 1924 sb_watchpoint.SetSP (watchpoint_sp); 1925 Declaration decl; 1926 if (value_sp->GetDeclaration (decl)) 1927 { 1928 if (decl.GetFile()) 1929 { 1930 StreamString ss; 1931 // True to show fullpath for declaration file. 1932 decl.DumpStopContext(&ss, true); 1933 watchpoint_sp->SetDeclInfo(ss.GetString()); 1934 } 1935 } 1936 } 1937 } 1938 return sb_watchpoint; 1939} 1940 1941// FIXME: Remove this method impl (as well as the decl in .h) once it is no longer needed. 1942// Backward compatibility fix in the interim. 1943lldb::SBWatchpoint 1944SBValue::Watch (bool resolve_location, bool read, bool write) 1945{ 1946 SBError error; 1947 return Watch(resolve_location, read, write, error); 1948} 1949 1950lldb::SBWatchpoint 1951SBValue::WatchPointee (bool resolve_location, bool read, bool write, SBError &error) 1952{ 1953 SBWatchpoint sb_watchpoint; 1954 if (IsInScope() && GetType().IsPointerType()) 1955 sb_watchpoint = Dereference().Watch (resolve_location, read, write, error); 1956 return sb_watchpoint; 1957} 1958