diff options
author | Med Ismail Bennani <ismail@bennani.ma> | 2024-09-19 23:35:34 -0700 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-09-19 23:35:34 -0700 |
commit | 1e131ddfa8f1d7b18c85c6e4079458be8b419421 (patch) | |
tree | 6aac6c2d98fdb259657996ba7848949ddb3152a5 /lldb/source/Interpreter/ScriptInterpreter.cpp | |
parent | f9bd08382a4ad84c06e0b572d3b7fc3ecdb81898 (diff) | |
download | llvm-1e131ddfa8f1d7b18c85c6e4079458be8b419421.zip llvm-1e131ddfa8f1d7b18c85c6e4079458be8b419421.tar.gz llvm-1e131ddfa8f1d7b18c85c6e4079458be8b419421.tar.bz2 |
[lldb/Interpreter] Introduce `ScriptedStopHook{,Python}Interface` & make use of it (#105449)
This patch introduces new `ScriptedStopHook{,Python}Interface` classes
that make use of the Scripted Interface infrastructure and makes use of
it in `StopHookScripted`.
It also relax the requirement on the number of argument for initializing
scripting extension if the size of the interface parameter pack contains
1 less element than the extension maximum number of positional arguments
for this initializer.
This addresses the cases where the embedded interpreter session
dictionary is passed to the extension initializer which is not used most
of the time.
---------
Signed-off-by: Med Ismail Bennani <ismail@bennani.ma>
Diffstat (limited to 'lldb/source/Interpreter/ScriptInterpreter.cpp')
-rw-r--r-- | lldb/source/Interpreter/ScriptInterpreter.cpp | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/lldb/source/Interpreter/ScriptInterpreter.cpp b/lldb/source/Interpreter/ScriptInterpreter.cpp index 8b55221..559b830 100644 --- a/lldb/source/Interpreter/ScriptInterpreter.cpp +++ b/lldb/source/Interpreter/ScriptInterpreter.cpp @@ -125,6 +125,12 @@ ScriptInterpreter::GetOpaqueTypeFromSBMemoryRegionInfo( return *mem_region.m_opaque_up.get(); } +lldb::ExecutionContextRefSP +ScriptInterpreter::GetOpaqueTypeFromSBExecutionContext( + const lldb::SBExecutionContext &exe_ctx) const { + return exe_ctx.m_exe_ctx_sp; +} + lldb::ScriptLanguage ScriptInterpreter::StringToLanguage(const llvm::StringRef &language) { if (language.equals_insensitive(LanguageToString(eScriptLanguageNone))) |