Files
llvm-project/lldb/source/Target/JITLoader.cpp
Jonas Devlieghere 81a537e708 [lldb] Use range-based for loops over plugins (#184837)
This PR replaces the Get*CallbackAtIndex pattern in the PluginManager
with returning a snapshot of callbacks that the caller can iterate over
using a range-based for loop. This is a continuation of #184452 which
added thread safety by using snapshots. However, that introduced a bunch
of unnecessary copies which are largely eliminated again by getting the
snapshot once when gather all the callbacks, rather than doing that on
each iteration when querying a plugin for a given index. It also
eliminates the possibility of the snapshot changing underneath you when
iterating over the plugins.

This change was largely mechanical and I used Claude to do the menial
work of updating the signatures and call sites.
2026-03-06 22:48:33 +00:00

29 lines
978 B
C++

//===-- JITLoader.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/Target/JITLoader.h"
#include "lldb/Core/PluginManager.h"
#include "lldb/Target/JITLoaderList.h"
#include "lldb/Target/Process.h"
#include "lldb/lldb-private.h"
using namespace lldb;
using namespace lldb_private;
void JITLoader::LoadPlugins(Process *process, JITLoaderList &list) {
for (auto create_callback : PluginManager::GetJITLoaderCreateCallbacks()) {
JITLoaderSP instance_sp(create_callback(process, false));
if (instance_sp)
list.Append(std::move(instance_sp));
}
}
JITLoader::JITLoader(Process *process) : m_process(process) {}
JITLoader::~JITLoader() = default;