1
Fork 0
mirror of https://github.com/RGBCube/serenity synced 2025-10-26 07:22:06 +00:00
serenity/Userland/Libraries/LibGUI/PersistentModelIndex.h
sin-ack 3f3f45580a Everywhere: Add sv suffix to strings relying on StringView(char const*)
Each of these strings would previously rely on StringView's char const*
constructor overload, which would call __builtin_strlen on the string.
Since we now have operator ""sv, we can replace these with much simpler
versions. This opens the door to being able to remove
StringView(char const*).

No functional changes.
2022-07-12 23:11:35 +02:00

93 lines
2.6 KiB
C++

/*
* Copyright (c) 2021, sin-ack <sin-ack@protonmail.com>
* Copyright (c) 2022, the SerenityOS developers.
*
* SPDX-License-Identifier: BSD-2-Clause
*/
#pragma once
#include <AK/RefCounted.h>
#include <AK/WeakPtr.h>
#include <LibGUI/Model.h>
#include <LibGUI/ModelIndex.h>
namespace GUI {
/// A PersistentHandle is an internal data structure used to keep track of the
/// target of multiple PersistentModelIndex instances.
class PersistentHandle : public Weakable<PersistentHandle> {
friend Model;
friend PersistentModelIndex;
friend AK::Traits<GUI::PersistentModelIndex>;
PersistentHandle(ModelIndex const& index)
: m_index(index)
{
}
ModelIndex m_index;
};
class PersistentModelIndex {
public:
PersistentModelIndex() = default;
PersistentModelIndex(ModelIndex const&);
PersistentModelIndex(PersistentModelIndex const&) = default;
PersistentModelIndex(PersistentModelIndex&&) = default;
PersistentModelIndex& operator=(PersistentModelIndex const&) = default;
PersistentModelIndex& operator=(PersistentModelIndex&&) = default;
bool is_valid() const { return has_valid_handle() && m_handle->m_index.is_valid(); }
bool has_valid_handle() const { return !m_handle.is_null(); }
int row() const;
int column() const;
PersistentModelIndex parent() const;
PersistentModelIndex sibling_at_column(int column) const;
Variant data(ModelRole = ModelRole::Display) const;
void* internal_data() const
{
if (has_valid_handle())
return m_handle->m_index.internal_data();
else
return nullptr;
}
operator ModelIndex() const;
bool operator==(PersistentModelIndex const&) const;
bool operator!=(PersistentModelIndex const&) const;
bool operator==(ModelIndex const&) const;
bool operator!=(ModelIndex const&) const;
private:
friend AK::Traits<GUI::PersistentModelIndex>;
WeakPtr<PersistentHandle> m_handle;
};
}
namespace AK {
template<>
struct Formatter<GUI::PersistentModelIndex> : Formatter<FormatString> {
ErrorOr<void> format(FormatBuilder& builder, GUI::PersistentModelIndex const& value)
{
return Formatter<FormatString>::format(builder, "PersistentModelIndex({},{},{})"sv, value.row(), value.column(), value.internal_data());
}
};
template<>
struct Traits<GUI::PersistentModelIndex> : public GenericTraits<GUI::PersistentModelIndex> {
static unsigned hash(const GUI::PersistentModelIndex& index)
{
if (index.has_valid_handle())
return Traits<GUI::ModelIndex>::hash(index.m_handle->m_index);
return 0;
}
};
}