Keep properties across an Exchange_Module call.
This is also used when saving a footprint from the Footprint Editor back to the board. Fixes https://gitlab.com/kicad/code/kicad/issues/5114 Fixes https://gitlab.com/kicad/code/kicad/issues/5114
This commit is contained in:
parent
4317881012
commit
3b280e4886
|
@ -523,6 +523,7 @@ void PCB_EDIT_FRAME::Exchange_Module( MODULE* aSrc, MODULE* aDest, BOARD_COMMIT&
|
||||||
|
|
||||||
// Updating other parameters
|
// Updating other parameters
|
||||||
const_cast<KIID&>( aDest->m_Uuid ) = aSrc->m_Uuid;
|
const_cast<KIID&>( aDest->m_Uuid ) = aSrc->m_Uuid;
|
||||||
|
aDest->SetProperties( aSrc->GetProperties() );
|
||||||
aDest->SetPath( aSrc->GetPath() );
|
aDest->SetPath( aSrc->GetPath() );
|
||||||
aDest->CalculateBoundingBox();
|
aDest->CalculateBoundingBox();
|
||||||
|
|
||||||
|
|
|
@ -517,7 +517,10 @@ void FOOTPRINT_EDIT_FRAME::OnCloseWindow( wxCloseEvent& aEvent )
|
||||||
wxString msg = _( "Save changes to \"%s\" before closing?" );
|
wxString msg = _( "Save changes to \"%s\" before closing?" );
|
||||||
|
|
||||||
if( !HandleUnsavedChanges( this, wxString::Format( msg, footprintName ),
|
if( !HandleUnsavedChanges( this, wxString::Format( msg, footprintName ),
|
||||||
[&]() -> bool { return SaveFootprint( GetBoard()->GetFirstModule() ); } ) )
|
[&]() -> bool
|
||||||
|
{
|
||||||
|
return SaveFootprint( GetBoard()->GetFirstModule() );
|
||||||
|
} ) )
|
||||||
{
|
{
|
||||||
aEvent.Veto();
|
aEvent.Veto();
|
||||||
return;
|
return;
|
||||||
|
|
|
@ -826,10 +826,8 @@ bool FOOTPRINT_EDIT_FRAME::SaveFootprintToBoard( bool aAddNew )
|
||||||
|
|
||||||
if( source_module ) // this is an update command
|
if( source_module ) // this is an update command
|
||||||
{
|
{
|
||||||
// In the main board,
|
// In the main board the new module replaces the old module (pos, orient, ref, value,
|
||||||
// the new module replace the old module (pos, orient, ref, value
|
// connections and properties are kept) and the source_module (old module) is deleted
|
||||||
// and connexions are kept)
|
|
||||||
// and the source_module (old module) is deleted
|
|
||||||
pcbframe->Exchange_Module( source_module, newmodule, commit );
|
pcbframe->Exchange_Module( source_module, newmodule, commit );
|
||||||
const_cast<KIID&>( newmodule->m_Uuid ) = module_in_edit->GetLink();
|
const_cast<KIID&>( newmodule->m_Uuid ) = module_in_edit->GetLink();
|
||||||
commit.Push( wxT( "Update module" ) );
|
commit.Push( wxT( "Update module" ) );
|
||||||
|
|
Loading…
Reference in New Issue