LLDB mainline
ScriptedFrameProviderPythonInterface.cpp
Go to the documentation of this file.
1//===----------------------------------------------------------------------===//
2//
3// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4// See https://llvm.org/LICENSE.txt for license information.
5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6//
7//===----------------------------------------------------------------------===//
8
9#include "../lldb-python.h"
10
12#include "lldb/Target/Thread.h"
13#include "lldb/Utility/Log.h"
15
16#include "../SWIGPythonBridge.h"
19#include <optional>
20
21using namespace lldb;
22using namespace lldb_private;
23using namespace lldb_private::python;
25
29
31 llvm::StringRef class_name, lldb::ThreadSP thread_sp) {
32 // If there is any issue with this method, we will just assume it also applies
33 // to this thread which is the default behavior.
34 constexpr bool fail_value = true;
37 CallStaticMethod(class_name, "applies_to_thread", error, thread_sp);
38 if (!ScriptedInterface::CheckStructuredDataObject(LLVM_PRETTY_FUNCTION, obj,
39 error))
40 return fail_value;
41
42 return obj->GetBooleanValue(fail_value);
43}
44
45llvm::Expected<StructuredData::GenericSP>
47 const ScriptedMetadata &scripted_metadata,
48 lldb::StackFrameListSP input_frames) {
49 if (!input_frames)
50 return llvm::createStringError("invalid frame list");
51
53 scripted_metadata, nullptr, input_frames, scripted_metadata.GetArgsSP());
54}
55
57 llvm::StringRef class_name) {
60 CallStaticMethod(class_name, "get_description", error);
61 if (!ScriptedInterface::CheckStructuredDataObject(LLVM_PRETTY_FUNCTION, obj,
62 error))
63 return {};
64
65 return obj->GetStringValue().str();
66}
67
68std::optional<uint32_t>
72 CallStaticMethod(class_name, "get_priority", error);
73
74 if (!ScriptedInterface::CheckStructuredDataObject(LLVM_PRETTY_FUNCTION, obj,
75 error))
76 return std::nullopt;
77
78 // Try to extract as unsigned integer. Return nullopt if Python returned None
79 // or if extraction fails.
80 if (StructuredData::UnsignedInteger *int_obj = obj->GetAsUnsignedInteger())
81 return static_cast<uint32_t>(int_obj->GetValue());
82
83 return std::nullopt;
84}
85
89 StructuredData::ObjectSP obj = Dispatch("get_frame_at_index", error, index);
90
91 if (!ScriptedInterface::CheckStructuredDataObject(LLVM_PRETTY_FUNCTION, obj,
92 error))
93 return {};
94
95 return obj;
96}
97
100 if (language != eScriptLanguagePython)
101 return false;
102
103 return true;
104}
105
107 const std::vector<llvm::StringRef> ci_usages = {
108 "target frame-provider register -C <script-name> [-k key -v value ...]",
109 "target frame-provider list",
110 "target frame-provider remove <provider-name>",
111 "target frame-provider clear"};
112 const std::vector<llvm::StringRef> api_usages = {
113 "SBTarget.RegisterScriptedFrameProvider",
114 "SBTarget.RemoveScriptedFrameProvider",
115 "SBTarget.ClearScriptedFrameProvider"};
118 llvm::StringRef("Provide scripted stack frames for threads"),
119 CreateInstance, eScriptLanguagePython, {ci_usages, api_usages});
120}
121
static llvm::raw_ostream & error(Stream &strm)
ScriptInterpreterPythonImpl::Locker Locker
static bool RegisterPlugin(llvm::StringRef name, llvm::StringRef description, ABICreateInstance create_callback)
static bool UnregisterPlugin(ABICreateInstance create_callback)
llvm::Expected< StructuredData::GenericSP > CreatePluginObject(const ScriptedMetadata &scripted_metadata, lldb::StackFrameListSP input_frames) override
static bool CreateInstance(lldb::ScriptLanguage language, ScriptedInterfaceUsages usages)
StructuredData::ObjectSP GetFrameAtIndex(uint32_t index) override
ScriptedFrameProviderPythonInterface(ScriptInterpreterPythonImpl &interpreter)
std::optional< uint32_t > GetPriority(llvm::StringRef class_name) override
Get the priority of this frame provider.
bool AppliesToThread(llvm::StringRef class_name, lldb::ThreadSP thread_sp) override
std::string GetDescription(llvm::StringRef class_name) override
Get a description string for the frame provider.
static bool CheckStructuredDataObject(llvm::StringRef caller, T obj, Status &error)
StructuredData::DictionarySP GetArgsSP() const
ScriptedPythonInterface(ScriptInterpreterPythonImpl &interpreter)
T CallStaticMethod(llvm::StringRef class_name, llvm::StringRef method_name, Status &error, Args &&...args)
Call a static method on a Python class without creating an instance.
T Dispatch(llvm::StringRef method_name, Status &error, Args &&...args)
llvm::Expected< StructuredData::GenericSP > CreatePluginObject(const ScriptedMetadata &scripted_metadata, StructuredData::Generic *script_obj, Args... args)
An error handling class.
Definition Status.h:118
std::shared_ptr< Object > ObjectSP
Integer< uint64_t > UnsignedInteger
A class that represents a running process on the host machine.
ScriptLanguage
Script interpreter types.
@ eScriptLanguagePython
std::shared_ptr< lldb_private::Thread > ThreadSP
std::shared_ptr< lldb_private::StackFrameList > StackFrameListSP