mirror of
				https://github.com/RGBCube/serenity
				synced 2025-10-31 17:22:43 +00:00 
			
		
		
		
	 4296425bd8
			
		
	
	
		4296425bd8
		
	
	
	
	
		
			
			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()));
 | |
|     }
 | |
| };
 | |
| 
 | |
| }
 |