Allow duplicating a zone onto the same layer in a GAL canvas.
Duplicate already works, so there's little reason to disallow using the zone dialog to do it. The legacy canvas can't be fixed because we'll immediately union the two zones, resulting in a no-op. Fixes: lp:1464677 * https://bugs.launchpad.net/kicad/+bug/1464677
This commit is contained in:
parent
ae711d9994
commit
c8a784058e
|
@ -796,30 +796,17 @@ int PCB_EDITOR_CONTROL::ZoneDuplicate( const TOOL_EVENT& aEvent )
|
||||||
else
|
else
|
||||||
success = InvokeNonCopperZonesEditor( m_frame, oldZone, &zoneSettings );
|
success = InvokeNonCopperZonesEditor( m_frame, oldZone, &zoneSettings );
|
||||||
|
|
||||||
// If the new zone is on the same layer as the the initial zone,
|
|
||||||
// do nothing
|
|
||||||
if( success )
|
|
||||||
{
|
|
||||||
if( oldZone->GetIsKeepout() && ( oldZone->GetLayerSet() == zoneSettings.m_Layers ) )
|
|
||||||
{
|
|
||||||
DisplayError(
|
|
||||||
m_frame, _( "The duplicated keepout zone cannot be on the same layers as the original zone." ) );
|
|
||||||
success = false;
|
|
||||||
}
|
|
||||||
else if( !oldZone->GetIsKeepout() && ( oldZone->GetLayer() == zoneSettings.m_CurrentZone_Layer ) )
|
|
||||||
{
|
|
||||||
DisplayError(
|
|
||||||
m_frame, _( "The duplicated zone cannot be on the same layer as the original zone." ) );
|
|
||||||
success = false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// duplicate the zone
|
// duplicate the zone
|
||||||
if( success )
|
if( success )
|
||||||
{
|
{
|
||||||
BOARD_COMMIT commit( m_frame );
|
BOARD_COMMIT commit( m_frame );
|
||||||
zoneSettings.ExportSetting( *newZone );
|
zoneSettings.ExportSetting( *newZone );
|
||||||
|
|
||||||
|
// If the new zone is on the same layer(s) as the the initial zone,
|
||||||
|
// offset it a bit so it can more easily be picked.
|
||||||
|
if( oldZone->GetLayerSet() == zoneSettings.m_Layers )
|
||||||
|
newZone->Move( wxPoint( IU_PER_MM, IU_PER_MM ) );
|
||||||
|
|
||||||
commit.Add( newZone.release() );
|
commit.Add( newZone.release() );
|
||||||
commit.Push( _( "Duplicate zone" ) );
|
commit.Push( _( "Duplicate zone" ) );
|
||||||
}
|
}
|
||||||
|
|
|
@ -129,8 +129,8 @@ void PCB_EDIT_FRAME::duplicateZone( wxDC* aDC, ZONE_CONTAINER* aZone )
|
||||||
else
|
else
|
||||||
success = InvokeNonCopperZonesEditor( this, aZone, &zoneSettings );
|
success = InvokeNonCopperZonesEditor( this, aZone, &zoneSettings );
|
||||||
|
|
||||||
// If the new zone is on the same layer as the the initial zone,
|
// If the new zone is on the same layer as the the initial zone we'll end up combining
|
||||||
// do nothing
|
// them which will result in a no-op. Might as well exit here.
|
||||||
if( success )
|
if( success )
|
||||||
{
|
{
|
||||||
if( aZone->GetIsKeepout() && ( aZone->GetLayerSet() == zoneSettings.m_Layers ) )
|
if( aZone->GetIsKeepout() && ( aZone->GetLayerSet() == zoneSettings.m_Layers ) )
|
||||||
|
|
Loading…
Reference in New Issue