Pretty-print cross references in Symbol Fields Table.

Fixes https://gitlab.com/kicad/code/kicad/-/issues/19941

(cherry picked from commit f65d2609618c7d5c55ee69a770fbcd1cdbfa02e3)
This commit is contained in:
Jeff Young 2025-02-15 14:21:28 +00:00
parent f45e2b2252
commit b81f0b4377
3 changed files with 30 additions and 32 deletions

View File

@ -38,7 +38,6 @@
#include <sch_commit.h> #include <sch_commit.h>
#include <sch_edit_frame.h> #include <sch_edit_frame.h>
#include <sch_reference_list.h> #include <sch_reference_list.h>
#include <schematic.h>
#include <tools/sch_editor_control.h> #include <tools/sch_editor_control.h>
#include <kiplatform/ui.h> #include <kiplatform/ui.h>
#include <widgets/grid_text_button_helpers.h> #include <widgets/grid_text_button_helpers.h>
@ -630,13 +629,7 @@ bool DIALOG_SYMBOL_FIELDS_TABLE::TransferDataFromWindow()
SCH_COMMIT commit( m_parent ); SCH_COMMIT commit( m_parent );
SCH_SHEET_PATH currentSheet = m_parent->GetCurrentSheet(); SCH_SHEET_PATH currentSheet = m_parent->GetCurrentSheet();
std::function<void( SCH_SYMBOL&, SCH_SHEET_PATH & aPath )> changeHandler = m_dataModel->ApplyData( commit );
[&commit]( SCH_SYMBOL& aSymbol, SCH_SHEET_PATH& aPath ) -> void
{
commit.Modify( &aSymbol, aPath.LastScreen() );
};
m_dataModel->ApplyData( changeHandler );
commit.Push( wxS( "Symbol Fields Table Edit" ) ); commit.Push( wxS( "Symbol Fields Table Edit" ) );

View File

