From ce9adeaf5150cd30ebe7edfbcac94bfab60a7006 Mon Sep 17 00:00:00 2001 From: Jeff Young Date: Thu, 15 Sep 2022 18:35:26 +0100 Subject: [PATCH] Don't set FreeVia when we can't find a net. Fixes https://gitlab.com/kicad/code/kicad/issues/12421 --- pcbnew/tools/drawing_tool.cpp | 22 +++++++++++++--------- 1 file changed, 13 insertions(+), 9 deletions(-) diff --git a/pcbnew/tools/drawing_tool.cpp b/pcbnew/tools/drawing_tool.cpp index f1b4599832..28583c8495 100644 --- a/pcbnew/tools/drawing_tool.cpp +++ b/pcbnew/tools/drawing_tool.cpp @@ -3002,18 +3002,28 @@ int DRAWING_TOOL::DrawVia( const TOOL_EVENT& aEvent ) PAD* pad = findPad( via ); if( track ) + { via->SetNetCode( track->GetNetCode() ); + via->SetIsFree( false ); + } else if( pad ) + { via->SetNetCode( pad->GetNetCode() ); + via->SetIsFree( false ); + } else + { via->SetNetCode( findStitchedZoneNet( via ) ); + via->SetIsFree( via->GetNetCode() > 0 ); + } - if( !m_allowDRCViolations && checkDRCViolation( via ) ) + if( checkDRCViolation( via ) ) { m_frame->ShowInfoBarError( _( "Via location violates DRC." ), true, WX_INFOBAR::MESSAGE_TYPE::DRC_VIOLATION ); - via->SetNetCode( 0 ); - return false; + + if( !m_allowDRCViolations ) + return false; } else { @@ -3021,12 +3031,6 @@ int DRAWING_TOOL::DrawVia( const TOOL_EVENT& aEvent ) infobar->Dismiss(); } - if( !track && !pad ) - { - via->SetNetCode( findStitchedZoneNet( via ) ); - via->SetIsFree(); - } - aCommit.Add( via ); if( track )