From 0b57cec536236d46e3dba9bd041533462f33dbb7 Mon Sep 17 00:00:00 2001 From: Dimitry Andric Date: Fri, 20 Dec 2019 19:53:05 +0000 Subject: Move all sources from the llvm project into contrib/llvm-project. This uses the new layout of the upstream repository, which was recently migrated to GitHub, and converted into a "monorepo". That is, most of the earlier separate sub-projects with their own branches and tags were consolidated into one top-level directory, and are now branched and tagged together. Updating the vendor area to match this layout is next. --- .../lldb/source/Target/ThreadCollection.cpp | 65 ++++++++++++++++++++++ 1 file changed, 65 insertions(+) create mode 100644 contrib/llvm-project/lldb/source/Target/ThreadCollection.cpp (limited to 'contrib/llvm-project/lldb/source/Target/ThreadCollection.cpp') diff --git a/contrib/llvm-project/lldb/source/Target/ThreadCollection.cpp b/contrib/llvm-project/lldb/source/Target/ThreadCollection.cpp new file mode 100644 index 000000000000..cf3c1e242999 --- /dev/null +++ b/contrib/llvm-project/lldb/source/Target/ThreadCollection.cpp @@ -0,0 +1,65 @@ +//===-- ThreadCollection.cpp ------------------------------------*- C++ -*-===// +// +// 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 + +#include +#include + +#include "lldb/Target/Thread.h" +#include "lldb/Target/ThreadCollection.h" + +using namespace lldb; +using namespace lldb_private; + +ThreadCollection::ThreadCollection() : m_threads(), m_mutex() {} + +ThreadCollection::ThreadCollection(collection threads) + : m_threads(threads), m_mutex() {} + +void ThreadCollection::AddThread(const ThreadSP &thread_sp) { + std::lock_guard guard(GetMutex()); + m_threads.push_back(thread_sp); +} + +void ThreadCollection::AddThreadSortedByIndexID(const ThreadSP &thread_sp) { + std::lock_guard guard(GetMutex()); + // Make sure we always keep the threads sorted by thread index ID + const uint32_t thread_index_id = thread_sp->GetIndexID(); + if (m_threads.empty() || m_threads.back()->GetIndexID() < thread_index_id) + m_threads.push_back(thread_sp); + else { + m_threads.insert( + std::upper_bound(m_threads.begin(), m_threads.end(), thread_sp, + [](const ThreadSP &lhs, const ThreadSP &rhs) -> bool { + return lhs->GetIndexID() < rhs->GetIndexID(); + }), + thread_sp); + } +} + +void ThreadCollection::InsertThread(const lldb::ThreadSP &thread_sp, + uint32_t idx) { + std::lock_guard guard(GetMutex()); + if (idx < m_threads.size()) + m_threads.insert(m_threads.begin() + idx, thread_sp); + else + m_threads.push_back(thread_sp); +} + +uint32_t ThreadCollection::GetSize() { + std::lock_guard guard(GetMutex()); + return m_threads.size(); +} + +ThreadSP ThreadCollection::GetThreadAtIndex(uint32_t idx) { + std::lock_guard guard(GetMutex()); + ThreadSP thread_sp; + if (idx < m_threads.size()) + thread_sp = m_threads[idx]; + return thread_sp; +} -- cgit v1.2.3