46#include <wx/filedlg.h>
48#include <wx/wupdlock.h>
142 listItem.SetText( str );
143 listItem.SetData( code );
155 { wxID_CANCEL,
_(
"Close" ) } } );
191 g_lastIgnored.push_back( { m_ignoredList->GetItemText( ii ), m_ignoredList->GetItemData( ii ) } );
212 SetReturnCode( wxID_CANCEL );
229 int newValue =
KiROUND( cur * 1000.0 );
243 Pgm().
App().SafeYieldFor(
this, wxEVT_CATEGORY_NATIVE_EVENTS );
280 menu.Append( 4205,
_(
"Report All Errors for Each Track" ),
281 _(
"If unchecked, only the first error will be reported for each track" ),
285 menu.AppendSeparator();
287 menu.Append( 4206,
_(
"Cross-probe Selected Items" ),
288 _(
"Highlight corresponding items on canvas when selected in the DRC list" ),
292 menu.Append( 4207,
_(
"Center on Cross-probe" ),
293 _(
"When cross-probing, scroll the canvas so that the item is visible" ),
298 int menu_id =
m_bMenu->GetPopupMenuSelectionFromUser( menu );
300 if( menu_id == 0 || menu_id == 4205 )
304 else if( menu_id == 2 || menu_id == 4206 )
308 else if( menu_id == 3 || menu_id == 4207 )
317 m_frame->ShowBoardSetupDialog(
_(
"Custom Rules" ),
this );
323 if(
int hotkey = aEvt.GetKeyCode() )
325 if( aEvt.ControlDown() )
327 if( aEvt.ShiftDown() )
351 if( zoneFillerTool->IsBusy() )
371 m_messages->Report(
_(
"DRC incomplete: could not compile custom design rules." )
372 + wxS(
" " )
373 + wxS(
"<a href='$CUSTOM_RULES'>" ) +
_(
"Show design rules." ) + wxT(
"</a>" ) );
386 m_frame->GetBoard()->RecordDRCExclusions();
392 for( std::reference_wrapper<RC_ITEM>& item : violations )
398 listItem.SetText( wxT(
" • " ) + item.get().GetErrorText(
true ) );
399 listItem.SetData( item.get().GetErrorCode() );
426 m_messages->Report(
_(
"-------- DRC canceled by user.<br><br>" ) );
483 auto getActiveLayers =
491 for(
int layer : aItem->GetLayerSet() )
493 if(
pad->FlashLayer( layer ) )
501 return aItem->GetLayerSet();
513 std::shared_ptr<RC_ITEM> rc_item = node->
m_RcItem;
535 LSET violationLayers;
561 if( a || b || c || d )
572 LSET layersList = getActiveLayers( it );
573 violationLayers &= layersList;
576 principalLayer = layersList.
Seq().front();
580 if( violationLayers.count() )
581 principalLayer = violationLayers.
Seq().front();
582 else if( principalLayer >= 0 )
583 violationLayers.
set( principalLayer );
588 m_frame->GetAppearancePanel()->SetLayerVisible( principalLayer,
true );
591 m_frame->SetActiveLayer( principalLayer );
595 if( !
m_frame->GetPcbNewSettings()->m_Display.m_ShowGlobalRatsnest )
602 m_frame->GetBoard()->GetConnectivity()->RunOnUnconnectedEdges(
618 if( item == a && item == b )
646 std::vector<BOARD_ITEM*> items;
654 for(
const KIID&
id : rc_item->GetIDs() )
658 if( candidate && candidate->GetNetCode() == net )
659 items.push_back( candidate );
664 items.push_back( item );
680 if( aEvent.GetItem().IsOk() )
702 std::shared_ptr<RC_ITEM> rcItem = node->m_RcItem;
704 std::shared_ptr<CONNECTIVITY_DATA> conn =
m_currentBoard->GetConnectivity();
708 switch(
bds().m_DRCSeverities[ rcItem->GetErrorCode() ] )
712 default: listName =
_(
"appropriate" );
break;
717 ID_EDIT_EXCLUSION_COMMENT = 4467,
719 ID_REMOVE_EXCLUSION_ALL,
721 ID_ADD_EXCLUSION_WITH_COMMENT,
722 ID_ADD_EXCLUSION_ALL,
723 ID_INSPECT_VIOLATION,
725 ID_SET_SEVERITY_TO_ERROR,
726 ID_SET_SEVERITY_TO_WARNING,
727 ID_SET_SEVERITY_TO_IGNORE,
731 if( rcItem->GetParent()->IsExcluded() )
733 menu.Append( ID_REMOVE_EXCLUSION,
734 _(
"Remove exclusion for this violation" ),
735 wxString::Format(
_(
"It will be placed back in the %s list" ), listName ) );
737 menu.Append( ID_EDIT_EXCLUSION_COMMENT,
738 _(
"Edit exclusion comment..." ) );
742 menu.Append( ID_REMOVE_EXCLUSION_ALL,
743 wxString::Format(
_(
"Remove all exclusions for violations of rule '%s'" ),
745 wxString::Format(
_(
"They will be placed back in the %s list" ), listName ) );
750 menu.Append( ID_ADD_EXCLUSION,
751 _(
"Exclude this violation" ),
752 wxString::Format(
_(
"It will be excluded from the %s list" ), listName ) );
754 menu.Append( ID_ADD_EXCLUSION_WITH_COMMENT,
755 _(
"Exclude with comment..." ),
756 wxString::Format(
_(
"It will be excluded from the %s list" ), listName ) );
760 menu.Append( ID_ADD_EXCLUSION_ALL,
761 wxString::Format(
_(
"Exclude all violations of rule '%s'..." ),
763 wxString::Format(
_(
"They will be excluded from the %s list" ), listName ) );
767 menu.AppendSeparator();
770 wxString fixDRCErrorMenuText = drcTool->FixDRCErrorMenuText( rcItem );
772 if( !inspectDRCErrorMenuText.IsEmpty() || !fixDRCErrorMenuText.IsEmpty() )
774 if( !inspectDRCErrorMenuText.IsEmpty() )
775 menu.Append( ID_INSPECT_VIOLATION, inspectDRCErrorMenuText );
777 if( !fixDRCErrorMenuText.IsEmpty() )
778 menu.Append( ID_FIX_VIOLATION, fixDRCErrorMenuText );
780 menu.AppendSeparator();
785 menu.Append( ID_SET_SEVERITY_TO_ERROR,
786 wxString::Format(
_(
"Change severity to Error for all '%s' violations" ),
787 rcItem->GetErrorText(
true ) ),
788 _(
"Violation severities can also be edited in the Board Setup... dialog" ) );
792 menu.Append( ID_SET_SEVERITY_TO_WARNING,
793 wxString::Format(
_(
"Change severity to Warning for all '%s' violations" ),
794 rcItem->GetErrorText(
true ) ),
795 _(
"Violation severities can also be edited in the Board Setup... dialog" ) );
798 menu.Append( ID_SET_SEVERITY_TO_IGNORE,
799 wxString::Format(
_(
"Ignore all '%s' violations" ), rcItem->GetErrorText(
true ) ),
800 _(
"Violations will not be checked or reported" ) );
802 menu.AppendSeparator();
804 menu.Append( ID_EDIT_SEVERITIES,
805 _(
"Edit violation severities..." ),
806 _(
"Open the Board Setup... dialog" ) );
808 bool modified =
false;
809 int command = GetPopupMenuSelectionFromUser( menu );
813 case ID_EDIT_EXCLUSION_COMMENT:
816 WX_TEXT_ENTRY_DIALOG dlg(
this, wxEmptyString,
_(
"Exclusion Comment" ), marker->GetComment(),
true );
821 marker->SetExcluded(
true, dlg.
GetValue() );
823 wxString serialized = marker->SerializeToString();
834 case ID_REMOVE_EXCLUSION:
837 marker->SetExcluded(
false );
839 wxString serialized = marker->SerializeToString();
845 m_frame->GetBoard()->UpdateRatsnestExclusions();
846 m_frame->GetCanvas()->RedrawRatsnest();
850 m_frame->GetCanvas()->GetView()->Update( marker );
860 case ID_ADD_EXCLUSION:
861 case ID_ADD_EXCLUSION_WITH_COMMENT:
866 if( command == ID_ADD_EXCLUSION_WITH_COMMENT )
876 marker->SetExcluded(
true, comment );
878 wxString serialized = marker->SerializeToString();
884 m_frame->GetBoard()->UpdateRatsnestExclusions();
885 m_frame->GetCanvas()->RedrawRatsnest();
889 m_frame->GetCanvas()->GetView()->Update( marker );
903 case ID_REMOVE_EXCLUSION_ALL:
906 DRC_ITEM* candidateDrcItem =
static_cast<DRC_ITEM*
>( marker->GetRCItem().get() );
910 marker->SetExcluded(
false );
912 wxString serialized = marker->SerializeToString();
923 case ID_ADD_EXCLUSION_ALL:
926 DRC_ITEM* candidateDrcItem =
static_cast<DRC_ITEM*
>( marker->GetRCItem().get() );
930 marker->SetExcluded(
true );
932 wxString serialized = marker->SerializeToString();
942 case ID_INSPECT_VIOLATION:
946 case ID_FIX_VIOLATION:
947 drcTool->FixDRCError( node->m_RcItem );
950 case ID_SET_SEVERITY_TO_ERROR:
955 if( marker->GetRCItem()->GetErrorCode() == rcItem->GetErrorCode() )
956 m_frame->GetCanvas()->GetView()->Update( marker );
964 case ID_SET_SEVERITY_TO_WARNING:
969 if( marker->GetRCItem()->GetErrorCode() == rcItem->GetErrorCode() )
970 m_frame->GetCanvas()->GetView()->Update( marker );
978 case ID_SET_SEVERITY_TO_IGNORE:
984 listItem.SetText( wxT(
" • " ) + rcItem->GetErrorText(
true ) );
985 listItem.SetData( rcItem->GetErrorCode() );
991 std::vector<BOARD_ITEM*> toRemove;
995 if( marker->GetRCItem()->GetErrorCode() == rcItem->GetErrorCode() )
997 m_frame->GetCanvas()->GetView()->Remove( marker );
998 toRemove.emplace_back( marker );
1008 m_frame->GetCanvas()->RedrawRatsnest();
1016 case ID_EDIT_SEVERITIES:
1017 m_frame->ShowBoardSetupDialog(
_(
"Violation Severity" ),
this );
1032 int errorCode = (int) event.m_item.GetData();
1039 menu.Check(
bds().GetSeverity( errorCode ),
true );
1041 int severity = GetPopupMenuSelectionFromUser( menu );
1045 if(
bds().m_DRCSeverities[ errorCode ] != severity )
1059 m_frame->ShowBoardSetupDialog(
_(
"Violation Severity" ),
this );
1065 if( aEvent.GetEventObject() ==
m_showAll )
1080 wxFileDialog dlg(
this,
_(
"Save Report File" ),
Prj().GetProjectPath(), fn.GetFullName(),
1082 wxFD_SAVE | wxFD_OVERWRITE_PROMPT );
1086 if( dlg.ShowModal() != wxID_OK )
1091 if( fn.GetExt().IsEmpty() )
1094 if( !fn.IsAbsolute() )
1097 fn.MakeAbsolute( prj_path );
1103 bool success =
false;
1110 m_messages->Report( wxString::Format(
_(
"Report file '%s' created<br>" ), fn.GetFullPath() ) );
1112 DisplayError(
this, wxString::Format(
_(
"Failed to create file '%s'." ), fn.GetFullPath() ) );
1118 wxCommandEvent
dummy;
1133 SetReturnCode( wxID_CANCEL );
1156 m_frame->GetCanvas()->Refresh();
1227 m_frame->GetCanvas()->GetView()->Update( marker );
1253 m_frame->GetBoard()->DeleteMARKERs(
true, aIncludeExclusions );
1285 static bool s_includeExclusions =
false;
1287 int numExcluded = 0;
1298 if( numExcluded > 0 )
1300 wxMessageDialog dlg(
this,
_(
"Delete exclusions too?" ),
_(
"Delete All Markers" ),
1301 wxYES_NO | wxCANCEL | wxCENTER | wxICON_QUESTION );
1302 dlg.SetYesNoLabels(
_(
"Errors and Warnings Only" ),
1303 _(
"Errors, Warnings and Exclusions" ) );
1305 int ret = dlg.ShowModal();
1307 if( ret == wxID_CANCEL )
1309 else if( ret == wxID_NO )
1310 s_includeExclusions =
true;
1329 int numUnconnected = 0;
1330 int numFootprints = 0;
1333 int numWarnings = 0;
1334 int numExcluded = 0;
1360 bool errorsOverflowed =
false;
1361 bool warningsOverflowed =
false;
1362 bool markersOverflowed =
false;
1363 bool unconnectedOverflowed =
false;
1364 bool footprintsOverflowed =
false;
1370 if( drcEngine->IsErrorLimitExceeded( ii ) )
1373 errorsOverflowed =
true;
1375 warningsOverflowed =
true;
1380 unconnectedOverflowed =
true;
1382 unconnectedOverflowed =
true;
1393 footprintsOverflowed =
true;
1395 footprintsOverflowed =
true;
1400 markersOverflowed =
true;
1402 markersOverflowed =
true;
1414 num.Printf( markersOverflowed ? wxT(
"%d+" ) : wxT(
"%d" ), numMarkers );
1420 msg.Replace( wxT(
"(%s)" ), wxEmptyString );
1427 num.Printf( unconnectedOverflowed ? wxT(
"%d+" ) : wxT(
"%d" ), numUnconnected );
1433 msg.Replace( wxT(
"(%s)" ), wxEmptyString );
1440 num.Printf( footprintsOverflowed ? wxT(
"%d+" ) : wxT(
"%d" ), numFootprints );
1446 msg.Replace( wxT(
"%s" ),
_(
"not run" ) );
1451 msg.Replace( wxT(
"(%s)" ), wxEmptyString );
1464 msg.Replace( wxT(
"(%s)" ), wxEmptyString );
1474 if( !
m_drcRun && numWarnings == 0 )
KIFACE_BASE & Kiface()
Global KIFACE_BASE "get" accessor.
wxBitmapBundle KiBitmapBundle(BITMAPS aBitmap, int aMinHeight)
constexpr BOX2I KiROUND(const BOX2D &aBoxD)
static TOOL_ACTION excludeMarker
static TOOL_ACTION selectionClear
Clear the current selection.
BASE_SET & set(size_t pos)
A base class derived from BOARD_ITEM for items that can be connected and have a net,...
std::map< wxString, wxString > m_DrcExclusionComments
std::map< int, SEVERITY > m_DRCSeverities
std::set< wxString > m_DrcExclusions
SEVERITY GetSeverity(int aDRCErrorCode)
A base class for any item which can be embedded within the BOARD container class, and therefore insta...
Information pertinent to a Pcbnew printed circuit board.
const LSET & GetVisibleLayers() const
A proxy function that calls the correspondent function in m_BoardSettings.
const MARKERS & Markers() const
void FinalizeBulkRemove(std::vector< BOARD_ITEM * > &aRemovedItems)
Must be used if Remove() is used using a BULK_x REMOVE_MODE to generate a change event for listeners.
void Remove(BOARD_ITEM *aBoardItem, REMOVE_MODE aMode=REMOVE_MODE::NORMAL) override
Removes an item from the container.
BOARD_ITEM * ResolveItem(const KIID &aID, bool aAllowNullptrReturn=false) const
BOARD_CONNECTED_ITEM * Parent() const
CN_EDGE represents a point-to-point connection, whether realized or unrealized (ie: tracks etc.
std::shared_ptr< const CN_ANCHOR > GetSourceNode() const
std::shared_ptr< const CN_ANCHOR > GetTargetNode() const
const VECTOR2I GetTargetPos() const
const VECTOR2I GetSourcePos() const
wxCheckBox * m_cbRefillZones
wxBoxSizer * bSizerViolationsBox
wxButton * m_DeleteAllMarkersButton
wxCheckBox * m_showExclusions
wxCheckBox * m_showErrors
wxDataViewCtrl * m_unconnectedDataView
wxDataViewCtrl * m_footprintsDataView
NUMBER_BADGE * m_warningsBadge
NUMBER_BADGE * m_exclusionsBadge
wxSimplebook * m_runningResultsBook
wxButton * m_DeleteCurrentMarkerButton
STD_BITMAP_BUTTON * m_bMenu
wxButton * m_sdbSizerCancel
wxCheckBox * m_cbTestFootprints
DIALOG_DRC_BASE(wxWindow *parent, wxWindowID id=wxID_ANY, const wxString &title=_("Design Rules Checker"), const wxPoint &pos=wxDefaultPosition, const wxSize &size=wxSize(-1,-1), long style=wxDEFAULT_DIALOG_STYLE|wxRESIZE_BORDER)
wxCheckBox * m_showWarnings
wxListCtrl * m_ignoredList
NUMBER_BADGE * m_errorsBadge
WX_HTML_REPORT_BOX * m_messages
wxDataViewCtrl * m_markerDataView
void OnDRCItemSelected(wxDataViewEvent &aEvent) override
wxString m_footprintsTitleTemplate
void UpdateData()
Rebuild the contents of the violation tabs based on the current markers and severties.
std::shared_ptr< RC_ITEMS_PROVIDER > m_ratsnestProvider
wxString m_markersTitleTemplate
DIALOG_DRC(PCB_EDIT_FRAME *aEditorFrame, wxWindow *aParent)
Constructors.
void OnEditViolationSeverities(wxHyperlinkEvent &aEvent) override
void OnDeleteOneClick(wxCommandEvent &aEvent) override
RC_TREE_MODEL * m_fpWarningsTreeModel
void OnDeleteAllClick(wxCommandEvent &aEvent) override
void OnMenu(wxCommandEvent &aEvent) override
bool TransferDataToWindow() override
void OnErrorLinkClicked(wxHtmlLinkEvent &event) override
BOARD_DESIGN_SETTINGS & bds()
bool m_report_all_track_errors
void SelectMarker(const PCB_MARKER *aMarker)
void OnClose(wxCloseEvent &event) override
void OnCharHook(wxKeyEvent &aEvt) override
void OnDRCItemRClick(wxDataViewEvent &aEvent) override
void OnRunDRCClick(wxCommandEvent &aEvent) override
wxString m_ignoredTitleTemplate
void OnDRCItemDClick(wxDataViewEvent &aEvent) override
THROTTLE m_updateThrottle
void deleteAllMarkers(bool aIncludeExclusions)
void updateDisplayedCounts()
RC_TREE_MODEL * m_unconnectedTreeModel
bool m_scroll_on_crossprobe
wxString m_unconnectedTitleTemplate
std::shared_ptr< RC_ITEMS_PROVIDER > m_fpWarningsProvider
std::shared_ptr< RC_ITEMS_PROVIDER > m_markersProvider
void OnSeverity(wxCommandEvent &aEvent) override
void OnIgnoredItemRClick(wxListEvent &event) override
void OnCancelClick(wxCommandEvent &aEvent) override
void OnActivateDlg(wxActivateEvent &aEvent) override
void OnChangingNotebookPage(wxNotebookEvent &aEvent) override
void OnSaveReport(wxCommandEvent &aEvent) override
RC_TREE_MODEL * m_markersTreeModel
bool Show(bool show) override
void SetupStandardButtons(std::map< int, wxString > aLabels={})
void finishDialogSettings()
In all dialogs, we must call the same functions to fix minimal dlg size, the default position and per...
virtual void OnCharHook(wxKeyEvent &aEvt)
EDA_UNITS GetUserUnits() const
Design Rule Checker object that performs all the DRC tests.
void InitEngine(const wxFileName &aRulePath)
Initialize the DRC engine.
static std::vector< std::reference_wrapper< RC_ITEM > > GetItemsWithSeverities()
DRC_RULE * GetViolatingRule() const
bool WriteJsonReport(const wxString &aFullFileName)
bool WriteTextReport(const wxString &aFullFileName)
KICAD_T Type() const
Returns the type of object.
EDA_ITEM_FLAGS GetFlags() const
PROJECT & Prj() const
Return a reference to the PROJECT associated with this KIWAY.
LSET is a set of PCB_LAYER_IDs.
LSEQ Seq(const LSEQ &aSequence) const
Return an LSEQ from the union of this LSET and a desired sequence.
static const LSET & AllLayersMask()
const VECTOR2I & GetPos() const
void SetExcluded(bool aExcluded, const wxString &aComment=wxEmptyString)
enum MARKER_T GetMarkerType() const
static TOOL_ACTION showRatsnest
The main frame for Pcbnew.
SEVERITY GetSeverity() const override
wxString SerializeToString() const
virtual wxApp & App()
Return a bare naked wxApp which may come from wxPython, SINGLE_TOP, or kicad.exe.
virtual void AdvancePhase() override
Use the next available virtual zone of the dialog progress bar.
PROGRESS_REPORTER_BASE(int aNumPhases)
virtual void SetCurrentProgress(double aProgress) override
Set the progress value to aProgress (0..1).
std::atomic_bool m_cancelled
std::atomic_int m_progress
std::atomic_int m_maxProgress
virtual void AdvancePhase()=0
Use the next available virtual zone of the dialog progress bar.
virtual const wxString GetProjectPath() const
Return the full path of the project.
MARKER_BASE * GetParent() const
static RC_TREE_NODE * ToNode(wxDataViewItem aItem)
void ValueChanged(RC_TREE_NODE *aNode)
void Update(std::shared_ptr< RC_ITEMS_PROVIDER > aProvider, int aSeverities)
void DeleteCurrentItem(bool aDeep)
static KIID ToUUID(wxDataViewItem aItem)
std::shared_ptr< RC_ITEM > m_RcItem
A KICAD version of wxTextEntryDialog which supports the various improvements/work-arounds from DIALOG...
wxString GetValue() const
void DisplayError(wxWindow *aParent, const wxString &aText)
Display an error or warning message box with aMessage.
This file is part of the common library.
static BOARD * g_lastDRCBoard
static bool g_lastFootprintTestsRun
static std::vector< std::pair< wxString, int > > g_lastIgnored
#define DIALOG_DRC_WINDOW_NAME
@ DRCE_SCHEMATIC_FIELDS_PARITY
@ DRCE_DIFF_PAIR_UNCOUPLED_LENGTH_TOO_LONG
@ DRCE_MALFORMED_COURTYARD
@ DRCE_UNRESOLVED_VARIABLE
@ DRCE_DUPLICATE_FOOTPRINT
#define MALFORMED_F_COURTYARD
#define MALFORMED_B_COURTYARD
static int DEFAULT_SINGLE_COL_WIDTH
static const std::string ReportFileExtension
static const std::string JsonFileExtension
static wxString JsonFileWildcard()
static wxString ReportFileWildcard()
PCB_LAYER_ID
A quick note on layer IDs:
This file contains miscellaneous commonly used macros and functions.
PGM_BASE & Pgm()
The global program "get" accessor.
std::vector< FAB_LAYER_COLOR > dummy
A filename or source description, a problem input line, a line number, a byte offset,...
@ PCB_ZONE_T
class ZONE, a copper pour area
@ PCB_PAD_T
class PAD, a pad in a footprint
Functions to provide common constants and other functions to assist in making a consistent UI.
VECTOR2< int32_t > VECTOR2I
Definition of file extensions used in Kicad.