mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2025-04-25 14:05:15 +00:00
C++20 can automatically synthesize `operator!=` from `operator==`, so there is no point in writing such functions by hand if all they do is call through to `operator==`. This fixes a compile error with compilers that implement P2468 (Clang 16 currently). This paper restores the C++17 behavior that if both `T::operator==(U)` and `T::operator!=(U)` exist, `U == T` won't be rewritten in reverse to call `T::operator==(U)`. Removing `!=` operators makes the rewriting possible again. See https://reviews.llvm.org/D134529#3853062
80 lines
2.1 KiB
C++
80 lines
2.1 KiB
C++
/*
|
|
* Copyright (c) 2018-2021, Andreas Kling <kling@serenityos.org>
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include <AK/Format.h>
|
|
#include <AK/Traits.h>
|
|
#include <LibGUI/Forward.h>
|
|
#include <LibGUI/ModelRole.h>
|
|
|
|
namespace GUI {
|
|
|
|
class ModelIndex {
|
|
friend class Model;
|
|
|
|
public:
|
|
ModelIndex() = default;
|
|
|
|
bool is_valid() const { return m_model && m_row != -1 && m_column != -1; }
|
|
int row() const { return m_row; }
|
|
int column() const { return m_column; }
|
|
|
|
void* internal_data() const { return m_internal_data; }
|
|
|
|
ModelIndex parent() const;
|
|
bool is_parent_of(ModelIndex const&) const;
|
|
|
|
bool operator==(ModelIndex const& other) const
|
|
{
|
|
return m_model == other.m_model && m_row == other.m_row && m_column == other.m_column && m_internal_data == other.m_internal_data;
|
|
}
|
|
|
|
Model const* model() const { return m_model; }
|
|
|
|
Variant data(ModelRole = ModelRole::Display) const;
|
|
|
|
ModelIndex sibling(int row, int column) const;
|
|
ModelIndex sibling_at_column(int column) const;
|
|
|
|
private:
|
|
ModelIndex(Model const& model, int row, int column, void* internal_data)
|
|
: m_model(&model)
|
|
, m_row(row)
|
|
, m_column(column)
|
|
, m_internal_data(internal_data)
|
|
{
|
|
}
|
|
|
|
Model const* m_model { nullptr };
|
|
int m_row { -1 };
|
|
int m_column { -1 };
|
|
void* m_internal_data { nullptr };
|
|
};
|
|
|
|
}
|
|
|
|
namespace AK {
|
|
|
|
template<>
|
|
struct Formatter<GUI::ModelIndex> : Formatter<FormatString> {
|
|
ErrorOr<void> format(FormatBuilder& builder, GUI::ModelIndex const& value)
|
|
{
|
|
if (value.internal_data())
|
|
return Formatter<FormatString>::format(builder, "ModelIndex({},{},{})"sv, value.row(), value.column(), value.internal_data());
|
|
return Formatter<FormatString>::format(builder, "ModelIndex({},{})"sv, value.row(), value.column());
|
|
}
|
|
};
|
|
|
|
template<>
|
|
struct Traits<GUI::ModelIndex> : public GenericTraits<GUI::ModelIndex> {
|
|
static unsigned hash(const GUI::ModelIndex& index)
|
|
{
|
|
return pair_int_hash(pair_int_hash(index.row(), index.column()), reinterpret_cast<FlatPtr>(index.internal_data()));
|
|
}
|
|
};
|
|
|
|
}
|