Net Inspector: clear sort ordering during rebuild

Fixes https://gitlab.com/kicad/code/kicad/-/issues/14697
This commit is contained in:
Jon Evans 2023-06-09 09:06:11 -04:00
parent 4e6092a280
commit 3a2cc8f56f
1 changed files with 22 additions and 1 deletions

View File

@ -110,6 +110,7 @@ public:
LIST_ITEM( NETINFO_ITEM* aNet ) : LIST_ITEM( NETINFO_ITEM* aNet ) :
m_net( aNet ) m_net( aNet )
{ {
wxASSERT( aNet );
m_net_name = UnescapeString( aNet->GetNetname() ); m_net_name = UnescapeString( aNet->GetNetname() );
m_column_changed.resize( COLUMN_NUM_STATIC_COL + MAX_CU_LAYERS, 0 ); m_column_changed.resize( COLUMN_NUM_STATIC_COL + MAX_CU_LAYERS, 0 );
} }
@ -809,8 +810,11 @@ protected:
else if( aCol == COLUMN_TOTAL_LENGTH ) else if( aCol == COLUMN_TOTAL_LENGTH )
aOutValue = m_parent.formatLength( i->GetTotalLength() ); aOutValue = m_parent.formatLength( i->GetTotalLength() );
else if( aCol > COLUMN_NUM_STATIC_COL ) else if( aCol > COLUMN_NUM_STATIC_COL && aCol <= m_parent.m_columns.size() )
aOutValue = m_parent.formatLength( i->GetLayerWireLength( m_parent.m_columns[aCol].layer ) ); aOutValue = m_parent.formatLength( i->GetLayerWireLength( m_parent.m_columns[aCol].layer ) );
else
aOutValue = "";
} }
} }
@ -1673,6 +1677,14 @@ void DIALOG_NET_INSPECTOR::buildNetsList()
prev_selected_netcodes.push_back( item->GetNetCode() ); prev_selected_netcodes.push_back( item->GetNetCode() );
} }
// At least on GTK, wxDVC will crash if you rebuild with a sorting column set.
if( wxDataViewColumn* sorting_column = m_netsList->GetSortingColumn() )
{
g_settings.sorting_column = static_cast<int>( sorting_column->GetModelColumn() ) ;
g_settings.sort_order_asc = sorting_column->IsSortOrderAscending();
sorting_column->UnsetAsSortKey();
}
m_data_model->deleteAllItems(); m_data_model->deleteAllItems();
std::vector<std::unique_ptr<LIST_ITEM>> new_items; std::vector<std::unique_ptr<LIST_ITEM>> new_items;
@ -1753,6 +1765,15 @@ void DIALOG_NET_INSPECTOR::buildNetsList()
m_data_model->addItems( std::move( new_items ) ); m_data_model->addItems( std::move( new_items ) );
if( g_settings.sorting_column != -1 )
{
if( wxDataViewColumn* c = m_netsList->GetColumn( g_settings.sorting_column ) )
{
c->SetSortOrder( g_settings.sort_order_asc );
m_data_model->Resort();
}
}
// try to restore the selected rows. set the ones that we can't find anymore to -1. // try to restore the selected rows. set the ones that we can't find anymore to -1.
sel.Clear(); sel.Clear();