24#include "lldb/Host/Config.h"
68#include "llvm/ADT/STLExtras.h"
69#include "llvm/ADT/StringRef.h"
70#include "llvm/ADT/iterator.h"
71#include "llvm/Config/llvm-config.h"
72#include "llvm/Support/DynamicLibrary.h"
73#include "llvm/Support/FileSystem.h"
74#include "llvm/Support/Process.h"
75#include "llvm/Support/ThreadPool.h"
76#include "llvm/Support/Threading.h"
77#include "llvm/Support/raw_ostream.h"
89#include <system_error>
110 static std::mutex g_mutex;
121 "Never show disassembly when displaying a stop context.",
126 "Show disassembly when there is no debug information.",
131 "Show disassembly when there is no source information, or the source "
133 "is missing when displaying a stop context.",
138 "Always show disassembly when displaying a stop context.",
146 "Disable scripting languages.",
151 "Select python as the default scripting language.",
156 "Select the lldb default as the default scripting language.",
162 "Use no verbosity when running dwim-print."},
164 "Use partial verbosity when running dwim-print - display a message when "
165 "`expression` evaluation is used."},
167 "Use full verbosity when running dwim-print."},
174 "Highlight the stop column with ANSI terminal codes when color/ANSI "
175 "mode is enabled; otherwise, fall back to using a text-only caret (^) "
176 "as if \"caret-only\" mode was selected.",
181 "Highlight the stop column with ANSI terminal codes when running LLDB "
182 "with color/ANSI enabled.",
187 "Highlight the stop column with a caret character (^) underneath the "
188 "stop column. This method introduces a new line in source listings "
189 "that display thread stop locations.",
194 "Do not highlight the stop column.",
198#define LLDB_PROPERTIES_debugger
199#include "CoreProperties.inc"
202#define LLDB_PROPERTIES_debugger
203#include "CorePropertiesEnum.inc"
207#define LLDB_PROPERTIES_testing
208#include "CoreProperties.inc"
211#define LLDB_PROPERTIES_testing
212#include "CorePropertiesEnum.inc"
220 const llvm::SmallVector<llvm::StringRef> kVendorSafePaths = {
221#include "SafeAutoloadPaths.inc"
224 for (
auto path : kVendorSafePaths) {
225 assert(!path.empty());
244 const uint32_t idx = ePropertyInjectVarLocListError;
246 idx, g_testing_properties[idx].default_uint_value != 0);
251 return g_testing_properties;
255 const uint32_t idx = ePropertySafeAutoloadPaths;
258 assert(option_value);
263 const uint32_t idx = ePropertySafeAutoloadPaths;
266 assert(option_value);
271 const uint32_t idx = ePropertySafeAutoloadPaths;
280 llvm::StringRef property_path,
281 llvm::StringRef value) {
282 bool is_load_script =
283 (property_path ==
"target.load-script-from-symbol-file");
285 bool invalidate_data_vis = (property_path ==
"escape-non-printables");
286 invalidate_data_vis |=
287 (property_path ==
"target.max-zero-padding-in-float-format");
288 if (invalidate_data_vis) {
294 if (is_load_script && exe_ctx && exe_ctx->
GetTargetSP()) {
296 load_script_old_value =
297 target_sp->TargetProperties::GetLoadScriptFromSymbolFile();
300 if (
error.Success()) {
302 if (property_path == g_debugger_properties[ePropertyPrompt].name) {
303 llvm::StringRef new_prompt =
GetPrompt();
309 auto bytes = std::make_unique<EventDataBytes>(new_prompt);
310 auto prompt_change_event_sp = std::make_shared<Event>(
313 }
else if (property_path == g_debugger_properties[ePropertyUseColor].name) {
317 }
else if (property_path ==
318 g_debugger_properties[ePropertyPromptAnsiPrefix].name ||
320 g_debugger_properties[ePropertyPromptAnsiSuffix].name) {
324 }
else if (property_path ==
325 g_debugger_properties[ePropertyShowStatusline].name) {
335 }
else if (property_path ==
336 g_debugger_properties[ePropertyStatuslineFormat].name ||
338 g_debugger_properties[ePropertySeparator].name) {
341 }
else if (property_path ==
342 g_debugger_properties[ePropertyUseSourceCache].name) {
348 }
else if (is_load_script && target_sp &&
350 if (target_sp->TargetProperties::GetLoadScriptFromSymbolFile() ==
352 std::list<Status> errors;
353 if (!target_sp->LoadScriptingResources(errors)) {
355 for (
auto &
error : errors)
356 s->Printf(
"%s\n",
error.AsCString());
365 constexpr uint32_t idx = ePropertyAutoConfirm;
367 idx, g_debugger_properties[idx].default_uint_value != 0);
371 constexpr uint32_t idx = ePropertyDisassemblyFormat;
376 constexpr uint32_t idx = ePropertyFrameFormat;
381 constexpr uint32_t idx = ePropertyFrameFormatUnique;
386 constexpr uint32_t idx = ePropertyStopDisassemblyMaxSize;
388 idx, g_debugger_properties[idx].default_uint_value);
392 constexpr uint32_t idx = ePropertyNotiftVoid;
394 idx, g_debugger_properties[idx].default_uint_value != 0);
398 constexpr uint32_t idx = ePropertyPrompt;
400 idx, g_debugger_properties[idx].default_cstr_value);
404 const uint32_t idx = ePropertyPromptAnsiPrefix;
406 idx, g_debugger_properties[idx].default_cstr_value);
410 const uint32_t idx = ePropertyPromptAnsiSuffix;
412 idx, g_debugger_properties[idx].default_cstr_value);
416 constexpr uint32_t idx = ePropertyPrompt;
418 llvm::StringRef new_prompt =
GetPrompt();
427 constexpr uint32_t idx = ePropertyThreadFormat;
432 constexpr uint32_t idx = ePropertyThreadStopFormat;
437 const uint32_t idx = ePropertyScriptLanguage;
440 g_debugger_properties[idx].default_uint_value));
444 const uint32_t idx = ePropertyScriptLanguage;
449 const uint32_t idx = ePropertyREPLLanguage;
454 const uint32_t idx = ePropertyREPLLanguage;
459 const uint32_t idx = ePropertyTerminalWidth;
461 idx, g_debugger_properties[idx].default_uint_value);
465 const uint32_t idx = ePropertyTerminalWidth;
469 handler_sp->TerminalSizeChanged();
481 const uint32_t idx = ePropertyTerminalHeight;
483 idx, g_debugger_properties[idx].default_uint_value);
487 const uint32_t idx = ePropertyTerminalHeight;
491 handler_sp->TerminalSizeChanged();
503 const uint32_t idx = ePropertyUseExternalEditor;
505 idx, g_debugger_properties[idx].default_uint_value != 0);
509 const uint32_t idx = ePropertyUseExternalEditor;
514 const uint32_t idx = ePropertyExternalEditor;
516 idx, g_debugger_properties[idx].default_cstr_value);
520 const uint32_t idx = ePropertyExternalEditor;
525 const uint32_t idx = ePropertyUseColor;
527 idx, g_debugger_properties[idx].default_uint_value != 0);
531 const uint32_t idx = ePropertyUseColor;
540 const uint32_t idx = ePropertyShowProgress;
542 idx, g_debugger_properties[idx].default_uint_value != 0);
546 const uint32_t idx = ePropertyShowProgress;
551 const uint32_t idx = ePropertyShowProgressAnsiPrefix;
553 idx, g_debugger_properties[idx].default_cstr_value);
557 const uint32_t idx = ePropertyShowProgressAnsiSuffix;
559 idx, g_debugger_properties[idx].default_cstr_value);
563 const uint32_t idx = ePropertyShowStatusline;
565 idx, g_debugger_properties[idx].default_uint_value != 0);
569 constexpr uint32_t idx = ePropertyStatuslineFormat;
574 constexpr uint32_t idx = ePropertyStatuslineFormat;
581 constexpr uint32_t idx = ePropertySeparator;
583 idx, g_debugger_properties[idx].default_cstr_value);
587 const uint32_t idx = ePropertyShowDisabledAnsiPrefix;
589 idx, g_debugger_properties[idx].default_cstr_value);
593 const uint32_t idx = ePropertyShowDisabledAnsiSuffix;
595 idx, g_debugger_properties[idx].default_cstr_value);
599 constexpr uint32_t idx = ePropertySeparator;
606 const uint32_t idx = ePropertyShowAutosuggestion;
608 idx, g_debugger_properties[idx].default_uint_value != 0);
612 const uint32_t idx = ePropertyShowAutosuggestionAnsiPrefix;
614 idx, g_debugger_properties[idx].default_cstr_value);
618 const uint32_t idx = ePropertyShowAutosuggestionAnsiSuffix;
620 idx, g_debugger_properties[idx].default_cstr_value);
624 const uint32_t idx = ePropertyShowRegexMatchAnsiPrefix;
626 idx, g_debugger_properties[idx].default_cstr_value);
630 const uint32_t idx = ePropertyShowRegexMatchAnsiSuffix;
632 idx, g_debugger_properties[idx].default_cstr_value);
636 const uint32_t idx = ePropertyShowDontUsePoHint;
638 idx, g_debugger_properties[idx].default_uint_value != 0);
642 const uint32_t idx = ePropertyUseSourceCache;
644 idx, g_debugger_properties[idx].default_uint_value != 0);
648 const uint32_t idx = ePropertyUseSourceCache;
657 const uint32_t idx = ePropertyMarkHiddenFrames;
659 idx, g_debugger_properties[idx].default_uint_value != 0);
663 const uint32_t idx = ePropertyHighlightSource;
665 idx, g_debugger_properties[idx].default_uint_value != 0);
669 const uint32_t idx = ePropertyStopShowColumn;
672 g_debugger_properties[idx].default_uint_value));
676 const uint32_t idx = ePropertyStopShowColumnAnsiPrefix;
678 idx, g_debugger_properties[idx].default_cstr_value);
682 const uint32_t idx = ePropertyStopShowColumnAnsiSuffix;
684 idx, g_debugger_properties[idx].default_cstr_value);
688 const uint32_t idx = ePropertyStopShowLineMarkerAnsiPrefix;
690 idx, g_debugger_properties[idx].default_cstr_value);
694 const uint32_t idx = ePropertyStopShowLineMarkerAnsiSuffix;
696 idx, g_debugger_properties[idx].default_cstr_value);
701 before ? ePropertyStopLineCountBefore : ePropertyStopLineCountAfter;
703 idx, g_debugger_properties[idx].default_uint_value);
707 const uint32_t idx = ePropertyStopDisassemblyDisplay;
710 g_debugger_properties[idx].default_uint_value));
714 const uint32_t idx = ePropertyStopDisassemblyCount;
716 idx, g_debugger_properties[idx].default_uint_value);
720 const uint32_t idx = ePropertyAutoOneLineSummaries;
722 idx, g_debugger_properties[idx].default_uint_value != 0);
726 const uint32_t idx = ePropertyEscapeNonPrintables;
728 idx, g_debugger_properties[idx].default_uint_value != 0);
732 const uint32_t idx = ePropertyAutoIndent;
734 idx, g_debugger_properties[idx].default_uint_value != 0);
738 const uint32_t idx = ePropertyAutoIndent;
743 const uint32_t idx = ePropertyPrintDecls;
745 idx, g_debugger_properties[idx].default_uint_value != 0);
749 const uint32_t idx = ePropertyPrintDecls;
754 const uint32_t idx = ePropertyTabSize;
756 idx, g_debugger_properties[idx].default_uint_value);
760 const uint32_t idx = ePropertyTabSize;
765 const uint32_t idx = ePropertyDWIMPrintVerbosity;
768 g_debugger_properties[idx].default_uint_value != 0));
772 const uint32_t idx = ePropertyShowInlineDiagnostics;
774 idx, g_debugger_properties[idx].default_uint_value);
778 const uint32_t idx = ePropertyShowInlineDiagnostics;
793 "Debugger::Initialize called more than once!");
796 g_thread_pool =
new llvm::DefaultThreadPool(llvm::optimal_concurrency());
802 "Debugger::Terminate called without a matching Debugger::Initialize!");
808 debugger->HandleDestroyCallback();
835 llvm::sys::DynamicLibrary dynlib =
837 if (dynlib.isValid()) {
852 llvm::StringRef path) {
855 static constexpr llvm::StringLiteral g_dylibext(
".dylib");
856 static constexpr llvm::StringLiteral g_solibext(
".so");
863 namespace fs = llvm::sys::fs;
868 if (ft == fs::file_type::regular_file || ft == fs::file_type::symlink_file ||
869 ft == fs::file_type::type_unknown) {
879 debugger->
LoadPlugin(plugin_file_spec, plugin_load_error);
882 }
else if (ft == fs::file_type::directory_file ||
883 ft == fs::file_type::symlink_file ||
884 ft == fs::file_type::type_unknown) {
896 const bool find_directories =
true;
897 const bool find_files =
true;
898 const bool find_other =
true;
900 if (
FileSpec dir_spec = HostInfo::GetSystemPluginDir()) {
902 dir_spec.GetPath(dir_path,
sizeof(dir_path))) {
904 find_files, find_other,
909 if (
FileSpec dir_spec = HostInfo::GetUserPluginDir()) {
911 dir_spec.GetPath(dir_path,
sizeof(dir_path))) {
913 find_files, find_other,
929 helper.SetDebugger(debugger_sp.get());
935 debugger_sp->InstanceInitialize();
969 debugger_sp->HandleDestroyCallback();
976 (*debugger_sp->GetAsyncOutputStream())
979 (*debugger_sp->GetAsyncErrorStream()) << result.
GetErrorString() <<
'\n';
982 debugger_sp->Clear();
988 if ((*pos).get() == debugger_sp.get()) {
1003 if (llvm::StringRef(debugger_sp->GetInstanceName()) == instance_name)
1011 static constexpr llvm::StringLiteral class_name(
"lldb.debugger");
1041 "target",
"Settings specify to debugging targets.",
true,
1044 "platform",
"Platform settings.",
true,
1047 "symbols",
"Symbol lookup and cache settings.",
true,
1055 "Settings specify to the debugger's command interpreter.",
true,
1060 "testing",
"Testing-only settings.",
true,
1066 std::make_shared<CallbackLogHandler>(log_callback, baton);
1070 assert(default_platform_sp);
1077 arch = HostInfo::GetArchitecture();
1078 assert(arch.
IsValid() &&
"No valid default or host archspec");
1079 const bool is_dummy_target =
true;
1081 new Target(*
this, arch, default_platform_sp, is_dummy_target));
1087 ePropertyTerminalWidth);
1092 ePropertyTerminalHeight);
1096 const char *term = getenv(
"TERM");
1097 auto disable_color = [&]() {
1102 if (term && !strcmp(term,
"dumb"))
1110 [
this](
const FileSpec &dir) -> llvm::Error {
1112 llvm::StringRef log_path = entry.first();
1113 llvm::StringRef file_name = llvm::sys::path::filename(log_path);
1115 std::error_code ec =
1116 llvm::sys::fs::copy_file(log_path, destination.
GetPath());
1118 return llvm::errorCodeToError(ec);
1120 return llvm::Error::success();
1124#if defined(_WIN32) && defined(ENABLE_VIRTUAL_TERMINAL_PROCESSING)
1127 llvm::sys::Process::UseANSIEscapeCodes(
true);
1156 if (
ProcessSP process_sp = target_sp->GetProcessSP())
1157 process_sp->Finalize(
false );
1158 target_sp->Destroy();
1183static inline int OpenPipe(
int fds[2], std::size_t size) {
1185 return _pipe(fds, size, O_BINARY);
1195 int fds[2] = {-1, -1};
1197 if (data ==
nullptr) {
1202 size_t size = strlen(data);
1210 "can't create pipe file descriptors for LLDB commands");
1214 int r = write(fds[
WRITE], data, size);
1218 llvm::sys::Process::SafelyCloseFileDescriptor(fds[
WRITE]);
1222 FILE *commands_file = fdopen(fds[
READ],
"rb");
1223 if (commands_file ==
nullptr) {
1225 "fdopen(%i, \"rb\") failed (errno = %i) "
1226 "when trying to open LLDB commands pipe",
1228 llvm::sys::Process::SafelyCloseFileDescriptor(fds[
READ]);
1238 assert(file_sp && file_sp->IsValid());
1246 assert(file_sp && file_sp->IsValid());
1252 assert(file_sp && file_sp->IsValid());
1278 std::optional<ExecutionContextRef> exe_ctx_ref) {
1288 bool adopt_selected =
true;
1304 reader_sp->Interrupt();
1311 reader_sp->GotEOF();
1333 std::lock_guard<std::recursive_mutex> guard(
1339 if (top_reader_sp && top_reader_sp->GetIsDone())
1356 while (top_reader_sp) {
1357 top_reader_sp->Run();
1360 if (top_reader_sp.get() == reader_sp.get()) {
1369 if (top_reader_sp && top_reader_sp->GetIsDone()) {
1372 if (top_reader_sp.get() == reader_sp.get())
1396 locked_stream.
Write(s, len);
1417 bool cancel_top_handler) {
1432 if (!in || !in->IsValid()) {
1434 in = top_reader_sp->GetInputFileSP();
1443 if (!out || !out->GetUnlockedFile().IsValid()) {
1445 out = top_reader_sp->GetOutputStreamFileSP();
1454 if (!err || !err->GetUnlockedFile().IsValid()) {
1456 err = top_reader_sp->GetErrorStreamFileSP();
1467 bool cancel_top_handler) {
1477 if (reader_sp == top_reader_sp)
1482 reader_sp->Activate();
1486 if (top_reader_sp) {
1487 top_reader_sp->Deactivate();
1488 if (cancel_top_handler)
1489 top_reader_sp->Cancel();
1506 if (pop_reader_sp != reader_sp)
1509 reader_sp->Deactivate();
1510 reader_sp->Cancel();
1515 reader_sp->Activate();
1524 reader_sp->Refresh();
1528 return std::make_unique<StreamAsynchronousIO>(*
this,
1533 return std::make_unique<StreamAsynchronousIO>(*
this,
1561 std::string function_name,
const llvm::formatv_object_base &payload)
1566 desc << payload <<
"\n";
1580 if (debugger_sp->InterruptRequested())
1581 result.push_back(debugger_sp);
1600 if (index < g_debugger_list_ptr->size())
1612 if (debugger_sp->GetID() ==
id)
1626 if (format ==
nullptr) {
1630 format = &format_entry;
1632 if (format ==
nullptr) {
1634 format = &format_entry;
1637 bool function_changed =
false;
1638 bool initial_function =
false;
1644 function_changed =
true;
1648 function_changed =
true;
1658 initial_function =
true;
1666 llvm::StringRef backtrace,
1667 llvm::StringRef prompt) {
1679 std::make_shared<CallbackLogHandler>(log_callback, baton);
1702 if (it->token == token) {
1711 std::string title, std::string details,
1712 uint64_t completed, uint64_t total,
1713 bool is_debugger_specific,
1714 uint32_t progress_broadcast_bit) {
1720 progress_broadcast_bit,
1722 completed, total, is_debugger_specific)));
1727 std::string details, uint64_t completed,
1729 std::optional<lldb::user_id_t> debugger_id,
1730 uint32_t progress_broadcast_bit) {
1738 std::move(details), completed, total,
1740 progress_broadcast_bit);
1751 progress_broadcast_bit);
1756 std::string message,
1757 bool debugger_specific) {
1758 uint32_t event_type = 0;
1761 assert(
false &&
"eSeverityInfo should not be broadcast");
1780 EventSP event_sp = std::make_shared<Event>(
1787 std::optional<lldb::user_id_t> debugger_id,
1788 std::once_flag *once) {
1789 auto ReportDiagnosticLambda = [&]() {
1822 std::call_once(*once, ReportDiagnosticLambda);
1824 ReportDiagnosticLambda();
1828 std::optional<lldb::user_id_t> debugger_id,
1829 std::once_flag *once) {
1834 std::optional<lldb::user_id_t> debugger_id,
1835 std::once_flag *once) {
1840 std::optional<lldb::user_id_t> debugger_id,
1841 std::once_flag *once) {
1851 EventSP event_sp = std::make_shared<Event>(
1854 debugger_sp->GetBroadcaster().BroadcastEvent(event_sp);
1858static std::shared_ptr<LogHandler>
1860 size_t buffer_size) {
1861 switch (log_handler_kind) {
1863 return std::make_shared<StreamLogHandler>(fd, should_close, buffer_size);
1865 return std::make_shared<RotatingLogHandler>(buffer_size);
1867 return std::make_shared<SystemLogHandler>();
1875 llvm::ArrayRef<const char *> categories,
1876 llvm::StringRef log_file, uint32_t log_options,
1878 llvm::raw_ostream &error_stream) {
1880 std::shared_ptr<LogHandler> log_handler_sp;
1886 }
else if (log_file.empty()) {
1889 false, buffer_size);
1893 log_handler_sp = pos->second.lock();
1894 if (!log_handler_sp) {
1902 FileSpec(log_file), flags, lldb::eFilePermissionsFileDefault,
false);
1904 error_stream <<
"Unable to open log file '" << log_file
1905 <<
"': " << llvm::toString(file.takeError()) <<
"\n";
1915 assert(log_handler_sp);
1917 if (log_options == 0)
1926 std::optional<lldb::ScriptLanguage> language) {
1949 using namespace lldb;
1950 const uint32_t event_type =
1967 if (event_type & eBreakpointEventTypeLocationsAdded) {
1968 uint32_t num_new_locations =
1971 if (num_new_locations > 0) {
1975 output_up->Printf(
"%d location%s added to breakpoint %d\n",
1976 num_new_locations, num_new_locations == 1 ?
"" :
"s",
1977 breakpoint->GetID());
1995 bool flush_stderr) {
1996 const auto &flush = [&](
Stream &stream,
2001 while ((len = (process.*get)(buffer,
sizeof(buffer),
error)) > 0)
2002 stream.
Write(buffer, len);
2015 const uint32_t event_type = event_sp->GetType();
2026 bool pop_process_io_handler =
false;
2029 bool state_is_stopped =
false;
2030 const bool got_state_changed =
2034 const bool got_structured_data =
2037 if (got_state_changed) {
2044 if (got_state_changed && !state_is_stopped) {
2049 pop_process_io_handler);
2054 got_stderr || got_state_changed);
2057 if (got_structured_data) {
2061 auto structured_data_sp =
2065 plugin_sp->GetDescription(structured_data_sp, content_stream);
2066 if (
error.Success()) {
2067 if (!content_stream.
GetString().empty()) {
2070 content_stream.
Flush();
2073 output_stream_up->PutCString(content_stream.
GetString());
2076 error_stream_up->Format(
"Failed to print structured "
2077 "data with plugin {0}: {1}",
2078 plugin_sp->GetPluginName(),
error);
2084 if (got_state_changed && state_is_stopped) {
2087 pop_process_io_handler);
2090 output_stream_up->Flush();
2091 error_stream_up->Flush();
2093 if (pop_process_io_handler)
2094 process_sp->PopProcessIOHandler();
2102 const uint32_t event_type = event_sp->GetType();
2103 const bool stop_format =
true;
2133 static std::once_flag g_once_flag;
2134 static bool g_supports_osc_progress =
false;
2136 std::call_once(g_once_flag, []() {
2139 if (
const char *term_program = std::getenv(
"TERM_PROGRAM")) {
2140 llvm::StringRef term_program_str(term_program);
2141 if (term_program_str.starts_with(
"ghostty") ||
2142 term_program_str.starts_with(
"wezterm")) {
2143 g_supports_osc_progress =
true;
2149 std::array<const char *, 3> known_env_vars = {
2151 "GHOSTTY_RESOURCES_DIR",
2154 for (
const char *env_var : known_env_vars) {
2155 if (std::getenv(env_var)) {
2156 g_supports_osc_progress =
true;
2162 return g_supports_osc_progress;
2168 File &file = stream_sp->GetUnlockedFile();
2199 broadcaster_class_process,
2210 process_event_spec);
2213 listener_sp->StartListeningForEvents(
2219 listener_sp->StartListeningForEvents(
2240 if (listener_sp->GetEvent(event_sp, std::nullopt)) {
2241 std::optional<ExecutionContextRef> exe_ctx_ref = std::nullopt;
2243 Broadcaster *broadcaster = event_sp->GetBroadcaster();
2245 uint32_t event_type = event_sp->GetType();
2247 if (broadcaster_class == broadcaster_class_process) {
2252 }
else if (broadcaster_class == broadcaster_class_target) {
2257 }
else if (broadcaster_class == broadcaster_class_thread) {
2266 }
else if (event_type &
2268 const char *data =
static_cast<const char *
>(
2270 if (data && data[0]) {
2272 error_up->PutCString(data);
2276 eBroadcastBitAsynchronousOutputData) {
2277 const char *data =
static_cast<const char *
>(
2279 if (data && data[0]) {
2281 output_up->PutCString(data);
2318 ConstString full_name(
"lldb.debugger.event-handler");
2323 llvm::StringRef thread_name =
2324 full_name.
GetLength() < llvm::get_max_thread_name_length()
2326 :
"dbg.evt-handler";
2329 llvm::Expected<HostThread> event_handler_thread =
2334 if (event_handler_thread) {
2338 "failed to launch host thread: {0}");
2347 listener_sp->GetEvent(event_sp, std::nullopt);
2372 ProgressReport progress_report{data->GetID(), data->GetCompleted(),
2373 data->GetTotal(), data->GetMessage()};
2381 return report.id == progress_report.
id;
2384 const bool complete = data->GetCompleted() == data->GetTotal();
2388 *it = progress_report;
2420std::optional<Debugger::ProgressReport>
2424 return std::nullopt;
2451 if (io_handler_thread) {
2455 "failed to launch host thread: {0}");
2483 if (!prefer_dummy) {
2501 language = *single_lang;
2502 }
else if (repl_languages.
Empty()) {
2504 "LLDB isn't configured with REPL support for any languages.");
2508 "Multiple possible REPL languages. Please specify a language.");
2524 "couldn't find a REPL for %s",
2529 repl_sp->SetCompilerOptions(repl_options);
2537 "Debugger::GetThreadPool called before Debugger::Initialize");
2542 llvm::StringRef name,
bool value,
2543 llvm::StringRef description) {
2544 auto entry_up = std::make_unique<StructuredData::Dictionary>();
2545 entry_up->AddBooleanItem(
"value", value);
2546 entry_up->AddStringItem(
"description", description);
2547 dict.
AddItem(name, std::move(entry_up));
2551 auto array_up = std::make_unique<StructuredData::Array>();
2552#define LLVM_TARGET(target) \
2553 array_up->AddItem(std::make_unique<StructuredData::String>(#target));
2554#include "llvm/Config/Targets.def"
2555 auto entry_up = std::make_unique<StructuredData::Dictionary>();
2556 entry_up->AddItem(
"value", std::move(array_up));
2557 entry_up->AddStringItem(
"description",
"A list of configured LLVM targets.");
2558 dict.
AddItem(
"targets", std::move(entry_up));
2562 auto config_up = std::make_unique<StructuredData::Dictionary>();
2565 "A boolean value that indicates if XML support is enabled in LLDB");
2567 *config_up,
"curl", LLVM_ENABLE_CURL,
2568 "A boolean value that indicates if CURL support is enabled in LLDB");
2570 *config_up,
"curses", LLDB_ENABLE_CURSES,
2571 "A boolean value that indicates if curses support is enabled in LLDB");
2573 *config_up,
"editline", LLDB_ENABLE_LIBEDIT,
2574 "A boolean value that indicates if editline support is enabled in LLDB");
2576 "A boolean value that indicates if editline wide "
2577 "characters support is enabled in LLDB");
2579 *config_up,
"zlib", LLVM_ENABLE_ZLIB,
2580 "A boolean value that indicates if zlib support is enabled in LLDB");
2582 *config_up,
"lzma", LLDB_ENABLE_LZMA,
2583 "A boolean value that indicates if lzma support is enabled in LLDB");
2585 *config_up,
"python", LLDB_ENABLE_PYTHON,
2586 "A boolean value that indicates if python support is enabled in LLDB");
2588 *config_up,
"lua", LLDB_ENABLE_LUA,
2589 "A boolean value that indicates if lua support is enabled in LLDB");
2598 for (
const auto &fspec :
#define OSC_PROGRESS_REMOVE
#define OSC_PROGRESS_INDETERMINATE
#define OSC_PROGRESS_SHOW
static llvm::raw_ostream & error(Stream &strm)
static bool RequiresFollowChildWorkaround(const Process &process)
static llvm::DefaultThreadPool * g_thread_pool
static constexpr OptionEnumValueElement g_show_disassembly_enum_values[]
static const FileSpecList & GetDefaultSafeAutoLoadPaths()
static bool TerminalSupportsOSCProgress()
Conservative heuristic to detect whether OSC 9;4 progress is supported by the current terminal.
static lldb::user_id_t g_unique_id
static constexpr OptionEnumValueElement g_language_enumerators[]
static void PrivateReportDiagnostic(Debugger &debugger, Severity severity, std::string message, bool debugger_specific)
static constexpr OptionEnumValueElement g_dwim_print_verbosities[]
static constexpr OptionEnumValueElement s_stop_show_column_values[]
static void PrivateReportProgress(Debugger &debugger, uint64_t progress_id, std::string title, std::string details, uint64_t completed, uint64_t total, bool is_debugger_specific, uint32_t progress_broadcast_bit)
static Debugger::DebuggerList * g_debugger_list_ptr
static int OpenPipe(int fds[2], std::size_t size)
static size_t g_debugger_event_thread_stack_bytes
static std::mutex & GetDebuggerListMutex()
static FileSystem::EnumerateDirectoryResult LoadPluginCallback(void *baton, llvm::sys::fs::file_type ft, llvm::StringRef path)
static std::shared_ptr< LogHandler > CreateLogHandler(LogHandlerKind log_handler_kind, int fd, bool should_close, size_t buffer_size)
static void AddBoolConfigEntry(StructuredData::Dictionary &dict, llvm::StringRef name, bool value, llvm::StringRef description)
static void AddLLVMTargets(StructuredData::Dictionary &dict)
#define LLDB_LOG(log,...)
The LLDB_LOG* macros defined below are the way to emit log messages.
#define LLDB_LOG_OPTION_APPEND
#define LLDB_LOG_ERROR(log, error,...)
#define LLDB_LOG_OPTION_PREPEND_TIMESTAMP
#define LLDB_LOG_OPTION_PREPEND_THREAD_NAME
A section + offset based address class.
An architecture specification class.
bool IsValid() const
Tests if this ArchSpec is valid.
static lldb::BreakpointEventType GetBreakpointEventTypeFromEvent(const lldb::EventSP &event_sp)
static lldb::BreakpointSP GetBreakpointFromEvent(const lldb::EventSP &event_sp)
static const BreakpointEventData * GetEventDataFromEvent(const Event *event_sp)
static size_t GetNumBreakpointLocationsFromEvent(const lldb::EventSP &event_sp)
An event broadcasting class.
bool EventTypeHasListeners(uint32_t event_type)
virtual llvm::StringRef GetBroadcasterClass() const
This needs to be filled in if you are going to register the broadcaster with the broadcaster manager ...
void BroadcastEvent(lldb::EventSP &event_sp)
Broadcast an event which has no associated data.
void UpdatePrompt(llvm::StringRef prompt)
void UpdateUseColor(bool use_color)
@ eBroadcastBitAsynchronousOutputData
@ eBroadcastBitQuitCommandReceived
@ eBroadcastBitAsynchronousErrorData
@ eBroadcastBitResetPrompt
bool WasInterrupted() const
bool SaveTranscript(CommandReturnObject &result, std::optional< std::string > output_file=std::nullopt)
Save the current debugger session transcript to a file on disk.
bool GetSaveSessionOnQuit() const
std::string GetErrorString(bool with_diagnostics=true) const
Return the errors as a string.
llvm::StringRef GetOutputString() const
A uniqued constant string class.
const char * AsCString(const char *value_if_empty=nullptr) const
Get the string value as a C string.
size_t GetLength() const
Get the length in bytes of string value.
llvm::StringRef GetStringRef() const
Get the string value as a llvm::StringRef.
static void ForceUpdate()
std::string m_function_name
const std::chrono::time_point< std::chrono::system_clock > m_interrupt_time
const uint64_t m_thread_id
InterruptionReport(std::string function_name, std::string description)
std::string m_description
A class to manage flag bits.
static void AssertCallback(llvm::StringRef message, llvm::StringRef backtrace, llvm::StringRef prompt)
llvm::StringRef GetAutosuggestionAnsiPrefix() const
bool SetUseExternalEditor(bool use_external_editor_p)
PlatformList m_platform_list
HostThread m_event_handler_thread
FormatEntity::Entry GetDisassemblyFormat() const
uint64_t GetDisassemblyLineCount() const
lldb::TargetSP GetSelectedTarget()
llvm::StringRef GetDisabledAnsiSuffix() const
uint64_t GetTerminalHeight() const
lldb::LockableStreamFileSP m_output_stream_sp
bool SetExternalEditor(llvm::StringRef editor)
void RequestInterrupt()
Interruption in LLDB:
void ReportInterruption(const InterruptionReport &report)
ExecutionContext GetSelectedExecutionContext()
Get the execution context representing the selected entities in the selected target.
const std::string m_instance_name
lldb::ThreadSP HandleThreadEvent(const lldb::EventSP &event_sp)
void HandleProgressEvent(const lldb::EventSP &event_sp)
SourceManager & GetSourceManager()
bool SetShowProgress(bool show_progress)
bool StartEventHandlerThread()
Manually start the global event handler thread.
bool SetUseSourceCache(bool use_source_cache)
void StopEventHandlerThread()
Manually stop the debugger's default event handler.
static void ReportInfo(std::string message, std::optional< lldb::user_id_t > debugger_id=std::nullopt, std::once_flag *once=nullptr)
Report info events.
void SetAsyncExecution(bool async)
HostThread SetIOHandlerThread(HostThread &new_thread)
void CancelForwardEvents(const lldb::ListenerSP &listener_sp)
bool GetPrintDecls() const
lldb::FileSP GetInputFileSP()
void StopIOHandlerThread()
bool GetHighlightSource() const
llvm::StringMap< std::weak_ptr< LogHandler > > m_stream_handlers
bool IsEscapeCodeCapableTTY()
CommandInterpreter & GetCommandInterpreter()
FormatEntity::Entry GetStatuslineFormat() const
void SaveInputTerminalState()
LoadedPluginsList m_loaded_plugins
bool GetShowInlineDiagnostics() const
void InstanceInitialize()
bool SetTabSize(uint64_t tab_size)
void HandleDiagnosticEvent(const lldb::EventSP &event_sp)
bool StartIOHandlerThread()
static lldb::DebuggerSP GetDebuggerAtIndex(size_t index)
llvm::StringRef GetAutosuggestionAnsiSuffix() const
lldb::ListenerSP m_listener_sp
void PushIOHandler(const lldb::IOHandlerSP &reader_sp, bool cancel_top_handler=true)
std::mutex m_destroy_callback_mutex
lldb::callback_token_t AddDestroyCallback(lldb_private::DebuggerDestroyCallback destroy_callback, void *baton)
Add a callback for when the debugger is destroyed.
lldb::thread_result_t IOHandlerThread()
FormatEntity::Entry GetFrameFormatUnique() const
std::optional< ProgressReport > GetCurrentProgressReport() const
llvm::StringRef GetDisabledAnsiPrefix() const
bool GetUseExternalEditor() const
TerminalState m_terminal_state
lldb::StreamUP GetAsyncErrorStream()
bool InterruptRequested()
bool GetEscapeNonPrintables() const
lldb::TargetSP m_dummy_target_sp
llvm::SmallVector< DestroyCallbackInfo, 2 > m_destroy_callbacks
std::unique_ptr< CommandInterpreter > m_command_interpreter_up
static void ReportWarning(std::string message, std::optional< lldb::user_id_t > debugger_id=std::nullopt, std::once_flag *once=nullptr)
Report warning events.
static bool FormatDisassemblerAddress(const FormatEntity::Entry *format, const SymbolContext *sc, const SymbolContext *prev_sc, const ExecutionContext *exe_ctx, const Address *addr, Stream &s)
static void SettingsInitialize()
LockableStreamFile::Mutex m_output_mutex
static llvm::ThreadPoolInterface & GetThreadPool()
Shared thread pool. Use only with ThreadPoolTaskGroup.
llvm::StringRef GetShowProgressAnsiSuffix() const
bool IsTopIOHandler(const lldb::IOHandlerSP &reader_sp)
bool HasIOHandlerThread() const
void DispatchInputEndOfFile()
llvm::SmallVector< ProgressReport, 4 > m_progress_reports
Bookkeeping for command line progress events.
bool IsIOHandlerThreadCurrentThread() const
void DispatchClientTelemetry(const lldb_private::StructuredDataImpl &entry)
std::mutex m_progress_reports_mutex
lldb::ProcessSP HandleProcessEvent(const lldb::EventSP &event_sp)
lldb::ListenerSP m_forward_listener_sp
std::array< lldb::ScriptInterpreterSP, lldb::eScriptLanguageUnknown > m_script_interpreters
std::shared_ptr< CallbackLogHandler > m_callback_handler_sp
void SetDestroyCallback(lldb_private::DebuggerDestroyCallback destroy_callback, void *baton)
DEPRECATED: We used to only support one Destroy callback.
lldb::FileSP GetOutputFileSP()
Broadcaster m_broadcaster
Public Debugger event broadcaster.
void DispatchInputInterrupt()
static void Initialize(LoadPluginCallbackType load_plugin_callback)
static lldb::DebuggerSP FindDebuggerWithInstanceName(llvm::StringRef instance_name)
uint64_t GetTerminalWidth() const
std::mutex m_interrupt_mutex
std::recursive_mutex m_io_handler_synchronous_mutex
bool RemoveIOHandler(const lldb::IOHandlerSP &reader_sp)
Remove the given IO handler if it's currently active.
Diagnostics::CallbackID m_diagnostics_callback_id
bool GetAutoOneLineSummaries() const
const char * GetIOHandlerCommandPrefix()
std::optional< Statusline > m_statusline
lldb::BroadcasterManagerSP m_broadcaster_manager_sp
Status RunREPL(lldb::LanguageType language, const char *repl_options)
bool PopIOHandler(const lldb::IOHandlerSP &reader_sp)
static StructuredData::DictionarySP GetBuildConfiguration()
Get the build configuration as structured data.
bool RemoveDestroyCallback(lldb::callback_token_t token)
Remove the specified callback. Return true if successful.
static LoadPluginCallbackType g_load_plugin_callback
bool GetShowStatusline() const
std::recursive_mutex m_script_interpreter_mutex
void RunIOHandlerAsync(const lldb::IOHandlerSP &reader_sp, bool cancel_top_handler=true)
Run the given IO handler and return immediately.
void SetInputFile(lldb::FileSP file)
lldb::LockableStreamFileSP GetOutputStreamSP()
Except for Debugger and IOHandler, GetOutputStreamSP and GetErrorStreamSP should not be used directly...
void SetPrompt(llvm::StringRef p)
llvm::StringRef GetSeparator() const
bool StatuslineSupported()
bool EnableLog(llvm::StringRef channel, llvm::ArrayRef< const char * > categories, llvm::StringRef log_file, uint32_t log_options, size_t buffer_size, LogHandlerKind log_handler_kind, llvm::raw_ostream &error_stream)
uint64_t GetStopDisassemblyMaxSize() const
bool SetTerminalHeight(uint64_t term_height)
Broadcaster m_sync_broadcaster
Private debugger synchronization.
void RestoreInputTerminalState()
bool GetUseSourceCache() const
HostThread m_io_handler_thread
llvm::StringRef GetRegexMatchAnsiSuffix() const
static llvm::StringRef GetStaticBroadcasterClass()
lldb::FileSP m_input_file_sp
bool SetREPLLanguage(lldb::LanguageType repl_lang)
@ eBroadcastBitEventThreadIsListening
bool GetAutoIndent() const
llvm::StringRef GetStopShowColumnAnsiSuffix() const
Status SetPropertyValue(const ExecutionContext *exe_ctx, VarSetOperationType op, llvm::StringRef property_path, llvm::StringRef value) override
llvm::StringRef GetPromptAnsiSuffix() const
FormatEntity::Entry GetThreadStopFormat() const
void SetErrorFile(lldb::FileSP file)
bool GetAutoConfirm() const
lldb::ScriptLanguage GetScriptLanguage() const
lldb::callback_token_t m_destroy_callback_next_token
std::unique_ptr< SourceManager > m_source_manager_up
static lldb::DebuggerSP CreateInstance(lldb::LogOutputCallback log_callback=nullptr, void *baton=nullptr)
static FileSpecList GetSafeAutoLoadPaths()
Get the list of paths that LLDB will consider automatically loading scripting resources from.
lldb::StopShowColumn GetStopShowColumn() const
static void ReportSymbolChange(const ModuleSpec &module_spec)
static void ReportError(std::string message, std::optional< lldb::user_id_t > debugger_id=std::nullopt, std::once_flag *once=nullptr)
Report error events.
bool SetPrintDecls(bool b)
bool SetScriptLanguage(lldb::ScriptLanguage script_lang)
lldb::LockableStreamFileSP m_error_stream_sp
bool SetShowInlineDiagnostics(bool)
bool LoadPlugin(const FileSpec &spec, Status &error)
void SetOutputFile(lldb::FileSP file)
uint64_t GetStopSourceLineCount(bool before) const
bool SetStatuslineFormat(const FormatEntity::Entry &format)
void EnableForwardEvents(const lldb::ListenerSP &listener_sp)
static lldb::DebuggerSP FindDebuggerWithID(lldb::user_id_t id)
void HandleBreakpointEvent(const lldb::EventSP &event_sp)
void JoinIOHandlerThread()
bool CheckTopIOHandlerTypes(IOHandler::Type top_type, IOHandler::Type second_top_type)
Target & GetDummyTarget()
lldb::ListenerSP GetListener()
static void Destroy(lldb::DebuggerSP &debugger_sp)
SourceManager::SourceFileCache m_source_file_cache
ExecutionContextRef GetSelectedExecutionContextRef()
Similar to GetSelectedExecutionContext but returns a ExecutionContextRef, and will hold the dummy tar...
llvm::StringRef GetPromptAnsiPrefix() const
lldb::StreamUP GetAsyncOutputStream()
void RedrawStatusline(std::optional< ExecutionContextRef > exe_ctx_ref)
Redraw the statusline if enabled.
void RunIOHandlerSync(const lldb::IOHandlerSP &reader_sp)
Run the given IO handler and block until it's complete.
Broadcaster & GetBroadcaster()
Get the public broadcaster for this debugger.
llvm::StringRef GetStopShowLineMarkerAnsiPrefix() const
bool GetShowDontUsePoHint() const
uint64_t GetTabSize() const
bool GetShowProgress() const
llvm::StringRef GetRegexMatchAnsiPrefix() const
void HandleDestroyCallback()
std::mutex m_output_flush_mutex
llvm::StringRef GetStopShowLineMarkerAnsiSuffix() const
bool SetSeparator(llvm::StringRef s)
bool SetUseColor(bool use_color)
std::mutex m_statusline_mutex
Mutex protecting the m_statusline member.
const char * GetIOHandlerHelpPrologue()
Status SetInputString(const char *data)
bool GetUseAutosuggestion() const
Target & GetSelectedOrDummyTarget(bool prefer_dummy=false)
IOHandlerStack m_io_handler_stack
llvm::once_flag m_clear_once
static void SettingsTerminate()
static void ReportProgress(uint64_t progress_id, std::string title, std::string details, uint64_t completed, uint64_t total, std::optional< lldb::user_id_t > debugger_id, uint32_t progress_category_bit=lldb::eBroadcastBitProgress)
Report progress events.
lldb::LanguageType GetREPLLanguage() const
ScriptInterpreter * GetScriptInterpreter(bool can_create=true, std::optional< lldb::ScriptLanguage > language={})
void SetLoggingCallback(lldb::LogOutputCallback log_callback, void *baton)
bool SetTerminalWidth(uint64_t term_width)
Debugger(lldb::LogOutputCallback m_log_callback, void *baton)
llvm::StringRef GetExternalEditor() const
static size_t GetNumDebuggers()
FormatEntity::Entry GetThreadFormat() const
uint32_t m_interrupt_requested
Tracks interrupt requests.
lldb::DWIMPrintVerbosity GetDWIMPrintVerbosity() const
bool GetMarkHiddenFrames() const
lldb::thread_result_t DefaultEventHandler()
void PrintAsync(const char *s, size_t len, bool is_stdout)
lldb::LockableStreamFileSP GetErrorStreamSP()
bool IsForwardingEvents()
llvm::StringRef GetPrompt() const
bool GetNotifyVoid() const
llvm::StringRef GetShowProgressAnsiPrefix() const
void AdoptTopIOHandlerFilesIfInvalid(lldb::FileSP &in, lldb::LockableStreamFileSP &out, lldb::LockableStreamFileSP &err)
FormatEntity::Entry GetFrameFormat() const
lldb::StopDisassemblyType GetStopDisassemblyDisplay() const
llvm::StringRef GetTopIOHandlerControlSequence(char ch)
void FlushProcessOutput(Process &process, bool flush_stdout, bool flush_stderr)
Force flushing the process's pending stdout and stderr to the debugger's asynchronous stdout and stde...
void CancelInterruptRequest()
Decrement the "interrupt requested" counter.
static void ReportDiagnosticImpl(lldb::Severity severity, std::string message, std::optional< lldb::user_id_t > debugger_id, std::once_flag *once)
std::vector< lldb::DebuggerSP > DebuggerList
bool SetAutoIndent(bool b)
friend class CommandInterpreter
llvm::StringRef GetStopShowColumnAnsiPrefix() const
static DebuggerList DebuggersRequestingInterruption()
void Dump(Stream *s) const override
static const DiagnosticEventData * GetEventDataFromEvent(const Event *event_ptr)
CallbackID AddCallback(Callback callback)
void Report(llvm::StringRef message)
void RemoveCallback(CallbackID id)
static Diagnostics & Instance()
static const void * GetBytesFromEvent(const Event *event_ptr)
static lldb::ProcessSP GetProcessFromEvent(const Event *event_ptr)
static lldb::StructuredDataPluginSP GetPluginFromEvent(const Event *event_ptr)
static StructuredData::ObjectSP GetObjectFromEvent(const Event *event_ptr)
Execution context objects refer to objects in the execution of the program that is being debugged.
"lldb/Target/ExecutionContext.h" A class that contains an execution context.
const lldb::TargetSP & GetTargetSP() const
Get accessor to get the target shared pointer.
bool HasTargetScope() const
Returns true the ExecutionContext object contains a valid target.
Target & GetTargetRef() const
Returns a reference to the target object.
void EmplaceBack(Args &&...args)
Inserts a new FileSpec into the FileSpecList constructed in-place with the given arguments.
void Append(const FileSpec &file)
Append a FileSpec object to the list.
FileSpec CopyByAppendingPathComponent(llvm::StringRef component) const
size_t GetPath(char *path, size_t max_path_length, bool denormalize=true) const
Extract the full path to the file.
llvm::StringRef GetFileNameExtension() const
Extract the extension of the file.
void EnumerateDirectory(llvm::Twine path, bool find_directories, bool find_files, bool find_other, EnumerateDirectoryCallbackType callback, void *callback_baton)
@ eEnumerateDirectoryResultEnter
Recurse into the current entry if it is a directory or symlink, or next if not.
@ eEnumerateDirectoryResultNext
Enumerate next entry in the current directory.
@ eEnumerateDirectoryResultQuit
Stop directory enumerations at any level.
int Open(const char *path, int flags, int mode=0600)
Wraps open in a platform-independent way.
static FileSystem & Instance()
void Resolve(llvm::SmallVectorImpl< char > &path, bool force_make_absolute=false)
Resolve path to make it canonical.
An abstract base class for files.
bool GetIsRealTerminal()
Return true if this file from a real terminal.
static int kInvalidDescriptor
virtual int GetDescriptor() const
Get underlying OS file descriptor for this file, or kInvalidDescriptor.
bool GetIsTerminalWithColors()
Return true if this file is a terminal which supports colors.
Status Close() override
Flush any buffers and release any resources owned by the file.
bool GetIsInteractive()
Return true if this file is interactive.
const Mangled & GetMangled() const
static void SystemLog(lldb::Severity severity, llvm::StringRef message)
Emit the given message to the operating system log.
static lldb::thread_t GetCurrentThread()
Get the thread token (the one returned by ThreadCreate when the thread was created) for the calling t...
static llvm::StringRef GetSettingName()
static LanguageSet GetLanguagesSupportingREPLs()
static const char * GetNameForLanguageType(lldb::LanguageType language)
Returns the internal LLDB name for the specified language.
static LanguageProperties & GetGlobalLanguageProperties()
static lldb::ListenerSP MakeListener(const char *name)
static bool EnableLogChannel(const std::shared_ptr< LogHandler > &log_handler_sp, uint32_t log_options, llvm::StringRef channel, llvm::ArrayRef< const char * > categories, llvm::raw_ostream &error_stream)
static ModuleListProperties & GetGlobalModuleListProperties()
void AppendCurrentValue(const FileSpec &value)
void SetCurrentValue(const FileSpecList &value)
void SetMinimumValue(uint64_t v)
static lldb::ScriptInterpreterSP GetScriptInterpreterForLanguage(lldb::ScriptLanguage script_lang, Debugger &debugger)
static void DebuggerInitialize(Debugger &debugger)
FollowForkMode GetFollowForkMode() const
static lldb::ProcessSP GetProcessFromEvent(const Event *event_ptr)
static lldb::StateType GetStateFromEvent(const Event *event_ptr)
A plug-in interface definition class for debugging a process.
static bool HandleProcessStateChangedEvent(const lldb::EventSP &event_sp, Stream *stream, SelectMostRelevant select_most_relevant, bool &pop_process_io_handler)
Centralize the code that handles and prints descriptions for process state changes.
static llvm::StringRef GetStaticBroadcasterClass()
@ eBroadcastBitStructuredData
@ eBroadcastBitStateChanged
virtual size_t GetSTDERR(char *buf, size_t buf_size, Status &error)
Get any available STDERR.
virtual size_t GetSTDOUT(char *buf, size_t buf_size, Status &error)
Get any available STDOUT.
static const ProgressEventData * GetEventDataFromEvent(const Event *event_ptr)
lldb::OptionValuePropertiesSP m_collection_sp
virtual Status SetPropertyValue(const ExecutionContext *exe_ctx, VarSetOperationType op, llvm::StringRef property_path, llvm::StringRef value)
T GetPropertyAtIndexAs(uint32_t idx, T default_value, const ExecutionContext *exe_ctx=nullptr) const
bool SetPropertyAtIndex(uint32_t idx, T t, const ExecutionContext *exe_ctx=nullptr) const
lldb::OptionValuePropertiesSP GetValueProperties() const
static lldb::REPLSP Create(Status &Status, lldb::LanguageType language, Debugger *debugger, Target *target, const char *repl_options)
Get a REPL with an existing target (or, failing that, a debugger to use), and (optional) extra argume...
static Status FromErrorStringWithFormat(const char *format,...) __attribute__((format(printf
static Status FromErrorString(const char *str)
bool Success() const
Test for success condition.
void Flush() override
Flush the stream.
llvm::StringRef GetString() const
A stream class that can stream formatted output to a file.
size_t Write(const void *src, size_t src_len)
Output character bytes to the stream.
virtual void Flush()=0
Flush the stream.
void AddItem(llvm::StringRef key, ObjectSP value_sp)
std::shared_ptr< Dictionary > DictionarySP
Defines a symbol context baton that can be handed other debug core functions.
Function * function
The Function for a given query.
Symbol * symbol
The Symbol for a given query.
bool Compare(ConstString name, lldb::SymbolType type) const
ConstString GetName() const
lldb::SymbolType GetType() const
Debugger & GetDebugger() const
static void SettingsTerminate()
static llvm::StringRef GetStaticBroadcasterClass()
static TargetProperties & GetGlobalProperties()
static ArchSpec GetDefaultArchitecture()
@ eBroadcastBitBreakpointChanged
static void SettingsInitialize()
static llvm::Expected< HostThread > LaunchThread(llvm::StringRef name, std::function< lldb::thread_result_t()> thread_function, size_t min_stack_byte_size=0)
static lldb::ThreadSP GetThreadFromEvent(const Event *event_ptr)
@ eBroadcastBitThreadSelected
@ eBroadcastBitStackChanged
static llvm::StringRef GetStaticBroadcasterClass()
virtual void DispatchClientTelemetry(const lldb_private::StructuredDataImpl &entry, Debugger *debugger)
static TelemetryManager * GetInstance()
@ SelectMostRelevantFrame
#define LLDB_INVALID_HOST_THREAD
std::string FormatAnsiTerminalCodes(llvm::StringRef format, bool do_color=true)
A class that represents a running process on the host machine.
Log * GetLog(Cat mask)
Retrieve the Log object for the channel associated with the given log enum.
@ eLoadScriptFromSymFileTrue
@ eLoadScriptFromSymFileFalse
@ eLoadScriptFromSymFileWarn
const char * GetVersion()
Retrieves a string representing the complete LLDB version, which includes the lldb version number,...
void(* DebuggerDestroyCallback)(lldb::user_id_t debugger_id, void *baton)
bool StateIsStoppedState(lldb::StateType state, bool must_exist)
Check if a state represents a state where the process or thread is stopped.
llvm::sys::DynamicLibrary(* LoadPluginCallbackType)(const lldb::DebuggerSP &debugger_sp, const FileSpec &spec, Status &error)
VarSetOperationType
Settable state variable types.
ScriptLanguage
Script interpreter types.
Severity
Used for expressing severity in logs and diagnostics.
@ eBroadcastBitExternalProgress
std::shared_ptr< lldb_private::IOHandler > IOHandlerSP
std::shared_ptr< lldb_private::Thread > ThreadSP
std::shared_ptr< lldb_private::Platform > PlatformSP
DWIMPrintVerbosity
Enum to control the verbosity level of dwim-print execution.
@ eDWIMPrintVerbosityFull
Always print a message indicating how dwim-print is evaluating its expression.
@ eDWIMPrintVerbosityNone
Run dwim-print with no verbosity.
@ eDWIMPrintVerbosityExpression
Print a message when dwim-print uses expression evaluation.
StateType
Process and Thread States.
LanguageType
Programming language type.
@ eLanguageTypeUnknown
Unknown or invalid language value.
std::shared_ptr< lldb_private::Breakpoint > BreakpointSP
std::shared_ptr< lldb_private::StructuredDataPlugin > StructuredDataPluginSP
std::shared_ptr< lldb_private::Process > ProcessSP
std::shared_ptr< lldb_private::Debugger > DebuggerSP
StopDisassemblyType
Used to determine when to show disassembly.
@ eStopDisassemblyTypeNever
@ eStopDisassemblyTypeNoSource
@ eStopDisassemblyTypeAlways
@ eStopDisassemblyTypeNoDebugInfo
@ eStopShowColumnAnsiOrCaret
std::shared_ptr< lldb_private::Event > EventSP
std::shared_ptr< lldb_private::Listener > ListenerSP
std::shared_ptr< lldb_private::LockableStreamFile > LockableStreamFileSP
void(* LogOutputCallback)(const char *, void *baton)
std::shared_ptr< lldb_private::Target > TargetSP
std::unique_ptr< lldb_private::Stream > StreamUP
std::shared_ptr< lldb_private::File > FileSP
std::shared_ptr< lldb_private::REPL > REPLSP
lldb_private::DebuggerDestroyCallback callback
A SmallBitVector that represents a set of source languages (lldb::LanguageType).
std::optional< lldb::LanguageType > GetSingularLanguage()
If the set contains a single language only, return it.
void AppendSafeAutoLoadPaths(FileSpec path)
Appends a path to the testing.safe-auto-load-paths setting.
static TestingProperties & GetGlobalTestingProperties()
FileSpecList GetSafeAutoLoadPaths() const
Callers should use Debugger::GetSafeAutoLoadPaths since it accounts for default paths configured via ...
void SetSafeAutoLoadPaths(FileSpecList paths)
Overwrites the testing.safe-auto-load-paths settings.
bool GetInjectVarLocListError() const
UserID(lldb::user_id_t uid=LLDB_INVALID_UID)
Construct with optional user ID.
lldb::user_id_t GetID() const
Get accessor for the user ID.
Helper RAII class for collecting telemetry.