Handle custom columns in symbol tree synchronizing adapter
Fixes https://gitlab.com/kicad/code/kicad/-/issues/13907
(cherry picked from commit 0913552f84
)
This commit is contained in:
parent
c213b37e96
commit
21081cf80f
|
@ -245,33 +245,35 @@ void SYMBOL_TREE_SYNCHRONIZING_ADAPTER::GetValue( wxVariant& aVariant, wxDataVie
|
||||||
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DESC_COL:
|
default:
|
||||||
if( m_frame->GetCurSymbol() && m_frame->GetCurSymbol()->GetLibId() == node->m_LibId )
|
if( m_colIdxMap.count( aCol ) )
|
||||||
{
|
{
|
||||||
node->m_Desc = m_frame->GetCurSymbol()->GetDescription();
|
if( node->m_Type == LIB_TREE_NODE::LIB )
|
||||||
}
|
|
||||||
else if( node->m_Type == LIB_TREE_NODE::LIB )
|
|
||||||
{
|
{
|
||||||
LIB_SYMBOL_LIBRARY_MANAGER& libMgr = m_frame->GetLibManager();
|
LIB_SYMBOL_LIBRARY_MANAGER& libMgr = m_frame->GetLibManager();
|
||||||
SYMBOL_LIB_TABLE_ROW* lib = libMgr.GetLibrary( node->m_LibId.GetLibNickname() );
|
SYMBOL_LIB_TABLE_ROW* lib = libMgr.GetLibrary( node->m_LibId.GetLibNickname() );
|
||||||
|
|
||||||
if( lib )
|
if( lib )
|
||||||
node->m_Desc = lib->GetDescr();
|
node->m_Desc = lib->GetDescr();
|
||||||
}
|
|
||||||
|
|
||||||
aVariant = node->m_Desc;
|
|
||||||
|
|
||||||
// Annotate that the library failed to load in the description column
|
|
||||||
if( node->m_Type == LIB_TREE_NODE::LIB )
|
|
||||||
{
|
|
||||||
if( !m_libMgr->IsLibraryLoaded( node->m_Name ) )
|
if( !m_libMgr->IsLibraryLoaded( node->m_Name ) )
|
||||||
aVariant = _( "(failed to load)" ) + wxS( " " ) + aVariant.GetString();
|
aVariant = _( "(failed to load)" ) + wxS( " " ) + aVariant.GetString();
|
||||||
}
|
}
|
||||||
|
|
||||||
break;
|
const wxString& key = m_colIdxMap.at( aCol );
|
||||||
|
|
||||||
default: // column == -1 is used for default Compare function
|
if( m_frame->GetCurSymbol() && m_frame->GetCurSymbol()->GetLibId() == node->m_LibId )
|
||||||
aVariant = node->m_Name;
|
{
|
||||||
|
node->m_Desc = m_frame->GetCurSymbol()->GetDescription();
|
||||||
|
}
|
||||||
|
|
||||||
|
if( node->m_Fields.count( key ) )
|
||||||
|
aVariant = node->m_Fields.at( key );
|
||||||
|
else if( key == wxT( "Description" ) )
|
||||||
|
aVariant = node->m_Desc;
|
||||||
|
else
|
||||||
|
aVariant = wxEmptyString;
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue