mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2024-11-11 09:18:05 +03:00
d6d7d11590
This patch adds a (spinlock-protected) custody cache. It's a simple intrusive list containing all currently live custody objects. This allows us to re-use existing custodies instead of creating them again and again. This gives a pretty decent performance improvement on "find /" :^)
57 lines
1.5 KiB
C++
57 lines
1.5 KiB
C++
/*
|
|
* Copyright (c) 2018-2020, Andreas Kling <kling@serenityos.org>
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include <AK/IntrusiveList.h>
|
|
#include <AK/RefCounted.h>
|
|
#include <AK/RefPtr.h>
|
|
#include <AK/String.h>
|
|
#include <Kernel/Forward.h>
|
|
#include <Kernel/Heap/SlabAllocator.h>
|
|
#include <Kernel/KResult.h>
|
|
#include <Kernel/KString.h>
|
|
|
|
namespace Kernel {
|
|
|
|
// FIXME: Custody needs some locking.
|
|
|
|
class Custody : public RefCountedBase {
|
|
MAKE_SLAB_ALLOCATED(Custody)
|
|
public:
|
|
bool unref() const;
|
|
|
|
static KResultOr<NonnullRefPtr<Custody>> try_create(Custody* parent, StringView name, Inode&, int mount_flags);
|
|
|
|
~Custody();
|
|
|
|
Custody* parent() { return m_parent.ptr(); }
|
|
Custody const* parent() const { return m_parent.ptr(); }
|
|
Inode& inode() { return *m_inode; }
|
|
Inode const& inode() const { return *m_inode; }
|
|
StringView name() const { return m_name->view(); }
|
|
OwnPtr<KString> try_create_absolute_path() const;
|
|
String absolute_path() const;
|
|
|
|
int mount_flags() const { return m_mount_flags; }
|
|
bool is_readonly() const;
|
|
|
|
private:
|
|
Custody(Custody* parent, NonnullOwnPtr<KString> name, Inode&, int mount_flags);
|
|
|
|
RefPtr<Custody> m_parent;
|
|
NonnullOwnPtr<KString> m_name;
|
|
NonnullRefPtr<Inode> m_inode;
|
|
int m_mount_flags { 0 };
|
|
|
|
mutable IntrusiveListNode<Custody> m_all_custodies_list_node;
|
|
|
|
public:
|
|
using AllCustodiesList = IntrusiveList<Custody, RawPtr<Custody>, &Custody::m_all_custodies_list_node>;
|
|
};
|
|
|
|
}
|