
This patch tries to fix an issue with the windows debug builds where the PDB file for python scripted interfaces cannot be opened since its path length exceed the windows `MAX_PATH` limit: https://github.com/llvm/llvm-project/pull/101672#issuecomment-2289481324 This patch addresses the issue by building all the interfaces as a single library plugin that initiliazes each component as part of its `Initialize` method, instead of building each interface as its own library plugin. This keeps the build artifact path length smaller while respecting the naming convention and without making any exception in the build system. Fixes #104895. Signed-off-by: Med Ismail Bennani <ismail@bennani.ma>
124 lines
3.8 KiB
C++
124 lines
3.8 KiB
C++
//===-- ScriptedThreadPlanPythonInterface.cpp -----------------------------===//
|
|
//
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#include "lldb/Core/PluginManager.h"
|
|
#include "lldb/Host/Config.h"
|
|
#include "lldb/Utility/Log.h"
|
|
#include "lldb/lldb-enumerations.h"
|
|
|
|
#if LLDB_ENABLE_PYTHON
|
|
|
|
// clang-format off
|
|
// LLDB Python header must be included first
|
|
#include "../lldb-python.h"
|
|
//clang-format on
|
|
|
|
#include "../SWIGPythonBridge.h"
|
|
#include "../ScriptInterpreterPythonImpl.h"
|
|
#include "ScriptedThreadPlanPythonInterface.h"
|
|
|
|
using namespace lldb;
|
|
using namespace lldb_private;
|
|
using namespace lldb_private::python;
|
|
|
|
ScriptedThreadPlanPythonInterface::ScriptedThreadPlanPythonInterface(
|
|
ScriptInterpreterPythonImpl &interpreter)
|
|
: ScriptedThreadPlanInterface(), ScriptedPythonInterface(interpreter) {}
|
|
|
|
llvm::Expected<StructuredData::GenericSP>
|
|
ScriptedThreadPlanPythonInterface::CreatePluginObject(
|
|
const llvm::StringRef class_name, lldb::ThreadPlanSP thread_plan_sp,
|
|
const StructuredDataImpl &args_sp) {
|
|
return ScriptedPythonInterface::CreatePluginObject(class_name, nullptr,
|
|
thread_plan_sp, args_sp);
|
|
}
|
|
|
|
llvm::Expected<bool>
|
|
ScriptedThreadPlanPythonInterface::ExplainsStop(Event *event) {
|
|
Status error;
|
|
StructuredData::ObjectSP obj = Dispatch("explains_stop", error, event);
|
|
|
|
if (!ScriptedInterface::CheckStructuredDataObject(LLVM_PRETTY_FUNCTION, obj,
|
|
error)) {
|
|
if (!obj)
|
|
return false;
|
|
return error.ToError();
|
|
}
|
|
|
|
return obj->GetBooleanValue();
|
|
}
|
|
|
|
llvm::Expected<bool>
|
|
ScriptedThreadPlanPythonInterface::ShouldStop(Event *event) {
|
|
Status error;
|
|
StructuredData::ObjectSP obj = Dispatch("should_stop", error, event);
|
|
|
|
if (!ScriptedInterface::CheckStructuredDataObject(LLVM_PRETTY_FUNCTION, obj,
|
|
error)) {
|
|
if (!obj)
|
|
return false;
|
|
return error.ToError();
|
|
}
|
|
|
|
return obj->GetBooleanValue();
|
|
}
|
|
|
|
llvm::Expected<bool> ScriptedThreadPlanPythonInterface::IsStale() {
|
|
Status error;
|
|
StructuredData::ObjectSP obj = Dispatch("is_stale", error);
|
|
|
|
if (!ScriptedInterface::CheckStructuredDataObject(LLVM_PRETTY_FUNCTION, obj,
|
|
error)) {
|
|
if (!obj)
|
|
return false;
|
|
return error.ToError();
|
|
}
|
|
|
|
return obj->GetBooleanValue();
|
|
}
|
|
|
|
lldb::StateType ScriptedThreadPlanPythonInterface::GetRunState() {
|
|
Status error;
|
|
StructuredData::ObjectSP obj = Dispatch("should_step", error);
|
|
|
|
if (!ScriptedInterface::CheckStructuredDataObject(LLVM_PRETTY_FUNCTION, obj,
|
|
error))
|
|
return lldb::eStateStepping;
|
|
|
|
return static_cast<lldb::StateType>(obj->GetUnsignedIntegerValue(
|
|
static_cast<uint32_t>(lldb::eStateStepping)));
|
|
}
|
|
|
|
llvm::Error
|
|
ScriptedThreadPlanPythonInterface::GetStopDescription(lldb::StreamSP &stream) {
|
|
Status error;
|
|
Dispatch("stop_description", error, stream);
|
|
|
|
if (error.Fail())
|
|
return error.ToError();
|
|
|
|
return llvm::Error::success();
|
|
}
|
|
|
|
void ScriptedThreadPlanPythonInterface::Initialize() {
|
|
const std::vector<llvm::StringRef> ci_usages = {
|
|
"thread step-scripted -C <script-name> [-k key -v value ...]"};
|
|
const std::vector<llvm::StringRef> api_usages = {
|
|
"SBThread.StepUsingScriptedThreadPlan"};
|
|
PluginManager::RegisterPlugin(
|
|
GetPluginNameStatic(),
|
|
llvm::StringRef("Alter thread stepping logic and stop reason"),
|
|
CreateInstance, eScriptLanguagePython, {ci_usages, api_usages});
|
|
}
|
|
|
|
void ScriptedThreadPlanPythonInterface::Terminate() {
|
|
PluginManager::UnregisterPlugin(CreateInstance);
|
|
}
|
|
|
|
#endif
|