mirror of
https://github.com/SerenityOS/serenity
synced 2024-11-05 17:46:52 +00:00
11eee67b85
Until now, our kernel has reimplemented a number of AK classes to provide automatic internal locking: - RefPtr - NonnullRefPtr - WeakPtr - Weakable This patch renames the Kernel classes so that they can coexist with the original AK classes: - RefPtr => LockRefPtr - NonnullRefPtr => NonnullLockRefPtr - WeakPtr => LockWeakPtr - Weakable => LockWeakable The goal here is to eventually get rid of the Lock* classes in favor of using external locking.
41 lines
819 B
C++
41 lines
819 B
C++
/*
|
|
* Copyright (c) 2021, Ali Mohammad Pur <mpfard@serenityos.org>
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include <AK/NonnullRefPtr.h>
|
|
|
|
#ifdef KERNEL
|
|
# include <Kernel/Library/LockRefPtr.h>
|
|
#endif
|
|
namespace AK::Detail {
|
|
|
|
template<typename T, typename Container>
|
|
struct SubstituteIntrusiveContainerType {
|
|
using Type = Container;
|
|
};
|
|
|
|
template<typename T>
|
|
struct SubstituteIntrusiveContainerType<T, NonnullRefPtr<T>> {
|
|
using Type = RefPtr<T>;
|
|
};
|
|
|
|
#ifdef KERNEL
|
|
template<typename T>
|
|
struct SubstituteIntrusiveContainerType<T, NonnullLockRefPtr<T>> {
|
|
using Type = LockRefPtr<T>;
|
|
};
|
|
#endif
|
|
|
|
template<typename Container, bool _IsRaw>
|
|
struct SelfReferenceIfNeeded {
|
|
Container reference = nullptr;
|
|
};
|
|
template<typename Container>
|
|
struct SelfReferenceIfNeeded<Container, true> {
|
|
};
|
|
|
|
}
|