1 //===-- PluginManager.cpp ---------------------------------------*- C++ -*-===//
3 // The LLVM Compiler Infrastructure
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
8 //===----------------------------------------------------------------------===//
10 #include "lldb/Core/PluginManager.h"
12 #include "lldb/Core/Debugger.h"
13 #include "lldb/Host/HostInfo.h"
14 #include "lldb/Interpreter/OptionValueProperties.h"
15 #include "lldb/Utility/ConstString.h" // for ConstString
16 #include "lldb/Utility/FileSpec.h"
17 #include "lldb/Utility/Status.h"
18 #include "lldb/Utility/StringList.h" // for StringList
20 #if defined(LLVM_ON_WIN32)
21 #include "lldb/Host/windows/PosixApi.h" // for PATH_MAX
24 #include "llvm/ADT/StringRef.h"
25 #include "llvm/Support/DynamicLibrary.h"
26 #include "llvm/Support/FileSystem.h" // for file_type, file_...
27 #include "llvm/Support/raw_ostream.h" // for fs
29 #include <map> // for map<>::const_ite...
30 #include <memory> // for shared_ptr
33 #include <utility> // for pair
36 #include <assert.h> // for assert
38 namespace lldb_private {
39 class CommandInterpreter;
43 using namespace lldb_private;
46 ePluginRegisterInstance,
47 ePluginUnregisterInstance,
48 ePluginGetInstanceAtIndex
51 typedef bool (*PluginInitCallback)();
52 typedef void (*PluginTermCallback)();
55 PluginInfo() : plugin_init_callback(nullptr), plugin_term_callback(nullptr) {}
57 llvm::sys::DynamicLibrary library;
58 PluginInitCallback plugin_init_callback;
59 PluginTermCallback plugin_term_callback;
62 typedef std::map<FileSpec, PluginInfo> PluginTerminateMap;
64 static std::recursive_mutex &GetPluginMapMutex() {
65 static std::recursive_mutex g_plugin_map_mutex;
66 return g_plugin_map_mutex;
69 static PluginTerminateMap &GetPluginMap() {
70 static PluginTerminateMap g_plugin_map;
74 static bool PluginIsLoaded(const FileSpec &plugin_file_spec) {
75 std::lock_guard<std::recursive_mutex> guard(GetPluginMapMutex());
76 PluginTerminateMap &plugin_map = GetPluginMap();
77 return plugin_map.find(plugin_file_spec) != plugin_map.end();
80 static void SetPluginInfo(const FileSpec &plugin_file_spec,
81 const PluginInfo &plugin_info) {
82 std::lock_guard<std::recursive_mutex> guard(GetPluginMapMutex());
83 PluginTerminateMap &plugin_map = GetPluginMap();
84 assert(plugin_map.find(plugin_file_spec) == plugin_map.end());
85 plugin_map[plugin_file_spec] = plugin_info;
88 template <typename FPtrTy> static FPtrTy CastToFPtr(void *VPtr) {
89 return reinterpret_cast<FPtrTy>(reinterpret_cast<intptr_t>(VPtr));
92 static FileSpec::EnumerateDirectoryResult
93 LoadPluginCallback(void *baton, llvm::sys::fs::file_type ft,
94 const FileSpec &file_spec) {
95 // PluginManager *plugin_manager = (PluginManager *)baton;
98 namespace fs = llvm::sys::fs;
99 // If we have a regular file, a symbolic link or unknown file type, try
100 // and process the file. We must handle unknown as sometimes the directory
101 // enumeration might be enumerating a file system that doesn't have correct
102 // file type information.
103 if (ft == fs::file_type::regular_file || ft == fs::file_type::symlink_file ||
104 ft == fs::file_type::type_unknown) {
105 FileSpec plugin_file_spec(file_spec);
106 plugin_file_spec.ResolvePath();
108 if (PluginIsLoaded(plugin_file_spec))
109 return FileSpec::eEnumerateDirectoryResultNext;
111 PluginInfo plugin_info;
113 std::string pluginLoadError;
114 plugin_info.library = llvm::sys::DynamicLibrary::getPermanentLibrary(
115 plugin_file_spec.GetPath().c_str(), &pluginLoadError);
116 if (plugin_info.library.isValid()) {
117 bool success = false;
118 plugin_info.plugin_init_callback = CastToFPtr<PluginInitCallback>(
119 plugin_info.library.getAddressOfSymbol("LLDBPluginInitialize"));
120 if (plugin_info.plugin_init_callback) {
121 // Call the plug-in "bool LLDBPluginInitialize(void)" function
122 success = plugin_info.plugin_init_callback();
126 // It is ok for the "LLDBPluginTerminate" symbol to be nullptr
127 plugin_info.plugin_term_callback = CastToFPtr<PluginTermCallback>(
128 plugin_info.library.getAddressOfSymbol("LLDBPluginTerminate"));
130 // The initialize function returned FALSE which means the plug-in
132 // compatible, or might be too new or too old, or might not want to
134 // machine. Set it to a default-constructed instance to invalidate
136 plugin_info = PluginInfo();
139 // Regardless of success or failure, cache the plug-in load
140 // in our plug-in info so we don't try to load it again and
142 SetPluginInfo(plugin_file_spec, plugin_info);
144 return FileSpec::eEnumerateDirectoryResultNext;
149 if (ft == fs::file_type::directory_file ||
150 ft == fs::file_type::symlink_file || ft == fs::file_type::type_unknown) {
151 // Try and recurse into anything that a directory or symbolic link.
152 // We must also do this for unknown as sometimes the directory enumeration
153 // might be enumerating a file system that doesn't have correct file type
155 return FileSpec::eEnumerateDirectoryResultEnter;
158 return FileSpec::eEnumerateDirectoryResultNext;
161 void PluginManager::Initialize() {
164 const bool find_directories = true;
165 const bool find_files = true;
166 const bool find_other = true;
167 char dir_path[PATH_MAX];
168 if (HostInfo::GetLLDBPath(ePathTypeLLDBSystemPlugins, dir_spec)) {
169 if (dir_spec.Exists() && dir_spec.GetPath(dir_path, sizeof(dir_path))) {
170 FileSpec::EnumerateDirectory(dir_path, find_directories, find_files,
171 find_other, LoadPluginCallback, nullptr);
175 if (HostInfo::GetLLDBPath(ePathTypeLLDBUserPlugins, dir_spec)) {
176 if (dir_spec.Exists() && dir_spec.GetPath(dir_path, sizeof(dir_path))) {
177 FileSpec::EnumerateDirectory(dir_path, find_directories, find_files,
178 find_other, LoadPluginCallback, nullptr);
184 void PluginManager::Terminate() {
185 std::lock_guard<std::recursive_mutex> guard(GetPluginMapMutex());
186 PluginTerminateMap &plugin_map = GetPluginMap();
188 PluginTerminateMap::const_iterator pos, end = plugin_map.end();
189 for (pos = plugin_map.begin(); pos != end; ++pos) {
190 // Call the plug-in "void LLDBPluginTerminate (void)" function if there
191 // is one (if the symbol was not nullptr).
192 if (pos->second.library.isValid()) {
193 if (pos->second.plugin_term_callback)
194 pos->second.plugin_term_callback();
203 ABIInstance() : name(), description(), create_callback(nullptr) {}
206 std::string description;
207 ABICreateInstance create_callback;
210 typedef std::vector<ABIInstance> ABIInstances;
212 static std::recursive_mutex &GetABIInstancesMutex() {
213 static std::recursive_mutex g_instances_mutex;
214 return g_instances_mutex;
217 static ABIInstances &GetABIInstances() {
218 static ABIInstances g_instances;
222 bool PluginManager::RegisterPlugin(const ConstString &name,
223 const char *description,
224 ABICreateInstance create_callback) {
225 if (create_callback) {
226 ABIInstance instance;
228 instance.name = name;
229 if (description && description[0])
230 instance.description = description;
231 instance.create_callback = create_callback;
232 std::lock_guard<std::recursive_mutex> guard(GetABIInstancesMutex());
233 GetABIInstances().push_back(instance);
239 bool PluginManager::UnregisterPlugin(ABICreateInstance create_callback) {
240 if (create_callback) {
241 std::lock_guard<std::recursive_mutex> guard(GetABIInstancesMutex());
242 ABIInstances &instances = GetABIInstances();
244 ABIInstances::iterator pos, end = instances.end();
245 for (pos = instances.begin(); pos != end; ++pos) {
246 if (pos->create_callback == create_callback) {
247 instances.erase(pos);
255 ABICreateInstance PluginManager::GetABICreateCallbackAtIndex(uint32_t idx) {
256 std::lock_guard<std::recursive_mutex> guard(GetABIInstancesMutex());
257 ABIInstances &instances = GetABIInstances();
258 if (idx < instances.size())
259 return instances[idx].create_callback;
264 PluginManager::GetABICreateCallbackForPluginName(const ConstString &name) {
266 std::lock_guard<std::recursive_mutex> guard(GetABIInstancesMutex());
267 ABIInstances &instances = GetABIInstances();
269 ABIInstances::iterator pos, end = instances.end();
270 for (pos = instances.begin(); pos != end; ++pos) {
271 if (name == pos->name)
272 return pos->create_callback;
278 #pragma mark Architecture
280 struct ArchitectureInstance {
282 std::string description;
283 PluginManager::ArchitectureCreateInstance create_callback;
286 typedef std::vector<ArchitectureInstance> ArchitectureInstances;
288 static std::mutex g_architecture_mutex;
290 static ArchitectureInstances &GetArchitectureInstances() {
291 static ArchitectureInstances g_instances;
295 void PluginManager::RegisterPlugin(const ConstString &name,
296 llvm::StringRef description,
297 ArchitectureCreateInstance create_callback) {
298 std::lock_guard<std::mutex> guard(g_architecture_mutex);
299 GetArchitectureInstances().push_back({name, description, create_callback});
302 void PluginManager::UnregisterPlugin(
303 ArchitectureCreateInstance create_callback) {
304 std::lock_guard<std::mutex> guard(g_architecture_mutex);
305 auto &instances = GetArchitectureInstances();
307 for (auto pos = instances.begin(), end = instances.end(); pos != end; ++pos) {
308 if (pos->create_callback == create_callback) {
309 instances.erase(pos);
313 llvm_unreachable("Plugin not found");
316 std::unique_ptr<Architecture>
317 PluginManager::CreateArchitectureInstance(const ArchSpec &arch) {
318 std::lock_guard<std::mutex> guard(g_architecture_mutex);
319 for (const auto &instances : GetArchitectureInstances()) {
320 if (auto plugin_up = instances.create_callback(arch))
326 #pragma mark Disassembler
328 struct DisassemblerInstance {
329 DisassemblerInstance() : name(), description(), create_callback(nullptr) {}
332 std::string description;
333 DisassemblerCreateInstance create_callback;
336 typedef std::vector<DisassemblerInstance> DisassemblerInstances;
338 static std::recursive_mutex &GetDisassemblerMutex() {
339 static std::recursive_mutex g_instances_mutex;
340 return g_instances_mutex;
343 static DisassemblerInstances &GetDisassemblerInstances() {
344 static DisassemblerInstances g_instances;
348 bool PluginManager::RegisterPlugin(const ConstString &name,
349 const char *description,
350 DisassemblerCreateInstance create_callback) {
351 if (create_callback) {
352 DisassemblerInstance instance;
354 instance.name = name;
355 if (description && description[0])
356 instance.description = description;
357 instance.create_callback = create_callback;
358 std::lock_guard<std::recursive_mutex> guard(GetDisassemblerMutex());
359 GetDisassemblerInstances().push_back(instance);
365 bool PluginManager::UnregisterPlugin(
366 DisassemblerCreateInstance create_callback) {
367 if (create_callback) {
368 std::lock_guard<std::recursive_mutex> guard(GetDisassemblerMutex());
369 DisassemblerInstances &instances = GetDisassemblerInstances();
371 DisassemblerInstances::iterator pos, end = instances.end();
372 for (pos = instances.begin(); pos != end; ++pos) {
373 if (pos->create_callback == create_callback) {
374 instances.erase(pos);
382 DisassemblerCreateInstance
383 PluginManager::GetDisassemblerCreateCallbackAtIndex(uint32_t idx) {
384 std::lock_guard<std::recursive_mutex> guard(GetDisassemblerMutex());
385 DisassemblerInstances &instances = GetDisassemblerInstances();
386 if (idx < instances.size())
387 return instances[idx].create_callback;
391 DisassemblerCreateInstance
392 PluginManager::GetDisassemblerCreateCallbackForPluginName(
393 const ConstString &name) {
395 std::lock_guard<std::recursive_mutex> guard(GetDisassemblerMutex());
396 DisassemblerInstances &instances = GetDisassemblerInstances();
398 DisassemblerInstances::iterator pos, end = instances.end();
399 for (pos = instances.begin(); pos != end; ++pos) {
400 if (name == pos->name)
401 return pos->create_callback;
407 #pragma mark DynamicLoader
409 struct DynamicLoaderInstance {
410 DynamicLoaderInstance()
411 : name(), description(), create_callback(nullptr),
412 debugger_init_callback(nullptr) {}
415 std::string description;
416 DynamicLoaderCreateInstance create_callback;
417 DebuggerInitializeCallback debugger_init_callback;
420 typedef std::vector<DynamicLoaderInstance> DynamicLoaderInstances;
422 static std::recursive_mutex &GetDynamicLoaderMutex() {
423 static std::recursive_mutex g_instances_mutex;
424 return g_instances_mutex;
427 static DynamicLoaderInstances &GetDynamicLoaderInstances() {
428 static DynamicLoaderInstances g_instances;
432 bool PluginManager::RegisterPlugin(
433 const ConstString &name, const char *description,
434 DynamicLoaderCreateInstance create_callback,
435 DebuggerInitializeCallback debugger_init_callback) {
436 if (create_callback) {
437 DynamicLoaderInstance instance;
439 instance.name = name;
440 if (description && description[0])
441 instance.description = description;
442 instance.create_callback = create_callback;
443 instance.debugger_init_callback = debugger_init_callback;
444 std::lock_guard<std::recursive_mutex> guard(GetDynamicLoaderMutex());
445 GetDynamicLoaderInstances().push_back(instance);
450 bool PluginManager::UnregisterPlugin(
451 DynamicLoaderCreateInstance create_callback) {
452 if (create_callback) {
453 std::lock_guard<std::recursive_mutex> guard(GetDynamicLoaderMutex());
454 DynamicLoaderInstances &instances = GetDynamicLoaderInstances();
456 DynamicLoaderInstances::iterator pos, end = instances.end();
457 for (pos = instances.begin(); pos != end; ++pos) {
458 if (pos->create_callback == create_callback) {
459 instances.erase(pos);
467 DynamicLoaderCreateInstance
468 PluginManager::GetDynamicLoaderCreateCallbackAtIndex(uint32_t idx) {
469 std::lock_guard<std::recursive_mutex> guard(GetDynamicLoaderMutex());
470 DynamicLoaderInstances &instances = GetDynamicLoaderInstances();
471 if (idx < instances.size())
472 return instances[idx].create_callback;
476 DynamicLoaderCreateInstance
477 PluginManager::GetDynamicLoaderCreateCallbackForPluginName(
478 const ConstString &name) {
480 std::lock_guard<std::recursive_mutex> guard(GetDynamicLoaderMutex());
481 DynamicLoaderInstances &instances = GetDynamicLoaderInstances();
483 DynamicLoaderInstances::iterator pos, end = instances.end();
484 for (pos = instances.begin(); pos != end; ++pos) {
485 if (name == pos->name)
486 return pos->create_callback;
492 #pragma mark JITLoader
494 struct JITLoaderInstance {
496 : name(), description(), create_callback(nullptr),
497 debugger_init_callback(nullptr) {}
500 std::string description;
501 JITLoaderCreateInstance create_callback;
502 DebuggerInitializeCallback debugger_init_callback;
505 typedef std::vector<JITLoaderInstance> JITLoaderInstances;
507 static std::recursive_mutex &GetJITLoaderMutex() {
508 static std::recursive_mutex g_instances_mutex;
509 return g_instances_mutex;
512 static JITLoaderInstances &GetJITLoaderInstances() {
513 static JITLoaderInstances g_instances;
517 bool PluginManager::RegisterPlugin(
518 const ConstString &name, const char *description,
519 JITLoaderCreateInstance create_callback,
520 DebuggerInitializeCallback debugger_init_callback) {
521 if (create_callback) {
522 JITLoaderInstance instance;
524 instance.name = name;
525 if (description && description[0])
526 instance.description = description;
527 instance.create_callback = create_callback;
528 instance.debugger_init_callback = debugger_init_callback;
529 std::lock_guard<std::recursive_mutex> guard(GetJITLoaderMutex());
530 GetJITLoaderInstances().push_back(instance);
535 bool PluginManager::UnregisterPlugin(JITLoaderCreateInstance create_callback) {
536 if (create_callback) {
537 std::lock_guard<std::recursive_mutex> guard(GetJITLoaderMutex());
538 JITLoaderInstances &instances = GetJITLoaderInstances();
540 JITLoaderInstances::iterator pos, end = instances.end();
541 for (pos = instances.begin(); pos != end; ++pos) {
542 if (pos->create_callback == create_callback) {
543 instances.erase(pos);
551 JITLoaderCreateInstance
552 PluginManager::GetJITLoaderCreateCallbackAtIndex(uint32_t idx) {
553 std::lock_guard<std::recursive_mutex> guard(GetJITLoaderMutex());
554 JITLoaderInstances &instances = GetJITLoaderInstances();
555 if (idx < instances.size())
556 return instances[idx].create_callback;
560 JITLoaderCreateInstance PluginManager::GetJITLoaderCreateCallbackForPluginName(
561 const ConstString &name) {
563 std::lock_guard<std::recursive_mutex> guard(GetJITLoaderMutex());
564 JITLoaderInstances &instances = GetJITLoaderInstances();
566 JITLoaderInstances::iterator pos, end = instances.end();
567 for (pos = instances.begin(); pos != end; ++pos) {
568 if (name == pos->name)
569 return pos->create_callback;
575 #pragma mark EmulateInstruction
577 struct EmulateInstructionInstance {
578 EmulateInstructionInstance()
579 : name(), description(), create_callback(nullptr) {}
582 std::string description;
583 EmulateInstructionCreateInstance create_callback;
586 typedef std::vector<EmulateInstructionInstance> EmulateInstructionInstances;
588 static std::recursive_mutex &GetEmulateInstructionMutex() {
589 static std::recursive_mutex g_instances_mutex;
590 return g_instances_mutex;
593 static EmulateInstructionInstances &GetEmulateInstructionInstances() {
594 static EmulateInstructionInstances g_instances;
598 bool PluginManager::RegisterPlugin(
599 const ConstString &name, const char *description,
600 EmulateInstructionCreateInstance create_callback) {
601 if (create_callback) {
602 EmulateInstructionInstance instance;
604 instance.name = name;
605 if (description && description[0])
606 instance.description = description;
607 instance.create_callback = create_callback;
608 std::lock_guard<std::recursive_mutex> guard(GetEmulateInstructionMutex());
609 GetEmulateInstructionInstances().push_back(instance);
614 bool PluginManager::UnregisterPlugin(
615 EmulateInstructionCreateInstance create_callback) {
616 if (create_callback) {
617 std::lock_guard<std::recursive_mutex> guard(GetEmulateInstructionMutex());
618 EmulateInstructionInstances &instances = GetEmulateInstructionInstances();
620 EmulateInstructionInstances::iterator pos, end = instances.end();
621 for (pos = instances.begin(); pos != end; ++pos) {
622 if (pos->create_callback == create_callback) {
623 instances.erase(pos);
631 EmulateInstructionCreateInstance
632 PluginManager::GetEmulateInstructionCreateCallbackAtIndex(uint32_t idx) {
633 std::lock_guard<std::recursive_mutex> guard(GetEmulateInstructionMutex());
634 EmulateInstructionInstances &instances = GetEmulateInstructionInstances();
635 if (idx < instances.size())
636 return instances[idx].create_callback;
640 EmulateInstructionCreateInstance
641 PluginManager::GetEmulateInstructionCreateCallbackForPluginName(
642 const ConstString &name) {
644 std::lock_guard<std::recursive_mutex> guard(GetEmulateInstructionMutex());
645 EmulateInstructionInstances &instances = GetEmulateInstructionInstances();
647 EmulateInstructionInstances::iterator pos, end = instances.end();
648 for (pos = instances.begin(); pos != end; ++pos) {
649 if (name == pos->name)
650 return pos->create_callback;
656 #pragma mark OperatingSystem
658 struct OperatingSystemInstance {
659 OperatingSystemInstance()
660 : name(), description(), create_callback(nullptr),
661 debugger_init_callback(nullptr) {}
664 std::string description;
665 OperatingSystemCreateInstance create_callback;
666 DebuggerInitializeCallback debugger_init_callback;
669 typedef std::vector<OperatingSystemInstance> OperatingSystemInstances;
671 static std::recursive_mutex &GetOperatingSystemMutex() {
672 static std::recursive_mutex g_instances_mutex;
673 return g_instances_mutex;
676 static OperatingSystemInstances &GetOperatingSystemInstances() {
677 static OperatingSystemInstances g_instances;
681 bool PluginManager::RegisterPlugin(
682 const ConstString &name, const char *description,
683 OperatingSystemCreateInstance create_callback,
684 DebuggerInitializeCallback debugger_init_callback) {
685 if (create_callback) {
686 OperatingSystemInstance instance;
688 instance.name = name;
689 if (description && description[0])
690 instance.description = description;
691 instance.create_callback = create_callback;
692 instance.debugger_init_callback = debugger_init_callback;
693 std::lock_guard<std::recursive_mutex> guard(GetOperatingSystemMutex());
694 GetOperatingSystemInstances().push_back(instance);
699 bool PluginManager::UnregisterPlugin(
700 OperatingSystemCreateInstance create_callback) {
701 if (create_callback) {
702 std::lock_guard<std::recursive_mutex> guard(GetOperatingSystemMutex());
703 OperatingSystemInstances &instances = GetOperatingSystemInstances();
705 OperatingSystemInstances::iterator pos, end = instances.end();
706 for (pos = instances.begin(); pos != end; ++pos) {
707 if (pos->create_callback == create_callback) {
708 instances.erase(pos);
716 OperatingSystemCreateInstance
717 PluginManager::GetOperatingSystemCreateCallbackAtIndex(uint32_t idx) {
718 std::lock_guard<std::recursive_mutex> guard(GetOperatingSystemMutex());
719 OperatingSystemInstances &instances = GetOperatingSystemInstances();
720 if (idx < instances.size())
721 return instances[idx].create_callback;
725 OperatingSystemCreateInstance
726 PluginManager::GetOperatingSystemCreateCallbackForPluginName(
727 const ConstString &name) {
729 std::lock_guard<std::recursive_mutex> guard(GetOperatingSystemMutex());
730 OperatingSystemInstances &instances = GetOperatingSystemInstances();
732 OperatingSystemInstances::iterator pos, end = instances.end();
733 for (pos = instances.begin(); pos != end; ++pos) {
734 if (name == pos->name)
735 return pos->create_callback;
741 #pragma mark Language
743 struct LanguageInstance {
744 LanguageInstance() : name(), description(), create_callback(nullptr) {}
747 std::string description;
748 LanguageCreateInstance create_callback;
751 typedef std::vector<LanguageInstance> LanguageInstances;
753 static std::recursive_mutex &GetLanguageMutex() {
754 static std::recursive_mutex g_instances_mutex;
755 return g_instances_mutex;
758 static LanguageInstances &GetLanguageInstances() {
759 static LanguageInstances g_instances;
763 bool PluginManager::RegisterPlugin(const ConstString &name,
764 const char *description,
765 LanguageCreateInstance create_callback) {
766 if (create_callback) {
767 LanguageInstance instance;
769 instance.name = name;
770 if (description && description[0])
771 instance.description = description;
772 instance.create_callback = create_callback;
773 std::lock_guard<std::recursive_mutex> guard(GetLanguageMutex());
774 GetLanguageInstances().push_back(instance);
779 bool PluginManager::UnregisterPlugin(LanguageCreateInstance create_callback) {
780 if (create_callback) {
781 std::lock_guard<std::recursive_mutex> guard(GetLanguageMutex());
782 LanguageInstances &instances = GetLanguageInstances();
784 LanguageInstances::iterator pos, end = instances.end();
785 for (pos = instances.begin(); pos != end; ++pos) {
786 if (pos->create_callback == create_callback) {
787 instances.erase(pos);
795 LanguageCreateInstance
796 PluginManager::GetLanguageCreateCallbackAtIndex(uint32_t idx) {
797 std::lock_guard<std::recursive_mutex> guard(GetLanguageMutex());
798 LanguageInstances &instances = GetLanguageInstances();
799 if (idx < instances.size())
800 return instances[idx].create_callback;
804 LanguageCreateInstance
805 PluginManager::GetLanguageCreateCallbackForPluginName(const ConstString &name) {
807 std::lock_guard<std::recursive_mutex> guard(GetLanguageMutex());
808 LanguageInstances &instances = GetLanguageInstances();
810 LanguageInstances::iterator pos, end = instances.end();
811 for (pos = instances.begin(); pos != end; ++pos) {
812 if (name == pos->name)
813 return pos->create_callback;
819 #pragma mark LanguageRuntime
821 struct LanguageRuntimeInstance {
822 LanguageRuntimeInstance() : name(), description(), create_callback(nullptr) {}
825 std::string description;
826 LanguageRuntimeCreateInstance create_callback;
827 LanguageRuntimeGetCommandObject command_callback;
830 typedef std::vector<LanguageRuntimeInstance> LanguageRuntimeInstances;
832 static std::recursive_mutex &GetLanguageRuntimeMutex() {
833 static std::recursive_mutex g_instances_mutex;
834 return g_instances_mutex;
837 static LanguageRuntimeInstances &GetLanguageRuntimeInstances() {
838 static LanguageRuntimeInstances g_instances;
842 bool PluginManager::RegisterPlugin(
843 const ConstString &name, const char *description,
844 LanguageRuntimeCreateInstance create_callback,
845 LanguageRuntimeGetCommandObject command_callback) {
846 if (create_callback) {
847 LanguageRuntimeInstance instance;
849 instance.name = name;
850 if (description && description[0])
851 instance.description = description;
852 instance.create_callback = create_callback;
853 instance.command_callback = command_callback;
854 std::lock_guard<std::recursive_mutex> guard(GetLanguageRuntimeMutex());
855 GetLanguageRuntimeInstances().push_back(instance);
860 bool PluginManager::UnregisterPlugin(
861 LanguageRuntimeCreateInstance create_callback) {
862 if (create_callback) {
863 std::lock_guard<std::recursive_mutex> guard(GetLanguageRuntimeMutex());
864 LanguageRuntimeInstances &instances = GetLanguageRuntimeInstances();
866 LanguageRuntimeInstances::iterator pos, end = instances.end();
867 for (pos = instances.begin(); pos != end; ++pos) {
868 if (pos->create_callback == create_callback) {
869 instances.erase(pos);
877 LanguageRuntimeCreateInstance
878 PluginManager::GetLanguageRuntimeCreateCallbackAtIndex(uint32_t idx) {
879 std::lock_guard<std::recursive_mutex> guard(GetLanguageRuntimeMutex());
880 LanguageRuntimeInstances &instances = GetLanguageRuntimeInstances();
881 if (idx < instances.size())
882 return instances[idx].create_callback;
886 LanguageRuntimeGetCommandObject
887 PluginManager::GetLanguageRuntimeGetCommandObjectAtIndex(uint32_t idx) {
888 std::lock_guard<std::recursive_mutex> guard(GetLanguageRuntimeMutex());
889 LanguageRuntimeInstances &instances = GetLanguageRuntimeInstances();
890 if (idx < instances.size())
891 return instances[idx].command_callback;
895 LanguageRuntimeCreateInstance
896 PluginManager::GetLanguageRuntimeCreateCallbackForPluginName(
897 const ConstString &name) {
899 std::lock_guard<std::recursive_mutex> guard(GetLanguageRuntimeMutex());
900 LanguageRuntimeInstances &instances = GetLanguageRuntimeInstances();
902 LanguageRuntimeInstances::iterator pos, end = instances.end();
903 for (pos = instances.begin(); pos != end; ++pos) {
904 if (name == pos->name)
905 return pos->create_callback;
911 #pragma mark SystemRuntime
913 struct SystemRuntimeInstance {
914 SystemRuntimeInstance() : name(), description(), create_callback(nullptr) {}
917 std::string description;
918 SystemRuntimeCreateInstance create_callback;
921 typedef std::vector<SystemRuntimeInstance> SystemRuntimeInstances;
923 static std::recursive_mutex &GetSystemRuntimeMutex() {
924 static std::recursive_mutex g_instances_mutex;
925 return g_instances_mutex;
928 static SystemRuntimeInstances &GetSystemRuntimeInstances() {
929 static SystemRuntimeInstances g_instances;
933 bool PluginManager::RegisterPlugin(
934 const ConstString &name, const char *description,
935 SystemRuntimeCreateInstance create_callback) {
936 if (create_callback) {
937 SystemRuntimeInstance instance;
939 instance.name = name;
940 if (description && description[0])
941 instance.description = description;
942 instance.create_callback = create_callback;
943 std::lock_guard<std::recursive_mutex> guard(GetSystemRuntimeMutex());
944 GetSystemRuntimeInstances().push_back(instance);
949 bool PluginManager::UnregisterPlugin(
950 SystemRuntimeCreateInstance create_callback) {
951 if (create_callback) {
952 std::lock_guard<std::recursive_mutex> guard(GetSystemRuntimeMutex());
953 SystemRuntimeInstances &instances = GetSystemRuntimeInstances();
955 SystemRuntimeInstances::iterator pos, end = instances.end();
956 for (pos = instances.begin(); pos != end; ++pos) {
957 if (pos->create_callback == create_callback) {
958 instances.erase(pos);
966 SystemRuntimeCreateInstance
967 PluginManager::GetSystemRuntimeCreateCallbackAtIndex(uint32_t idx) {
968 std::lock_guard<std::recursive_mutex> guard(GetSystemRuntimeMutex());
969 SystemRuntimeInstances &instances = GetSystemRuntimeInstances();
970 if (idx < instances.size())
971 return instances[idx].create_callback;
975 SystemRuntimeCreateInstance
976 PluginManager::GetSystemRuntimeCreateCallbackForPluginName(
977 const ConstString &name) {
979 std::lock_guard<std::recursive_mutex> guard(GetSystemRuntimeMutex());
980 SystemRuntimeInstances &instances = GetSystemRuntimeInstances();
982 SystemRuntimeInstances::iterator pos, end = instances.end();
983 for (pos = instances.begin(); pos != end; ++pos) {
984 if (name == pos->name)
985 return pos->create_callback;
991 #pragma mark ObjectFile
993 struct ObjectFileInstance {
995 : name(), description(), create_callback(nullptr),
996 create_memory_callback(nullptr), get_module_specifications(nullptr),
997 save_core(nullptr) {}
1000 std::string description;
1001 ObjectFileCreateInstance create_callback;
1002 ObjectFileCreateMemoryInstance create_memory_callback;
1003 ObjectFileGetModuleSpecifications get_module_specifications;
1004 ObjectFileSaveCore save_core;
1007 typedef std::vector<ObjectFileInstance> ObjectFileInstances;
1009 static std::recursive_mutex &GetObjectFileMutex() {
1010 static std::recursive_mutex g_instances_mutex;
1011 return g_instances_mutex;
1014 static ObjectFileInstances &GetObjectFileInstances() {
1015 static ObjectFileInstances g_instances;
1019 bool PluginManager::RegisterPlugin(
1020 const ConstString &name, const char *description,
1021 ObjectFileCreateInstance create_callback,
1022 ObjectFileCreateMemoryInstance create_memory_callback,
1023 ObjectFileGetModuleSpecifications get_module_specifications,
1024 ObjectFileSaveCore save_core) {
1025 if (create_callback) {
1026 ObjectFileInstance instance;
1028 instance.name = name;
1029 if (description && description[0])
1030 instance.description = description;
1031 instance.create_callback = create_callback;
1032 instance.create_memory_callback = create_memory_callback;
1033 instance.save_core = save_core;
1034 instance.get_module_specifications = get_module_specifications;
1035 std::lock_guard<std::recursive_mutex> guard(GetObjectFileMutex());
1036 GetObjectFileInstances().push_back(instance);
1041 bool PluginManager::UnregisterPlugin(ObjectFileCreateInstance create_callback) {
1042 if (create_callback) {
1043 std::lock_guard<std::recursive_mutex> guard(GetObjectFileMutex());
1044 ObjectFileInstances &instances = GetObjectFileInstances();
1046 ObjectFileInstances::iterator pos, end = instances.end();
1047 for (pos = instances.begin(); pos != end; ++pos) {
1048 if (pos->create_callback == create_callback) {
1049 instances.erase(pos);
1057 ObjectFileCreateInstance
1058 PluginManager::GetObjectFileCreateCallbackAtIndex(uint32_t idx) {
1059 std::lock_guard<std::recursive_mutex> guard(GetObjectFileMutex());
1060 ObjectFileInstances &instances = GetObjectFileInstances();
1061 if (idx < instances.size())
1062 return instances[idx].create_callback;
1066 ObjectFileCreateMemoryInstance
1067 PluginManager::GetObjectFileCreateMemoryCallbackAtIndex(uint32_t idx) {
1068 std::lock_guard<std::recursive_mutex> guard(GetObjectFileMutex());
1069 ObjectFileInstances &instances = GetObjectFileInstances();
1070 if (idx < instances.size())
1071 return instances[idx].create_memory_callback;
1075 ObjectFileGetModuleSpecifications
1076 PluginManager::GetObjectFileGetModuleSpecificationsCallbackAtIndex(
1078 std::lock_guard<std::recursive_mutex> guard(GetObjectFileMutex());
1079 ObjectFileInstances &instances = GetObjectFileInstances();
1080 if (idx < instances.size())
1081 return instances[idx].get_module_specifications;
1085 ObjectFileCreateInstance
1086 PluginManager::GetObjectFileCreateCallbackForPluginName(
1087 const ConstString &name) {
1089 std::lock_guard<std::recursive_mutex> guard(GetObjectFileMutex());
1090 ObjectFileInstances &instances = GetObjectFileInstances();
1092 ObjectFileInstances::iterator pos, end = instances.end();
1093 for (pos = instances.begin(); pos != end; ++pos) {
1094 if (name == pos->name)
1095 return pos->create_callback;
1101 ObjectFileCreateMemoryInstance
1102 PluginManager::GetObjectFileCreateMemoryCallbackForPluginName(
1103 const ConstString &name) {
1105 std::lock_guard<std::recursive_mutex> guard(GetObjectFileMutex());
1106 ObjectFileInstances &instances = GetObjectFileInstances();
1108 ObjectFileInstances::iterator pos, end = instances.end();
1109 for (pos = instances.begin(); pos != end; ++pos) {
1110 if (name == pos->name)
1111 return pos->create_memory_callback;
1117 Status PluginManager::SaveCore(const lldb::ProcessSP &process_sp,
1118 const FileSpec &outfile) {
1120 std::lock_guard<std::recursive_mutex> guard(GetObjectFileMutex());
1121 ObjectFileInstances &instances = GetObjectFileInstances();
1123 ObjectFileInstances::iterator pos, end = instances.end();
1124 for (pos = instances.begin(); pos != end; ++pos) {
1125 if (pos->save_core && pos->save_core(process_sp, outfile, error))
1128 error.SetErrorString(
1129 "no ObjectFile plugins were able to save a core for this process");
1133 #pragma mark ObjectContainer
1135 struct ObjectContainerInstance {
1136 ObjectContainerInstance()
1137 : name(), description(), create_callback(nullptr),
1138 get_module_specifications(nullptr) {}
1141 std::string description;
1142 ObjectContainerCreateInstance create_callback;
1143 ObjectFileGetModuleSpecifications get_module_specifications;
1146 typedef std::vector<ObjectContainerInstance> ObjectContainerInstances;
1148 static std::recursive_mutex &GetObjectContainerMutex() {
1149 static std::recursive_mutex g_instances_mutex;
1150 return g_instances_mutex;
1153 static ObjectContainerInstances &GetObjectContainerInstances() {
1154 static ObjectContainerInstances g_instances;
1158 bool PluginManager::RegisterPlugin(
1159 const ConstString &name, const char *description,
1160 ObjectContainerCreateInstance create_callback,
1161 ObjectFileGetModuleSpecifications get_module_specifications) {
1162 if (create_callback) {
1163 ObjectContainerInstance instance;
1165 instance.name = name;
1166 if (description && description[0])
1167 instance.description = description;
1168 instance.create_callback = create_callback;
1169 instance.get_module_specifications = get_module_specifications;
1170 std::lock_guard<std::recursive_mutex> guard(GetObjectContainerMutex());
1171 GetObjectContainerInstances().push_back(instance);
1176 bool PluginManager::UnregisterPlugin(
1177 ObjectContainerCreateInstance create_callback) {
1178 if (create_callback) {
1179 std::lock_guard<std::recursive_mutex> guard(GetObjectContainerMutex());
1180 ObjectContainerInstances &instances = GetObjectContainerInstances();
1182 ObjectContainerInstances::iterator pos, end = instances.end();
1183 for (pos = instances.begin(); pos != end; ++pos) {
1184 if (pos->create_callback == create_callback) {
1185 instances.erase(pos);
1193 ObjectContainerCreateInstance
1194 PluginManager::GetObjectContainerCreateCallbackAtIndex(uint32_t idx) {
1195 std::lock_guard<std::recursive_mutex> guard(GetObjectContainerMutex());
1196 ObjectContainerInstances &instances = GetObjectContainerInstances();
1197 if (idx < instances.size())
1198 return instances[idx].create_callback;
1202 ObjectContainerCreateInstance
1203 PluginManager::GetObjectContainerCreateCallbackForPluginName(
1204 const ConstString &name) {
1206 std::lock_guard<std::recursive_mutex> guard(GetObjectContainerMutex());
1207 ObjectContainerInstances &instances = GetObjectContainerInstances();
1209 ObjectContainerInstances::iterator pos, end = instances.end();
1210 for (pos = instances.begin(); pos != end; ++pos) {
1211 if (name == pos->name)
1212 return pos->create_callback;
1218 ObjectFileGetModuleSpecifications
1219 PluginManager::GetObjectContainerGetModuleSpecificationsCallbackAtIndex(
1221 std::lock_guard<std::recursive_mutex> guard(GetObjectContainerMutex());
1222 ObjectContainerInstances &instances = GetObjectContainerInstances();
1223 if (idx < instances.size())
1224 return instances[idx].get_module_specifications;
1228 #pragma mark Platform
1230 struct PlatformInstance {
1232 : name(), description(), create_callback(nullptr),
1233 debugger_init_callback(nullptr) {}
1236 std::string description;
1237 PlatformCreateInstance create_callback;
1238 DebuggerInitializeCallback debugger_init_callback;
1241 typedef std::vector<PlatformInstance> PlatformInstances;
1243 static std::recursive_mutex &GetPlatformInstancesMutex() {
1244 static std::recursive_mutex g_platform_instances_mutex;
1245 return g_platform_instances_mutex;
1248 static PlatformInstances &GetPlatformInstances() {
1249 static PlatformInstances g_platform_instances;
1250 return g_platform_instances;
1253 bool PluginManager::RegisterPlugin(
1254 const ConstString &name, const char *description,
1255 PlatformCreateInstance create_callback,
1256 DebuggerInitializeCallback debugger_init_callback) {
1257 if (create_callback) {
1258 std::lock_guard<std::recursive_mutex> guard(GetPlatformInstancesMutex());
1260 PlatformInstance instance;
1262 instance.name = name;
1263 if (description && description[0])
1264 instance.description = description;
1265 instance.create_callback = create_callback;
1266 instance.debugger_init_callback = debugger_init_callback;
1267 GetPlatformInstances().push_back(instance);
1273 const char *PluginManager::GetPlatformPluginNameAtIndex(uint32_t idx) {
1274 std::lock_guard<std::recursive_mutex> guard(GetPlatformInstancesMutex());
1275 PlatformInstances &instances = GetPlatformInstances();
1276 if (idx < instances.size())
1277 return instances[idx].name.GetCString();
1281 const char *PluginManager::GetPlatformPluginDescriptionAtIndex(uint32_t idx) {
1282 std::lock_guard<std::recursive_mutex> guard(GetPlatformInstancesMutex());
1283 PlatformInstances &instances = GetPlatformInstances();
1284 if (idx < instances.size())
1285 return instances[idx].description.c_str();
1289 bool PluginManager::UnregisterPlugin(PlatformCreateInstance create_callback) {
1290 if (create_callback) {
1291 std::lock_guard<std::recursive_mutex> guard(GetPlatformInstancesMutex());
1292 PlatformInstances &instances = GetPlatformInstances();
1294 PlatformInstances::iterator pos, end = instances.end();
1295 for (pos = instances.begin(); pos != end; ++pos) {
1296 if (pos->create_callback == create_callback) {
1297 instances.erase(pos);
1305 PlatformCreateInstance
1306 PluginManager::GetPlatformCreateCallbackAtIndex(uint32_t idx) {
1307 std::lock_guard<std::recursive_mutex> guard(GetPlatformInstancesMutex());
1308 PlatformInstances &instances = GetPlatformInstances();
1309 if (idx < instances.size())
1310 return instances[idx].create_callback;
1314 PlatformCreateInstance
1315 PluginManager::GetPlatformCreateCallbackForPluginName(const ConstString &name) {
1317 std::lock_guard<std::recursive_mutex> guard(GetPlatformInstancesMutex());
1318 PlatformInstances &instances = GetPlatformInstances();
1320 PlatformInstances::iterator pos, end = instances.end();
1321 for (pos = instances.begin(); pos != end; ++pos) {
1322 if (name == pos->name)
1323 return pos->create_callback;
1329 size_t PluginManager::AutoCompletePlatformName(llvm::StringRef name,
1330 StringList &matches) {
1332 return matches.GetSize();
1334 std::lock_guard<std::recursive_mutex> guard(GetPlatformInstancesMutex());
1335 PlatformInstances &instances = GetPlatformInstances();
1336 llvm::StringRef name_sref(name);
1338 PlatformInstances::iterator pos, end = instances.end();
1339 for (pos = instances.begin(); pos != end; ++pos) {
1340 llvm::StringRef plugin_name(pos->name.GetCString());
1341 if (plugin_name.startswith(name_sref))
1342 matches.AppendString(plugin_name.data());
1344 return matches.GetSize();
1347 #pragma mark Process
1349 struct ProcessInstance {
1351 : name(), description(), create_callback(nullptr),
1352 debugger_init_callback(nullptr) {}
1355 std::string description;
1356 ProcessCreateInstance create_callback;
1357 DebuggerInitializeCallback debugger_init_callback;
1360 typedef std::vector<ProcessInstance> ProcessInstances;
1362 static std::recursive_mutex &GetProcessMutex() {
1363 static std::recursive_mutex g_instances_mutex;
1364 return g_instances_mutex;
1367 static ProcessInstances &GetProcessInstances() {
1368 static ProcessInstances g_instances;
1372 bool PluginManager::RegisterPlugin(
1373 const ConstString &name, const char *description,
1374 ProcessCreateInstance create_callback,
1375 DebuggerInitializeCallback debugger_init_callback) {
1376 if (create_callback) {
1377 ProcessInstance instance;
1379 instance.name = name;
1380 if (description && description[0])
1381 instance.description = description;
1382 instance.create_callback = create_callback;
1383 instance.debugger_init_callback = debugger_init_callback;
1384 std::lock_guard<std::recursive_mutex> guard(GetProcessMutex());
1385 GetProcessInstances().push_back(instance);
1390 const char *PluginManager::GetProcessPluginNameAtIndex(uint32_t idx) {
1391 std::lock_guard<std::recursive_mutex> guard(GetProcessMutex());
1392 ProcessInstances &instances = GetProcessInstances();
1393 if (idx < instances.size())
1394 return instances[idx].name.GetCString();
1398 const char *PluginManager::GetProcessPluginDescriptionAtIndex(uint32_t idx) {
1399 std::lock_guard<std::recursive_mutex> guard(GetProcessMutex());
1400 ProcessInstances &instances = GetProcessInstances();
1401 if (idx < instances.size())
1402 return instances[idx].description.c_str();
1406 bool PluginManager::UnregisterPlugin(ProcessCreateInstance create_callback) {
1407 if (create_callback) {
1408 std::lock_guard<std::recursive_mutex> guard(GetProcessMutex());
1409 ProcessInstances &instances = GetProcessInstances();
1411 ProcessInstances::iterator pos, end = instances.end();
1412 for (pos = instances.begin(); pos != end; ++pos) {
1413 if (pos->create_callback == create_callback) {
1414 instances.erase(pos);
1422 ProcessCreateInstance
1423 PluginManager::GetProcessCreateCallbackAtIndex(uint32_t idx) {
1424 std::lock_guard<std::recursive_mutex> guard(GetProcessMutex());
1425 ProcessInstances &instances = GetProcessInstances();
1426 if (idx < instances.size())
1427 return instances[idx].create_callback;
1431 ProcessCreateInstance
1432 PluginManager::GetProcessCreateCallbackForPluginName(const ConstString &name) {
1434 std::lock_guard<std::recursive_mutex> guard(GetProcessMutex());
1435 ProcessInstances &instances = GetProcessInstances();
1437 ProcessInstances::iterator pos, end = instances.end();
1438 for (pos = instances.begin(); pos != end; ++pos) {
1439 if (name == pos->name)
1440 return pos->create_callback;
1446 #pragma mark ScriptInterpreter
1448 struct ScriptInterpreterInstance {
1449 ScriptInterpreterInstance()
1450 : name(), language(lldb::eScriptLanguageNone), description(),
1451 create_callback(nullptr) {}
1454 lldb::ScriptLanguage language;
1455 std::string description;
1456 ScriptInterpreterCreateInstance create_callback;
1459 typedef std::vector<ScriptInterpreterInstance> ScriptInterpreterInstances;
1461 static std::recursive_mutex &GetScriptInterpreterMutex() {
1462 static std::recursive_mutex g_instances_mutex;
1463 return g_instances_mutex;
1466 static ScriptInterpreterInstances &GetScriptInterpreterInstances() {
1467 static ScriptInterpreterInstances g_instances;
1471 bool PluginManager::RegisterPlugin(
1472 const ConstString &name, const char *description,
1473 lldb::ScriptLanguage script_language,
1474 ScriptInterpreterCreateInstance create_callback) {
1475 if (!create_callback)
1477 ScriptInterpreterInstance instance;
1479 instance.name = name;
1480 if (description && description[0])
1481 instance.description = description;
1482 instance.create_callback = create_callback;
1483 instance.language = script_language;
1484 std::lock_guard<std::recursive_mutex> guard(GetScriptInterpreterMutex());
1485 GetScriptInterpreterInstances().push_back(instance);
1489 bool PluginManager::UnregisterPlugin(
1490 ScriptInterpreterCreateInstance create_callback) {
1491 if (!create_callback)
1493 std::lock_guard<std::recursive_mutex> guard(GetScriptInterpreterMutex());
1494 ScriptInterpreterInstances &instances = GetScriptInterpreterInstances();
1496 ScriptInterpreterInstances::iterator pos, end = instances.end();
1497 for (pos = instances.begin(); pos != end; ++pos) {
1498 if (pos->create_callback != create_callback)
1501 instances.erase(pos);
1507 ScriptInterpreterCreateInstance
1508 PluginManager::GetScriptInterpreterCreateCallbackAtIndex(uint32_t idx) {
1509 std::lock_guard<std::recursive_mutex> guard(GetScriptInterpreterMutex());
1510 ScriptInterpreterInstances &instances = GetScriptInterpreterInstances();
1511 if (idx < instances.size())
1512 return instances[idx].create_callback;
1516 lldb::ScriptInterpreterSP PluginManager::GetScriptInterpreterForLanguage(
1517 lldb::ScriptLanguage script_lang, CommandInterpreter &interpreter) {
1518 std::lock_guard<std::recursive_mutex> guard(GetScriptInterpreterMutex());
1519 ScriptInterpreterInstances &instances = GetScriptInterpreterInstances();
1521 ScriptInterpreterInstances::iterator pos, end = instances.end();
1522 ScriptInterpreterCreateInstance none_instance = nullptr;
1523 for (pos = instances.begin(); pos != end; ++pos) {
1524 if (pos->language == lldb::eScriptLanguageNone)
1525 none_instance = pos->create_callback;
1527 if (script_lang == pos->language)
1528 return pos->create_callback(interpreter);
1531 // If we didn't find one, return the ScriptInterpreter for the null language.
1532 assert(none_instance != nullptr);
1533 return none_instance(interpreter);
1537 #pragma mark StructuredDataPlugin
1539 // -----------------------------------------------------------------------------
1540 // StructuredDataPlugin
1541 // -----------------------------------------------------------------------------
1543 struct StructuredDataPluginInstance {
1544 StructuredDataPluginInstance()
1545 : name(), description(), create_callback(nullptr),
1546 debugger_init_callback(nullptr), filter_callback(nullptr) {}
1549 std::string description;
1550 StructuredDataPluginCreateInstance create_callback;
1551 DebuggerInitializeCallback debugger_init_callback;
1552 StructuredDataFilterLaunchInfo filter_callback;
1555 typedef std::vector<StructuredDataPluginInstance> StructuredDataPluginInstances;
1557 static std::recursive_mutex &GetStructuredDataPluginMutex() {
1558 static std::recursive_mutex g_instances_mutex;
1559 return g_instances_mutex;
1562 static StructuredDataPluginInstances &GetStructuredDataPluginInstances() {
1563 static StructuredDataPluginInstances g_instances;
1567 bool PluginManager::RegisterPlugin(
1568 const ConstString &name, const char *description,
1569 StructuredDataPluginCreateInstance create_callback,
1570 DebuggerInitializeCallback debugger_init_callback,
1571 StructuredDataFilterLaunchInfo filter_callback) {
1572 if (create_callback) {
1573 StructuredDataPluginInstance instance;
1575 instance.name = name;
1576 if (description && description[0])
1577 instance.description = description;
1578 instance.create_callback = create_callback;
1579 instance.debugger_init_callback = debugger_init_callback;
1580 instance.filter_callback = filter_callback;
1581 std::lock_guard<std::recursive_mutex> guard(GetStructuredDataPluginMutex());
1582 GetStructuredDataPluginInstances().push_back(instance);
1587 bool PluginManager::UnregisterPlugin(
1588 StructuredDataPluginCreateInstance create_callback) {
1589 if (create_callback) {
1590 std::lock_guard<std::recursive_mutex> guard(GetStructuredDataPluginMutex());
1591 StructuredDataPluginInstances &instances =
1592 GetStructuredDataPluginInstances();
1594 StructuredDataPluginInstances::iterator pos, end = instances.end();
1595 for (pos = instances.begin(); pos != end; ++pos) {
1596 if (pos->create_callback == create_callback) {
1597 instances.erase(pos);
1605 StructuredDataPluginCreateInstance
1606 PluginManager::GetStructuredDataPluginCreateCallbackAtIndex(uint32_t idx) {
1607 std::lock_guard<std::recursive_mutex> guard(GetStructuredDataPluginMutex());
1608 StructuredDataPluginInstances &instances = GetStructuredDataPluginInstances();
1609 if (idx < instances.size())
1610 return instances[idx].create_callback;
1614 StructuredDataPluginCreateInstance
1615 PluginManager::GetStructuredDataPluginCreateCallbackForPluginName(
1616 const ConstString &name) {
1618 std::lock_guard<std::recursive_mutex> guard(GetStructuredDataPluginMutex());
1619 StructuredDataPluginInstances &instances =
1620 GetStructuredDataPluginInstances();
1622 StructuredDataPluginInstances::iterator pos, end = instances.end();
1623 for (pos = instances.begin(); pos != end; ++pos) {
1624 if (name == pos->name)
1625 return pos->create_callback;
1631 StructuredDataFilterLaunchInfo
1632 PluginManager::GetStructuredDataFilterCallbackAtIndex(
1633 uint32_t idx, bool &iteration_complete) {
1634 std::lock_guard<std::recursive_mutex> guard(GetStructuredDataPluginMutex());
1635 StructuredDataPluginInstances &instances = GetStructuredDataPluginInstances();
1636 if (idx < instances.size()) {
1637 iteration_complete = false;
1638 return instances[idx].filter_callback;
1640 iteration_complete = true;
1645 #pragma mark SymbolFile
1647 struct SymbolFileInstance {
1648 SymbolFileInstance()
1649 : name(), description(), create_callback(nullptr),
1650 debugger_init_callback(nullptr) {}
1653 std::string description;
1654 SymbolFileCreateInstance create_callback;
1655 DebuggerInitializeCallback debugger_init_callback;
1658 typedef std::vector<SymbolFileInstance> SymbolFileInstances;
1660 static std::recursive_mutex &GetSymbolFileMutex() {
1661 static std::recursive_mutex g_instances_mutex;
1662 return g_instances_mutex;
1665 static SymbolFileInstances &GetSymbolFileInstances() {
1666 static SymbolFileInstances g_instances;
1670 bool PluginManager::RegisterPlugin(
1671 const ConstString &name, const char *description,
1672 SymbolFileCreateInstance create_callback,
1673 DebuggerInitializeCallback debugger_init_callback) {
1674 if (create_callback) {
1675 SymbolFileInstance instance;
1677 instance.name = name;
1678 if (description && description[0])
1679 instance.description = description;
1680 instance.create_callback = create_callback;
1681 instance.debugger_init_callback = debugger_init_callback;
1682 std::lock_guard<std::recursive_mutex> guard(GetSymbolFileMutex());
1683 GetSymbolFileInstances().push_back(instance);
1688 bool PluginManager::UnregisterPlugin(SymbolFileCreateInstance create_callback) {
1689 if (create_callback) {
1690 std::lock_guard<std::recursive_mutex> guard(GetSymbolFileMutex());
1691 SymbolFileInstances &instances = GetSymbolFileInstances();
1693 SymbolFileInstances::iterator pos, end = instances.end();
1694 for (pos = instances.begin(); pos != end; ++pos) {
1695 if (pos->create_callback == create_callback) {
1696 instances.erase(pos);
1704 SymbolFileCreateInstance
1705 PluginManager::GetSymbolFileCreateCallbackAtIndex(uint32_t idx) {
1706 std::lock_guard<std::recursive_mutex> guard(GetSymbolFileMutex());
1707 SymbolFileInstances &instances = GetSymbolFileInstances();
1708 if (idx < instances.size())
1709 return instances[idx].create_callback;
1713 SymbolFileCreateInstance
1714 PluginManager::GetSymbolFileCreateCallbackForPluginName(
1715 const ConstString &name) {
1717 std::lock_guard<std::recursive_mutex> guard(GetSymbolFileMutex());
1718 SymbolFileInstances &instances = GetSymbolFileInstances();
1720 SymbolFileInstances::iterator pos, end = instances.end();
1721 for (pos = instances.begin(); pos != end; ++pos) {
1722 if (name == pos->name)
1723 return pos->create_callback;
1729 #pragma mark SymbolVendor
1731 struct SymbolVendorInstance {
1732 SymbolVendorInstance() : name(), description(), create_callback(nullptr) {}
1735 std::string description;
1736 SymbolVendorCreateInstance create_callback;
1739 typedef std::vector<SymbolVendorInstance> SymbolVendorInstances;
1741 static std::recursive_mutex &GetSymbolVendorMutex() {
1742 static std::recursive_mutex g_instances_mutex;
1743 return g_instances_mutex;
1746 static SymbolVendorInstances &GetSymbolVendorInstances() {
1747 static SymbolVendorInstances g_instances;
1751 bool PluginManager::RegisterPlugin(const ConstString &name,
1752 const char *description,
1753 SymbolVendorCreateInstance create_callback) {
1754 if (create_callback) {
1755 SymbolVendorInstance instance;
1757 instance.name = name;
1758 if (description && description[0])
1759 instance.description = description;
1760 instance.create_callback = create_callback;
1761 std::lock_guard<std::recursive_mutex> guard(GetSymbolVendorMutex());
1762 GetSymbolVendorInstances().push_back(instance);
1767 bool PluginManager::UnregisterPlugin(
1768 SymbolVendorCreateInstance create_callback) {
1769 if (create_callback) {
1770 std::lock_guard<std::recursive_mutex> guard(GetSymbolVendorMutex());
1771 SymbolVendorInstances &instances = GetSymbolVendorInstances();
1773 SymbolVendorInstances::iterator pos, end = instances.end();
1774 for (pos = instances.begin(); pos != end; ++pos) {
1775 if (pos->create_callback == create_callback) {
1776 instances.erase(pos);
1784 SymbolVendorCreateInstance
1785 PluginManager::GetSymbolVendorCreateCallbackAtIndex(uint32_t idx) {
1786 std::lock_guard<std::recursive_mutex> guard(GetSymbolVendorMutex());
1787 SymbolVendorInstances &instances = GetSymbolVendorInstances();
1788 if (idx < instances.size())
1789 return instances[idx].create_callback;
1793 SymbolVendorCreateInstance
1794 PluginManager::GetSymbolVendorCreateCallbackForPluginName(
1795 const ConstString &name) {
1797 std::lock_guard<std::recursive_mutex> guard(GetSymbolVendorMutex());
1798 SymbolVendorInstances &instances = GetSymbolVendorInstances();
1800 SymbolVendorInstances::iterator pos, end = instances.end();
1801 for (pos = instances.begin(); pos != end; ++pos) {
1802 if (name == pos->name)
1803 return pos->create_callback;
1809 #pragma mark UnwindAssembly
1811 struct UnwindAssemblyInstance {
1812 UnwindAssemblyInstance() : name(), description(), create_callback(nullptr) {}
1815 std::string description;
1816 UnwindAssemblyCreateInstance create_callback;
1819 typedef std::vector<UnwindAssemblyInstance> UnwindAssemblyInstances;
1821 static std::recursive_mutex &GetUnwindAssemblyMutex() {
1822 static std::recursive_mutex g_instances_mutex;
1823 return g_instances_mutex;
1826 static UnwindAssemblyInstances &GetUnwindAssemblyInstances() {
1827 static UnwindAssemblyInstances g_instances;
1831 bool PluginManager::RegisterPlugin(
1832 const ConstString &name, const char *description,
1833 UnwindAssemblyCreateInstance create_callback) {
1834 if (create_callback) {
1835 UnwindAssemblyInstance instance;
1837 instance.name = name;
1838 if (description && description[0])
1839 instance.description = description;
1840 instance.create_callback = create_callback;
1841 std::lock_guard<std::recursive_mutex> guard(GetUnwindAssemblyMutex());
1842 GetUnwindAssemblyInstances().push_back(instance);
1847 bool PluginManager::UnregisterPlugin(
1848 UnwindAssemblyCreateInstance create_callback) {
1849 if (create_callback) {
1850 std::lock_guard<std::recursive_mutex> guard(GetUnwindAssemblyMutex());
1851 UnwindAssemblyInstances &instances = GetUnwindAssemblyInstances();
1853 UnwindAssemblyInstances::iterator pos, end = instances.end();
1854 for (pos = instances.begin(); pos != end; ++pos) {
1855 if (pos->create_callback == create_callback) {
1856 instances.erase(pos);
1864 UnwindAssemblyCreateInstance
1865 PluginManager::GetUnwindAssemblyCreateCallbackAtIndex(uint32_t idx) {
1866 std::lock_guard<std::recursive_mutex> guard(GetUnwindAssemblyMutex());
1867 UnwindAssemblyInstances &instances = GetUnwindAssemblyInstances();
1868 if (idx < instances.size())
1869 return instances[idx].create_callback;
1873 UnwindAssemblyCreateInstance
1874 PluginManager::GetUnwindAssemblyCreateCallbackForPluginName(
1875 const ConstString &name) {
1877 std::lock_guard<std::recursive_mutex> guard(GetUnwindAssemblyMutex());
1878 UnwindAssemblyInstances &instances = GetUnwindAssemblyInstances();
1880 UnwindAssemblyInstances::iterator pos, end = instances.end();
1881 for (pos = instances.begin(); pos != end; ++pos) {
1882 if (name == pos->name)
1883 return pos->create_callback;
1889 #pragma mark MemoryHistory
1891 struct MemoryHistoryInstance {
1892 MemoryHistoryInstance() : name(), description(), create_callback(nullptr) {}
1895 std::string description;
1896 MemoryHistoryCreateInstance create_callback;
1899 typedef std::vector<MemoryHistoryInstance> MemoryHistoryInstances;
1901 static std::recursive_mutex &GetMemoryHistoryMutex() {
1902 static std::recursive_mutex g_instances_mutex;
1903 return g_instances_mutex;
1906 static MemoryHistoryInstances &GetMemoryHistoryInstances() {
1907 static MemoryHistoryInstances g_instances;
1911 bool PluginManager::RegisterPlugin(
1912 const ConstString &name, const char *description,
1913 MemoryHistoryCreateInstance create_callback) {
1914 if (create_callback) {
1915 MemoryHistoryInstance instance;
1917 instance.name = name;
1918 if (description && description[0])
1919 instance.description = description;
1920 instance.create_callback = create_callback;
1921 std::lock_guard<std::recursive_mutex> guard(GetMemoryHistoryMutex());
1922 GetMemoryHistoryInstances().push_back(instance);
1927 bool PluginManager::UnregisterPlugin(
1928 MemoryHistoryCreateInstance create_callback) {
1929 if (create_callback) {
1930 std::lock_guard<std::recursive_mutex> guard(GetMemoryHistoryMutex());
1931 MemoryHistoryInstances &instances = GetMemoryHistoryInstances();
1933 MemoryHistoryInstances::iterator pos, end = instances.end();
1934 for (pos = instances.begin(); pos != end; ++pos) {
1935 if (pos->create_callback == create_callback) {
1936 instances.erase(pos);
1944 MemoryHistoryCreateInstance
1945 PluginManager::GetMemoryHistoryCreateCallbackAtIndex(uint32_t idx) {
1946 std::lock_guard<std::recursive_mutex> guard(GetMemoryHistoryMutex());
1947 MemoryHistoryInstances &instances = GetMemoryHistoryInstances();
1948 if (idx < instances.size())
1949 return instances[idx].create_callback;
1953 MemoryHistoryCreateInstance
1954 PluginManager::GetMemoryHistoryCreateCallbackForPluginName(
1955 const ConstString &name) {
1957 std::lock_guard<std::recursive_mutex> guard(GetMemoryHistoryMutex());
1958 MemoryHistoryInstances &instances = GetMemoryHistoryInstances();
1960 MemoryHistoryInstances::iterator pos, end = instances.end();
1961 for (pos = instances.begin(); pos != end; ++pos) {
1962 if (name == pos->name)
1963 return pos->create_callback;
1969 #pragma mark InstrumentationRuntime
1971 struct InstrumentationRuntimeInstance {
1972 InstrumentationRuntimeInstance()
1973 : name(), description(), create_callback(nullptr) {}
1976 std::string description;
1977 InstrumentationRuntimeCreateInstance create_callback;
1978 InstrumentationRuntimeGetType get_type_callback;
1981 typedef std::vector<InstrumentationRuntimeInstance>
1982 InstrumentationRuntimeInstances;
1984 static std::recursive_mutex &GetInstrumentationRuntimeMutex() {
1985 static std::recursive_mutex g_instances_mutex;
1986 return g_instances_mutex;
1989 static InstrumentationRuntimeInstances &GetInstrumentationRuntimeInstances() {
1990 static InstrumentationRuntimeInstances g_instances;
1994 bool PluginManager::RegisterPlugin(
1995 const ConstString &name, const char *description,
1996 InstrumentationRuntimeCreateInstance create_callback,
1997 InstrumentationRuntimeGetType get_type_callback) {
1998 if (create_callback) {
1999 InstrumentationRuntimeInstance instance;
2001 instance.name = name;
2002 if (description && description[0])
2003 instance.description = description;
2004 instance.create_callback = create_callback;
2005 instance.get_type_callback = get_type_callback;
2006 std::lock_guard<std::recursive_mutex> guard(
2007 GetInstrumentationRuntimeMutex());
2008 GetInstrumentationRuntimeInstances().push_back(instance);
2013 bool PluginManager::UnregisterPlugin(
2014 InstrumentationRuntimeCreateInstance create_callback) {
2015 if (create_callback) {
2016 std::lock_guard<std::recursive_mutex> guard(
2017 GetInstrumentationRuntimeMutex());
2018 InstrumentationRuntimeInstances &instances =
2019 GetInstrumentationRuntimeInstances();
2021 InstrumentationRuntimeInstances::iterator pos, end = instances.end();
2022 for (pos = instances.begin(); pos != end; ++pos) {
2023 if (pos->create_callback == create_callback) {
2024 instances.erase(pos);
2032 InstrumentationRuntimeGetType
2033 PluginManager::GetInstrumentationRuntimeGetTypeCallbackAtIndex(uint32_t idx) {
2034 std::lock_guard<std::recursive_mutex> guard(GetInstrumentationRuntimeMutex());
2035 InstrumentationRuntimeInstances &instances =
2036 GetInstrumentationRuntimeInstances();
2037 if (idx < instances.size())
2038 return instances[idx].get_type_callback;
2042 InstrumentationRuntimeCreateInstance
2043 PluginManager::GetInstrumentationRuntimeCreateCallbackAtIndex(uint32_t idx) {
2044 std::lock_guard<std::recursive_mutex> guard(GetInstrumentationRuntimeMutex());
2045 InstrumentationRuntimeInstances &instances =
2046 GetInstrumentationRuntimeInstances();
2047 if (idx < instances.size())
2048 return instances[idx].create_callback;
2052 InstrumentationRuntimeCreateInstance
2053 PluginManager::GetInstrumentationRuntimeCreateCallbackForPluginName(
2054 const ConstString &name) {
2056 std::lock_guard<std::recursive_mutex> guard(
2057 GetInstrumentationRuntimeMutex());
2058 InstrumentationRuntimeInstances &instances =
2059 GetInstrumentationRuntimeInstances();
2061 InstrumentationRuntimeInstances::iterator pos, end = instances.end();
2062 for (pos = instances.begin(); pos != end; ++pos) {
2063 if (name == pos->name)
2064 return pos->create_callback;
2070 #pragma mark TypeSystem
2072 struct TypeSystemInstance {
2073 TypeSystemInstance() : name(), description(), create_callback(nullptr) {}
2076 std::string description;
2077 TypeSystemCreateInstance create_callback;
2078 TypeSystemEnumerateSupportedLanguages enumerate_callback;
2081 typedef std::vector<TypeSystemInstance> TypeSystemInstances;
2083 static std::recursive_mutex &GetTypeSystemMutex() {
2084 static std::recursive_mutex g_instances_mutex;
2085 return g_instances_mutex;
2088 static TypeSystemInstances &GetTypeSystemInstances() {
2089 static TypeSystemInstances g_instances;
2093 bool PluginManager::RegisterPlugin(const ConstString &name,
2094 const char *description,
2095 TypeSystemCreateInstance create_callback,
2096 TypeSystemEnumerateSupportedLanguages
2097 enumerate_supported_languages_callback) {
2098 if (create_callback) {
2099 TypeSystemInstance instance;
2101 instance.name = name;
2102 if (description && description[0])
2103 instance.description = description;
2104 instance.create_callback = create_callback;
2105 instance.enumerate_callback = enumerate_supported_languages_callback;
2106 std::lock_guard<std::recursive_mutex> guard(GetTypeSystemMutex());
2107 GetTypeSystemInstances().push_back(instance);
2112 bool PluginManager::UnregisterPlugin(TypeSystemCreateInstance create_callback) {
2113 if (create_callback) {
2114 std::lock_guard<std::recursive_mutex> guard(GetTypeSystemMutex());
2115 TypeSystemInstances &instances = GetTypeSystemInstances();
2117 TypeSystemInstances::iterator pos, end = instances.end();
2118 for (pos = instances.begin(); pos != end; ++pos) {
2119 if (pos->create_callback == create_callback) {
2120 instances.erase(pos);
2128 TypeSystemCreateInstance
2129 PluginManager::GetTypeSystemCreateCallbackAtIndex(uint32_t idx) {
2130 std::lock_guard<std::recursive_mutex> guard(GetTypeSystemMutex());
2131 TypeSystemInstances &instances = GetTypeSystemInstances();
2132 if (idx < instances.size())
2133 return instances[idx].create_callback;
2137 TypeSystemCreateInstance
2138 PluginManager::GetTypeSystemCreateCallbackForPluginName(
2139 const ConstString &name) {
2141 std::lock_guard<std::recursive_mutex> guard(GetTypeSystemMutex());
2142 TypeSystemInstances &instances = GetTypeSystemInstances();
2144 TypeSystemInstances::iterator pos, end = instances.end();
2145 for (pos = instances.begin(); pos != end; ++pos) {
2146 if (name == pos->name)
2147 return pos->create_callback;
2153 TypeSystemEnumerateSupportedLanguages
2154 PluginManager::GetTypeSystemEnumerateSupportedLanguagesCallbackAtIndex(
2156 std::lock_guard<std::recursive_mutex> guard(GetTypeSystemMutex());
2157 TypeSystemInstances &instances = GetTypeSystemInstances();
2158 if (idx < instances.size())
2159 return instances[idx].enumerate_callback;
2163 TypeSystemEnumerateSupportedLanguages
2164 PluginManager::GetTypeSystemEnumerateSupportedLanguagesCallbackForPluginName(
2165 const ConstString &name) {
2167 std::lock_guard<std::recursive_mutex> guard(GetTypeSystemMutex());
2168 TypeSystemInstances &instances = GetTypeSystemInstances();
2170 TypeSystemInstances::iterator pos, end = instances.end();
2171 for (pos = instances.begin(); pos != end; ++pos) {
2172 if (name == pos->name)
2173 return pos->enumerate_callback;
2181 struct REPLInstance {
2182 REPLInstance() : name(), description(), create_callback(nullptr) {}
2185 std::string description;
2186 REPLCreateInstance create_callback;
2187 REPLEnumerateSupportedLanguages enumerate_languages_callback;
2190 typedef std::vector<REPLInstance> REPLInstances;
2192 static std::recursive_mutex &GetREPLMutex() {
2193 static std::recursive_mutex g_instances_mutex;
2194 return g_instances_mutex;
2197 static REPLInstances &GetREPLInstances() {
2198 static REPLInstances g_instances;
2202 bool PluginManager::RegisterPlugin(
2203 const ConstString &name, const char *description,
2204 REPLCreateInstance create_callback,
2205 REPLEnumerateSupportedLanguages enumerate_languages_callback) {
2206 if (create_callback) {
2207 REPLInstance instance;
2209 instance.name = name;
2210 if (description && description[0])
2211 instance.description = description;
2212 instance.create_callback = create_callback;
2213 instance.enumerate_languages_callback = enumerate_languages_callback;
2214 std::lock_guard<std::recursive_mutex> guard(GetREPLMutex());
2215 GetREPLInstances().push_back(instance);
2220 bool PluginManager::UnregisterPlugin(REPLCreateInstance create_callback) {
2221 if (create_callback) {
2222 std::lock_guard<std::recursive_mutex> guard(GetREPLMutex());
2223 REPLInstances &instances = GetREPLInstances();
2225 REPLInstances::iterator pos, end = instances.end();
2226 for (pos = instances.begin(); pos != end; ++pos) {
2227 if (pos->create_callback == create_callback) {
2228 instances.erase(pos);
2236 REPLCreateInstance PluginManager::GetREPLCreateCallbackAtIndex(uint32_t idx) {
2237 std::lock_guard<std::recursive_mutex> guard(GetREPLMutex());
2238 REPLInstances &instances = GetREPLInstances();
2239 if (idx < instances.size())
2240 return instances[idx].create_callback;
2245 PluginManager::GetREPLCreateCallbackForPluginName(const ConstString &name) {
2247 std::lock_guard<std::recursive_mutex> guard(GetREPLMutex());
2248 REPLInstances &instances = GetREPLInstances();
2250 REPLInstances::iterator pos, end = instances.end();
2251 for (pos = instances.begin(); pos != end; ++pos) {
2252 if (name == pos->name)
2253 return pos->create_callback;
2259 REPLEnumerateSupportedLanguages
2260 PluginManager::GetREPLEnumerateSupportedLanguagesCallbackAtIndex(uint32_t idx) {
2261 std::lock_guard<std::recursive_mutex> guard(GetREPLMutex());
2262 REPLInstances &instances = GetREPLInstances();
2263 if (idx < instances.size())
2264 return instances[idx].enumerate_languages_callback;
2268 REPLEnumerateSupportedLanguages
2269 PluginManager::GetREPLSystemEnumerateSupportedLanguagesCallbackForPluginName(
2270 const ConstString &name) {
2272 std::lock_guard<std::recursive_mutex> guard(GetREPLMutex());
2273 REPLInstances &instances = GetREPLInstances();
2275 REPLInstances::iterator pos, end = instances.end();
2276 for (pos = instances.begin(); pos != end; ++pos) {
2277 if (name == pos->name)
2278 return pos->enumerate_languages_callback;
2284 #pragma mark PluginManager
2286 void PluginManager::DebuggerInitialize(Debugger &debugger) {
2287 // Initialize the DynamicLoader plugins
2289 std::lock_guard<std::recursive_mutex> guard(GetDynamicLoaderMutex());
2290 DynamicLoaderInstances &instances = GetDynamicLoaderInstances();
2292 DynamicLoaderInstances::iterator pos, end = instances.end();
2293 for (pos = instances.begin(); pos != end; ++pos) {
2294 if (pos->debugger_init_callback)
2295 pos->debugger_init_callback(debugger);
2299 // Initialize the JITLoader plugins
2301 std::lock_guard<std::recursive_mutex> guard(GetJITLoaderMutex());
2302 JITLoaderInstances &instances = GetJITLoaderInstances();
2304 JITLoaderInstances::iterator pos, end = instances.end();
2305 for (pos = instances.begin(); pos != end; ++pos) {
2306 if (pos->debugger_init_callback)
2307 pos->debugger_init_callback(debugger);
2311 // Initialize the Platform plugins
2313 std::lock_guard<std::recursive_mutex> guard(GetPlatformInstancesMutex());
2314 PlatformInstances &instances = GetPlatformInstances();
2316 PlatformInstances::iterator pos, end = instances.end();
2317 for (pos = instances.begin(); pos != end; ++pos) {
2318 if (pos->debugger_init_callback)
2319 pos->debugger_init_callback(debugger);
2323 // Initialize the Process plugins
2325 std::lock_guard<std::recursive_mutex> guard(GetProcessMutex());
2326 ProcessInstances &instances = GetProcessInstances();
2328 ProcessInstances::iterator pos, end = instances.end();
2329 for (pos = instances.begin(); pos != end; ++pos) {
2330 if (pos->debugger_init_callback)
2331 pos->debugger_init_callback(debugger);
2335 // Initialize the SymbolFile plugins
2337 std::lock_guard<std::recursive_mutex> guard(GetSymbolFileMutex());
2338 for (auto &sym_file : GetSymbolFileInstances()) {
2339 if (sym_file.debugger_init_callback)
2340 sym_file.debugger_init_callback(debugger);
2344 // Initialize the OperatingSystem plugins
2346 std::lock_guard<std::recursive_mutex> guard(GetOperatingSystemMutex());
2347 for (auto &os : GetOperatingSystemInstances()) {
2348 if (os.debugger_init_callback)
2349 os.debugger_init_callback(debugger);
2353 // Initialize the StructuredDataPlugin plugins
2355 std::lock_guard<std::recursive_mutex> guard(GetStructuredDataPluginMutex());
2356 for (auto &plugin : GetStructuredDataPluginInstances()) {
2357 if (plugin.debugger_init_callback)
2358 plugin.debugger_init_callback(debugger);
2363 // This is the preferred new way to register plugin specific settings. e.g.
2364 // This will put a plugin's settings under e.g.
2365 // "plugin.<plugin_type_name>.<plugin_type_desc>.SETTINGNAME".
2366 static lldb::OptionValuePropertiesSP GetDebuggerPropertyForPlugins(
2367 Debugger &debugger, const ConstString &plugin_type_name,
2368 const ConstString &plugin_type_desc, bool can_create) {
2369 lldb::OptionValuePropertiesSP parent_properties_sp(
2370 debugger.GetValueProperties());
2371 if (parent_properties_sp) {
2372 static ConstString g_property_name("plugin");
2374 OptionValuePropertiesSP plugin_properties_sp =
2375 parent_properties_sp->GetSubProperty(nullptr, g_property_name);
2376 if (!plugin_properties_sp && can_create) {
2377 plugin_properties_sp =
2378 std::make_shared<OptionValueProperties>(g_property_name);
2379 parent_properties_sp->AppendProperty(
2380 g_property_name, ConstString("Settings specify to plugins."), true,
2381 plugin_properties_sp);
2384 if (plugin_properties_sp) {
2385 lldb::OptionValuePropertiesSP plugin_type_properties_sp =
2386 plugin_properties_sp->GetSubProperty(nullptr, plugin_type_name);
2387 if (!plugin_type_properties_sp && can_create) {
2388 plugin_type_properties_sp =
2389 std::make_shared<OptionValueProperties>(plugin_type_name);
2390 plugin_properties_sp->AppendProperty(plugin_type_name, plugin_type_desc,
2391 true, plugin_type_properties_sp);
2393 return plugin_type_properties_sp;
2396 return lldb::OptionValuePropertiesSP();
2399 // This is deprecated way to register plugin specific settings. e.g.
2400 // "<plugin_type_name>.plugin.<plugin_type_desc>.SETTINGNAME"
2401 // and Platform generic settings would be under "platform.SETTINGNAME".
2402 static lldb::OptionValuePropertiesSP GetDebuggerPropertyForPluginsOldStyle(
2403 Debugger &debugger, const ConstString &plugin_type_name,
2404 const ConstString &plugin_type_desc, bool can_create) {
2405 static ConstString g_property_name("plugin");
2406 lldb::OptionValuePropertiesSP parent_properties_sp(
2407 debugger.GetValueProperties());
2408 if (parent_properties_sp) {
2409 OptionValuePropertiesSP plugin_properties_sp =
2410 parent_properties_sp->GetSubProperty(nullptr, plugin_type_name);
2411 if (!plugin_properties_sp && can_create) {
2412 plugin_properties_sp =
2413 std::make_shared<OptionValueProperties>(plugin_type_name);
2414 parent_properties_sp->AppendProperty(plugin_type_name, plugin_type_desc,
2415 true, plugin_properties_sp);
2418 if (plugin_properties_sp) {
2419 lldb::OptionValuePropertiesSP plugin_type_properties_sp =
2420 plugin_properties_sp->GetSubProperty(nullptr, g_property_name);
2421 if (!plugin_type_properties_sp && can_create) {
2422 plugin_type_properties_sp =
2423 std::make_shared<OptionValueProperties>(g_property_name);
2424 plugin_properties_sp->AppendProperty(
2425 g_property_name, ConstString("Settings specific to plugins"), true,
2426 plugin_type_properties_sp);
2428 return plugin_type_properties_sp;
2431 return lldb::OptionValuePropertiesSP();
2436 typedef lldb::OptionValuePropertiesSP
2437 GetDebuggerPropertyForPluginsPtr(Debugger &, const ConstString &,
2438 const ConstString &, bool can_create);
2440 lldb::OptionValuePropertiesSP
2441 GetSettingForPlugin(Debugger &debugger, const ConstString &setting_name,
2442 const ConstString &plugin_type_name,
2443 GetDebuggerPropertyForPluginsPtr get_debugger_property =
2444 GetDebuggerPropertyForPlugins) {
2445 lldb::OptionValuePropertiesSP properties_sp;
2446 lldb::OptionValuePropertiesSP plugin_type_properties_sp(get_debugger_property(
2447 debugger, plugin_type_name,
2448 ConstString(), // not creating to so we don't need the description
2450 if (plugin_type_properties_sp)
2452 plugin_type_properties_sp->GetSubProperty(nullptr, setting_name);
2453 return properties_sp;
2456 bool CreateSettingForPlugin(
2457 Debugger &debugger, const ConstString &plugin_type_name,
2458 const ConstString &plugin_type_desc,
2459 const lldb::OptionValuePropertiesSP &properties_sp,
2460 const ConstString &description, bool is_global_property,
2461 GetDebuggerPropertyForPluginsPtr get_debugger_property =
2462 GetDebuggerPropertyForPlugins) {
2463 if (properties_sp) {
2464 lldb::OptionValuePropertiesSP plugin_type_properties_sp(
2465 get_debugger_property(debugger, plugin_type_name, plugin_type_desc,
2467 if (plugin_type_properties_sp) {
2468 plugin_type_properties_sp->AppendProperty(properties_sp->GetName(),
2469 description, is_global_property,
2477 const char *kDynamicLoaderPluginName("dynamic-loader");
2478 const char *kPlatformPluginName("platform");
2479 const char *kProcessPluginName("process");
2480 const char *kSymbolFilePluginName("symbol-file");
2481 const char *kJITLoaderPluginName("jit-loader");
2482 const char *kStructuredDataPluginName("structured-data");
2484 } // anonymous namespace
2486 lldb::OptionValuePropertiesSP PluginManager::GetSettingForDynamicLoaderPlugin(
2487 Debugger &debugger, const ConstString &setting_name) {
2488 return GetSettingForPlugin(debugger, setting_name,
2489 ConstString(kDynamicLoaderPluginName));
2492 bool PluginManager::CreateSettingForDynamicLoaderPlugin(
2493 Debugger &debugger, const lldb::OptionValuePropertiesSP &properties_sp,
2494 const ConstString &description, bool is_global_property) {
2495 return CreateSettingForPlugin(
2496 debugger, ConstString(kDynamicLoaderPluginName),
2497 ConstString("Settings for dynamic loader plug-ins"), properties_sp,
2498 description, is_global_property);
2501 lldb::OptionValuePropertiesSP
2502 PluginManager::GetSettingForPlatformPlugin(Debugger &debugger,
2503 const ConstString &setting_name) {
2504 return GetSettingForPlugin(debugger, setting_name,
2505 ConstString(kPlatformPluginName),
2506 GetDebuggerPropertyForPluginsOldStyle);
2509 bool PluginManager::CreateSettingForPlatformPlugin(
2510 Debugger &debugger, const lldb::OptionValuePropertiesSP &properties_sp,
2511 const ConstString &description, bool is_global_property) {
2512 return CreateSettingForPlugin(debugger, ConstString(kPlatformPluginName),
2513 ConstString("Settings for platform plug-ins"),
2514 properties_sp, description, is_global_property,
2515 GetDebuggerPropertyForPluginsOldStyle);
2518 lldb::OptionValuePropertiesSP
2519 PluginManager::GetSettingForProcessPlugin(Debugger &debugger,
2520 const ConstString &setting_name) {
2521 return GetSettingForPlugin(debugger, setting_name,
2522 ConstString(kProcessPluginName));
2525 bool PluginManager::CreateSettingForProcessPlugin(
2526 Debugger &debugger, const lldb::OptionValuePropertiesSP &properties_sp,
2527 const ConstString &description, bool is_global_property) {
2528 return CreateSettingForPlugin(debugger, ConstString(kProcessPluginName),
2529 ConstString("Settings for process plug-ins"),
2530 properties_sp, description, is_global_property);
2533 lldb::OptionValuePropertiesSP
2534 PluginManager::GetSettingForSymbolFilePlugin(Debugger &debugger,
2535 const ConstString &setting_name) {
2536 return GetSettingForPlugin(debugger, setting_name,
2537 ConstString(kSymbolFilePluginName));
2540 bool PluginManager::CreateSettingForSymbolFilePlugin(
2541 Debugger &debugger, const lldb::OptionValuePropertiesSP &properties_sp,
2542 const ConstString &description, bool is_global_property) {
2543 return CreateSettingForPlugin(
2544 debugger, ConstString(kSymbolFilePluginName),
2545 ConstString("Settings for symbol file plug-ins"), properties_sp,
2546 description, is_global_property);
2549 lldb::OptionValuePropertiesSP
2550 PluginManager::GetSettingForJITLoaderPlugin(Debugger &debugger,
2551 const ConstString &setting_name) {
2552 return GetSettingForPlugin(debugger, setting_name,
2553 ConstString(kJITLoaderPluginName));
2556 bool PluginManager::CreateSettingForJITLoaderPlugin(
2557 Debugger &debugger, const lldb::OptionValuePropertiesSP &properties_sp,
2558 const ConstString &description, bool is_global_property) {
2559 return CreateSettingForPlugin(debugger, ConstString(kJITLoaderPluginName),
2560 ConstString("Settings for JIT loader plug-ins"),
2561 properties_sp, description, is_global_property);
2564 static const char *kOperatingSystemPluginName("os");
2566 lldb::OptionValuePropertiesSP PluginManager::GetSettingForOperatingSystemPlugin(
2567 Debugger &debugger, const ConstString &setting_name) {
2568 lldb::OptionValuePropertiesSP properties_sp;
2569 lldb::OptionValuePropertiesSP plugin_type_properties_sp(
2570 GetDebuggerPropertyForPlugins(
2571 debugger, ConstString(kOperatingSystemPluginName),
2572 ConstString(), // not creating to so we don't need the description
2574 if (plugin_type_properties_sp)
2576 plugin_type_properties_sp->GetSubProperty(nullptr, setting_name);
2577 return properties_sp;
2580 bool PluginManager::CreateSettingForOperatingSystemPlugin(
2581 Debugger &debugger, const lldb::OptionValuePropertiesSP &properties_sp,
2582 const ConstString &description, bool is_global_property) {
2583 if (properties_sp) {
2584 lldb::OptionValuePropertiesSP plugin_type_properties_sp(
2585 GetDebuggerPropertyForPlugins(
2586 debugger, ConstString(kOperatingSystemPluginName),
2587 ConstString("Settings for operating system plug-ins"), true));
2588 if (plugin_type_properties_sp) {
2589 plugin_type_properties_sp->AppendProperty(properties_sp->GetName(),
2590 description, is_global_property,
2598 lldb::OptionValuePropertiesSP PluginManager::GetSettingForStructuredDataPlugin(
2599 Debugger &debugger, const ConstString &setting_name) {
2600 return GetSettingForPlugin(debugger, setting_name,
2601 ConstString(kStructuredDataPluginName));
2604 bool PluginManager::CreateSettingForStructuredDataPlugin(
2605 Debugger &debugger, const lldb::OptionValuePropertiesSP &properties_sp,
2606 const ConstString &description, bool is_global_property) {
2607 return CreateSettingForPlugin(
2608 debugger, ConstString(kStructuredDataPluginName),
2609 ConstString("Settings for structured data plug-ins"), properties_sp,
2610 description, is_global_property);