@ -23,7 +23,8 @@
#include <common.h> #include <common.h>
#include <widgets/wx_grid.h> #include <widgets/wx_grid.h>
#include <sch_reference_list.h> #include <sch_reference_list.h>
#include <schematic_settings.h> #include <sch_commit.h>
#include <sch_screen.h>
#include "string_utils.h" #include "string_utils.h"
#include "fields_data_model.h" #include "fields_data_model.h"
@ -60,9 +61,13 @@ void FIELDS_EDITOR_GRID_DATA_MODEL::updateDataStoreSymbolField( const SCH_SYMBOL
else if( const SCH_FIELD* field = aSymbol.GetFieldByName( aFieldName ) ) else if( const SCH_FIELD* field = aSymbol.GetFieldByName( aFieldName ) )
{ {
if( field->IsPrivate() ) if( field->IsPrivate() )
{
m_dataStore[aSymbol.m_Uuid][aFieldName] = wxEmptyString; m_dataStore[aSymbol.m_Uuid][aFieldName] = wxEmptyString;
else return;
m_dataStore[aSymbol.m_Uuid][aFieldName] = field->GetText(); }
wxString value = aSymbol.Schematic()->ConvertKIIDsToRefs( field->GetText() );
m_dataStore[aSymbol.m_Uuid][aFieldName] = value;
} }
else if( IsTextVar( aFieldName ) ) else if( IsTextVar( aFieldName ) )
{ {
@ -780,22 +785,18 @@ void FIELDS_EDITOR_GRID_DATA_MODEL::ExpandAfterSort()
} }
void FIELDS_EDITOR_GRID_DATA_MODEL::ApplyData( void FIELDS_EDITOR_GRID_DATA_MODEL::ApplyData( SCH_COMMIT& aCommit )
std::function<void( SCH_SYMBOL&, SCH_SHEET_PATH& )> symbolChangeHandler )
{ {
for( unsigned i = 0; i < m_symbolsList.GetCount(); ++i ) for( unsigned i = 0; i < m_symbolsList.GetCount(); ++i )
{ {
SCH_SYMBOL& symbol = *m_symbolsList[i].GetSymbol(); SCH_SYMBOL& symbol = *m_symbolsList[i].GetSymbol();
symbolChangeHandler( symbol, m_symbolsList[i].GetSheetPath() ); aCommit.Modify( &symbol, m_symbolsList[i].GetSheetPath().LastScreen() );
const std::map<wxString, wxString>& fieldStore = m_dataStore[symbol.m_Uuid]; const std::map<wxString, wxString>& fieldStore = m_dataStore[symbol.m_Uuid];
for( const std::pair<wxString, wxString> srcData : fieldStore ) for( const auto& [srcName, srcValue] : fieldStore )
{ {
const wxString& srcName = srcData.first;
const wxString& srcValue = srcData.second;
// Attributes bypass the field logic, so handle them first // Attributes bypass the field logic, so handle them first
if( isAttribute( srcName ) ) if( isAttribute( srcName ) )
{ {
@ -836,24 +837,19 @@ void FIELDS_EDITOR_GRID_DATA_MODEL::ApplyData(
if( destField->GetId() == REFERENCE_FIELD ) if( destField->GetId() == REFERENCE_FIELD )
{ {
// Reference is not editable from this dialog // Reference is not editable from this dialog
continue;
} }
else if( destField->GetId() == VALUE_FIELD ) else if( destField->GetId() == VALUE_FIELD )
{ {
// Value field cannot be empty // Value field cannot be empty
if( !srcValue.IsEmpty() ) if( srcValue.IsEmpty() )
symbol.SetValueFieldText( srcValue ); continue;
}
else if( destField->GetId() == FOOTPRINT_FIELD )
{
symbol.SetFootprintFieldText( srcValue );
}
else
{
destField->SetText( srcValue );
} }
destField->SetText( symbol.Schematic()->ConvertRefsToKIIDs( srcValue ) );
} }
for( int ii = symbol.GetFields().size() - 1; ii >= 0; ii-- ) for( int ii = (int) symbol.GetFields().size() - 1; ii >= 0; ii-- )
{ {
if( symbol.GetFields()[ii].IsMandatory() || symbol.GetFields()[ii].IsPrivate() ) if( symbol.GetFields()[ii].IsMandatory() || symbol.GetFields()[ii].IsPrivate() )
continue; continue;
@ -1001,8 +997,10 @@ wxString FIELDS_EDITOR_GRID_DATA_MODEL::Export( const BOM_FMT_PRESET& settings )
} }
if( !settings.stringDelimiter.IsEmpty() ) if( !settings.stringDelimiter.IsEmpty() )
{
field.Replace( settings.stringDelimiter, field.Replace( settings.stringDelimiter,
settings.stringDelimiter + settings.stringDelimiter ); settings.stringDelimiter + settings.stringDelimiter );
}
return settings.stringDelimiter + field + settings.stringDelimiter return settings.stringDelimiter + field + settings.stringDelimiter
+ ( last ? wxString( wxS( "\n" ) ) : settings.fieldDelimiter ); + ( last ? wxString( wxS( "\n" ) ) : settings.fieldDelimiter );
@ -1046,13 +1044,20 @@ void FIELDS_EDITOR_GRID_DATA_MODEL::AddReferences( const SCH_REFERENCE_LIST& aRe
{ {
if( !m_symbolsList.Contains( ref ) ) if( !m_symbolsList.Contains( ref ) )
{ {
SCH_SYMBOL* symbol = ref.GetSymbol();
m_symbolsList.AddItem( ref ); m_symbolsList.AddItem( ref );
// Update the fields of every reference // Update the fields of every reference
for( const SCH_FIELD& field : ref.GetSymbol()->GetFields() ) for( const SCH_FIELD& field : symbol->GetFields() )
{ {
if( !field.IsPrivate() ) if( !field.IsPrivate() )
m_dataStore[ref.GetSymbol()->m_Uuid][field.GetCanonicalName()] = field.GetText(); {
wxString name = field.GetCanonicalName();
wxString value = symbol->Schematic()->ConvertKIIDsToRefs( field.GetText() );
m_dataStore[symbol->m_Uuid][name] = value;
}
} }
} }
} }

View File

@ -216,7 +216,7 @@ public:
void CollapseForSort(); void CollapseForSort();
void ExpandAfterSort(); void ExpandAfterSort();
void ApplyData( std::function<void( SCH_SYMBOL&, SCH_SHEET_PATH& )> symbolChangeHandler ); void ApplyData( SCH_COMMIT& aCommit );
bool IsEdited() { return m_edited; } bool IsEdited() { return m_edited; }