From 5c1b15f8e35ee9753c38f8a70c48939eed59d575 Mon Sep 17 00:00:00 2001 From: Seth Hillbrand Date: Thu, 16 Feb 2023 12:56:19 -0800 Subject: [PATCH] Make LIB_TREE_NODE sort irreflexive std::sort requires explicit ordering of all elements. It does not allow for equality in its output --- common/lib_tree_model.cpp | 31 +++++++++++++++++++++---------- include/lib_tree_model.h | 5 ++--- 2 files changed, 23 insertions(+), 13 deletions(-) diff --git a/common/lib_tree_model.cpp b/common/lib_tree_model.cpp index b3e6e49b6a..1e79850620 100644 --- a/common/lib_tree_model.cpp +++ b/common/lib_tree_model.cpp @@ -92,7 +92,7 @@ void LIB_TREE_NODE::SortNodes() std::sort( m_Children.begin(), m_Children.end(), []( std::unique_ptr& a, std::unique_ptr& b ) { - return Compare( *a, *b ) > 0; + return Compare( *a, *b ); } ); for( std::unique_ptr& node: m_Children ) @@ -100,27 +100,38 @@ void LIB_TREE_NODE::SortNodes() } -int LIB_TREE_NODE::Compare( LIB_TREE_NODE const& aNode1, LIB_TREE_NODE const& aNode2 ) +bool LIB_TREE_NODE::Compare( LIB_TREE_NODE const& aNode1, LIB_TREE_NODE const& aNode2 ) { if( aNode1.m_Type != aNode2.m_Type ) - return 0; + return aNode1.m_Type < aNode2.m_Type; // Recently used sorts at top if( aNode1.m_Name.StartsWith( wxT( "-- " ) ) ) - return 1; + { + if( aNode2.m_Name.StartsWith( wxT( "-- " ) ) ) + { + return aNode1.m_IntrinsicRank > aNode2.m_IntrinsicRank; + } + else + { + return true; + } + } else if( aNode2.m_Name.StartsWith( wxT( "-- " ) ) ) - return 0; + { + return false; + } // Pinned nodes go next if( aNode1.m_Pinned && !aNode2.m_Pinned ) - return 1; + return true; else if( aNode2.m_Pinned && !aNode1.m_Pinned ) - return -1; + return false; - if( aNode1.m_Parent != aNode2.m_Parent ) - return 0; + if( aNode1.m_IntrinsicRank != aNode2.m_IntrinsicRank ) + return aNode1.m_IntrinsicRank > aNode2.m_IntrinsicRank; - return aNode1.m_IntrinsicRank - aNode2.m_IntrinsicRank; + return reinterpret_cast( &aNode1 ) < reinterpret_cast( &aNode2 ); } diff --git a/include/lib_tree_model.h b/include/lib_tree_model.h index fa9be1eff4..f8c7e1639b 100644 --- a/include/lib_tree_model.h +++ b/include/lib_tree_model.h @@ -101,10 +101,9 @@ public: void SortNodes(); /** - * Compare two nodes. Returns negative if aNode1 < aNode2, zero if aNode1 == - * aNode2, or positive if aNode1 > aNode2. + * Compare two nodes. Returns true if aNode1 < aNode2. */ - static int Compare( LIB_TREE_NODE const& aNode1, LIB_TREE_NODE const& aNode2 ); + static bool Compare( LIB_TREE_NODE const& aNode1, LIB_TREE_NODE const& aNode2 ); LIB_TREE_NODE(); virtual ~LIB_TREE_NODE() {}