51#include <wx/filedlg.h>
52#include <wx/hyperlink.h>
109 listItem.SetText( str );
110 listItem.SetData( code );
119 { wxID_CANCEL,
_(
"Close" ) } } );
154 g_lastERCIgnored.push_back( { m_ignoredList->GetItemText( ii ), m_ignoredList->GetItemData( ii ) } );
176 wxHyperlinkCtrl* button =
new wxHyperlinkCtrl(
m_infoBar, wxID_ANY,
_(
"Show Annotation dialog" ),
179 button->Bind( wxEVT_COMMAND_HYPERLINK, std::function<
void( wxHyperlinkEvent& aEvent )>(
180 [&]( wxHyperlinkEvent& aEvent )
182 wxHtmlLinkEvent htmlEvent( aEvent.GetId(), wxHtmlLinkInfo( aEvent.GetURL() ) );
188 m_infoBar->ShowMessage(
_(
"Schematic is not fully annotated. ERC results will be incomplete." ) );
224 menu.Append( 4206,
_(
"Cross-probe Selected Items" ),
225 _(
"Highlight corresponding items on canvas when selected in the ERC list" ),
229 menu.Append( 4207,
_(
"Center on Cross-probe" ),
230 _(
"When cross-probing, scroll the canvas so that the item is visible" ),
234 menu.Append( 4208,
_(
"Show all errors" ),
235 _(
"Show duplicate ERC markers on all applicable pins" ),
240 int menu_id =
m_bMenu->GetPopupMenuSelectionFromUser( menu );
242 if( menu_id == 0 || menu_id == 4206 )
246 else if( menu_id == 1 || menu_id == 4207 )
250 else if( menu_id == 2 || menu_id == 4208 )
259 if(
int hotkey = aEvt.GetKeyCode() )
261 if( aEvt.ControlDown() )
263 if( aEvt.ShiftDown() )
337 bool markersOverflowed =
false;
346 num.Printf( markersOverflowed ? wxT(
"%d+" ) : wxT(
"%d" ), numMarkers );
352 msg.Replace( wxT(
"(%s)" ), wxEmptyString );
365 msg.Replace( wxT(
"(%s)" ), wxEmptyString );
401 bool includeExclusions =
false;
407 if( numExcluded > 0 )
409 wxMessageDialog dlg(
this,
_(
"Delete exclusions too?" ),
_(
"Delete All Markers" ),
410 wxYES_NO | wxCANCEL | wxCENTER | wxICON_QUESTION );
411 dlg.SetYesNoLabels(
_(
"Errors and Warnings Only" ),
412 _(
"Errors, Warnings and Exclusions" ) );
414 int ret = dlg.ShowModal();
416 if( ret == wxID_CANCEL )
418 else if( ret == wxID_NO )
419 includeExclusions =
true;
452 if( wxWindow* parent = GetParent() )
453 wxQueueEvent( parent,
new wxCommandEvent( EDA_EVT_CLOSE_ERC_DIALOG, wxID_ANY ) );
480 for( std::reference_wrapper<RC_ITEM>& item : violations )
486 listItem.SetText( wxT(
" • " ) + item.get().GetErrorText(
true ) );
487 listItem.SetData( item.get().GetErrorCode() );
509 int itemsNotAnnotated =
m_parent->CheckAnnotate(
513 ercItem->SetErrorMessage( aMsg );
518 ercItem->SetItems( aItemA->
GetSymbol() );
526 if( itemsNotAnnotated )
528 m_messages->ReportHead( wxString::Format(
_(
"%d symbol(s) require annotation.<br><br>" ),
600 m_parent->GetCanvas()->GetView()->Remove( marker );
601 m_parent->GetCanvas()->GetView()->Add( marker );
625 else if( item && item->
GetClass() != wxT(
"DELETED_SHEET_ITEM" ) )
632 std::shared_ptr<ERC_ITEM> ercItem = std::static_pointer_cast<ERC_ITEM>( node->
m_RcItem );
637 if( ercItem->IsSheetSpecific() )
638 sheet = ercItem->GetSpecificSheetPath();
641 if( ercItem->MainItemHasSheetPath() )
642 sheet = ercItem->GetMainItemSheetPath();
645 if( ercItem->AuxItemHasSheetPath() )
646 sheet = ercItem->GetAuxItemSheetPath();
671 if( aEvent.GetItem().IsOk() )
695 std::shared_ptr<RC_ITEM> rcItem = node->m_RcItem;
699 switch( settings.
GetSeverity( rcItem->GetErrorCode() ) )
703 default: listName =
_(
"appropriate" );
break;
708 ID_EDIT_EXCLUSION_COMMENT = 4467,
710 ID_REMOVE_EXCLUSION_ALL,
712 ID_ADD_EXCLUSION_WITH_COMMENT,
713 ID_ADD_EXCLUSION_ALL,
714 ID_INSPECT_VIOLATION,
716 ID_EDIT_PIN_CONFLICT_MAP,
717 ID_EDIT_CONNECTION_GRID,
718 ID_SET_SEVERITY_TO_ERROR,
719 ID_SET_SEVERITY_TO_WARNING,
720 ID_SET_SEVERITY_TO_IGNORE,
724 if( rcItem->GetParent()->IsExcluded() )
726 menu.Append( ID_REMOVE_EXCLUSION,
727 _(
"Remove exclusion for this violation" ),
728 wxString::Format(
_(
"It will be placed back in the %s list" ), listName ) );
730 menu.Append( ID_EDIT_EXCLUSION_COMMENT,
731 _(
"Edit exclusion comment..." ) );
735 menu.Append( ID_ADD_EXCLUSION,
736 _(
"Exclude this violation" ),
737 wxString::Format(
_(
"It will be excluded from the %s list" ), listName ) );
739 menu.Append( ID_ADD_EXCLUSION_WITH_COMMENT,
740 _(
"Exclude with comment..." ),
741 wxString::Format(
_(
"It will be excluded from the %s list" ), listName ) );
744 menu.AppendSeparator();
747 wxString fixERCErrorMenuText = editTool->FixERCErrorMenuText( rcItem );
749 if( !inspectERCErrorMenuText.IsEmpty() || !fixERCErrorMenuText.IsEmpty() )
751 if( !inspectERCErrorMenuText.IsEmpty() )
752 menu.Append( ID_INSPECT_VIOLATION, inspectERCErrorMenuText );
754 if( !fixERCErrorMenuText.IsEmpty() )
755 menu.Append( ID_FIX_VIOLATION, fixERCErrorMenuText );
757 menu.AppendSeparator();
767 menu.Append( ID_SET_SEVERITY_TO_ERROR,
768 wxString::Format(
_(
"Change severity to Error for all '%s' violations" ),
769 rcItem->GetErrorText(
true ) ),
770 _(
"Violation severities can also be edited in the Schematic Setup... dialog" ) );
774 menu.Append( ID_SET_SEVERITY_TO_WARNING,
775 wxString::Format(
_(
"Change severity to Warning for all '%s' violations" ),
776 rcItem->GetErrorText(
true ) ),
777 _(
"Violation severities can also be edited in the Schematic Setup... "
781 menu.Append( ID_SET_SEVERITY_TO_IGNORE,
782 wxString::Format(
_(
"Ignore all '%s' violations" ), rcItem->GetErrorText(
true ) ),
783 _(
"Violations will not be checked or reported" ) );
785 menu.AppendSeparator();
790 menu.Append( ID_EDIT_PIN_CONFLICT_MAP,
791 _(
"Edit pin-to-pin conflict map..." ),
792 _(
"Open the Schematic Setup... dialog" ) );
796 menu.Append( ID_EDIT_SEVERITIES,
797 _(
"Edit violation severities..." ),
798 _(
"Open the Schematic Setup... dialog" ) );
803 menu.Append( ID_EDIT_CONNECTION_GRID,
804 _(
"Edit connection grid spacing..." ),
805 _(
"Open the Schematic 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() );
830 case ID_REMOVE_EXCLUSION:
833 marker->SetExcluded(
false );
834 m_parent->GetCanvas()->GetView()->Update( marker );
843 case ID_ADD_EXCLUSION:
844 case ID_ADD_EXCLUSION_WITH_COMMENT:
849 if( command == ID_ADD_EXCLUSION_WITH_COMMENT )
859 marker->SetExcluded(
true, comment );
861 m_parent->GetCanvas()->GetView()->Update( marker );
874 case ID_INSPECT_VIOLATION:
878 case ID_FIX_VIOLATION:
879 editTool->FixERCError( node->m_RcItem );
882 case ID_SET_SEVERITY_TO_ERROR:
890 m_parent->GetCanvas()->GetView()->Update( marker );
898 case ID_SET_SEVERITY_TO_WARNING:
906 m_parent->GetCanvas()->GetView()->Update( marker );
914 case ID_SET_SEVERITY_TO_IGNORE:
923 listItem.SetText( wxT(
" • " ) + rcItem->GetErrorText(
true ) );
924 listItem.SetData( rcItem->GetErrorCode() );
941 case ID_EDIT_PIN_CONFLICT_MAP:
942 m_parent->ShowSchematicSetupDialog(
_(
"Pin Conflicts Map" ) );
945 case ID_EDIT_SEVERITIES:
946 m_parent->ShowSchematicSetupDialog(
_(
"Violation Severity" ) );
949 case ID_EDIT_CONNECTION_GRID:
950 m_parent->ShowSchematicSetupDialog(
_(
"Formatting" ) );
966 int errorCode = (int) event.m_item.GetData();
973 menu.Check( settings.
GetSeverity( errorCode ),
true );
975 int severity = GetPopupMenuSelectionFromUser( menu );
979 if( settings.
GetSeverity( errorCode ) != severity )
1045 if( marker !=
nullptr )
1056 if( node && marker && !marker->
IsExcluded() )
1059 m_parent->GetCanvas()->GetView()->Update( marker );
1076 m_parent->ShowSchematicSetupDialog(
_(
"Violation Severity" ) );
1082 if( aEvent.GetEventObject() ==
m_showAll )
1115 wxFileDialog dlg(
this,
_(
"Save Report File" ),
Prj().GetProjectPath(), fn.GetFullName(),
1117 wxFD_SAVE | wxFD_OVERWRITE_PROMPT );
1119 if( dlg.ShowModal() != wxID_OK )
1124 if( fn.GetExt().IsEmpty() )
1127 if( !fn.IsAbsolute() )
1130 fn.MakeAbsolute( prj_path );
1135 bool success =
false;
1142 m_messages->Report( wxString::Format(
_(
"Report file '%s' created." ), fn.GetFullPath() ) );
1144 DisplayErrorMessage(
this, wxString::Format(
_(
"Failed to create file '%s'." ), fn.GetFullPath() ) );
wxBitmapBundle KiBitmapBundle(BITMAPS aBitmap, int aMinHeight)
static TOOL_ACTION excludeMarker
static TOOL_ACTION selectionClear
Clear the current selection.
wxButton * m_sdbSizer1Cancel
wxSimplebook * m_runningResultsBook
wxCheckBox * m_showExclusions
NUMBER_BADGE * m_errorsBadge
STD_BITMAP_BUTTON * m_bMenu
wxCheckBox * m_showErrors
NUMBER_BADGE * m_exclusionsBadge
wxListCtrl * m_ignoredList
WX_HTML_REPORT_BOX * m_messages
wxDataViewCtrl * m_markerDataView
wxButton * m_deleteAllMarkers
NUMBER_BADGE * m_warningsBadge
wxButton * m_deleteOneMarker
wxCheckBox * m_showWarnings
DIALOG_ERC_BASE(wxWindow *parent, wxWindowID id=wxID_ANY, const wxString &title=_("Electrical Rules Checker"), const wxPoint &pos=wxDefaultPosition, const wxSize &size=wxSize(-1,-1), long style=wxDEFAULT_DIALOG_STYLE|wxRESIZE_BORDER)
void OnMenu(wxCommandEvent &aEvent) override
void ExcludeMarker(SCH_MARKER *aMarker=nullptr)
Exclude aMarker from the ERC list.
void OnIgnoredItemRClick(wxListEvent &aEvent) override
const SCH_MARKER * m_centerMarkerOnIdle
void OnERCItemDClick(wxDataViewEvent &aEvent) override
std::shared_ptr< RC_ITEMS_PROVIDER > m_markerProvider
bool TransferDataToWindow() override
DIALOG_ERC(SCH_EDIT_FRAME *parent)
bool m_scroll_on_crossprobe
void SelectMarker(const SCH_MARKER *aMarker)
SCH_EDIT_FRAME * m_parent
wxString m_violationsTitleTemplate
void OnERCItemRClick(wxDataViewEvent &aEvent) override
void centerMarkerIdleHandler(wxIdleEvent &aEvent)
void OnDeleteAllClick(wxCommandEvent &event) override
void OnLinkClicked(wxHtmlLinkEvent &event) override
void OnCharHook(wxKeyEvent &aEvt) override
void OnRunERCClick(wxCommandEvent &event) override
void deleteAllMarkers(bool aIncludeExclusions)
wxString m_ignoredTitleTemplate
void OnDeleteOneClick(wxCommandEvent &event) override
void OnSaveReport(wxCommandEvent &aEvent) override
SCHEMATIC * m_currentSchematic
void OnEditViolationSeverities(wxHyperlinkEvent &aEvent) override
void UpdateAnnotationWarning()
void Report(const wxString &aMessage) override
Display aMessage in the progress bar dialog.
void OnERCItemSelected(wxDataViewEvent &aEvent) override
RC_TREE_MODEL * m_markerTreeModel
void updateDisplayedCounts()
void OnSeverity(wxCommandEvent &aEvent) override
void OnCloseErcDialog(wxCloseEvent &event) override
void OnCancelClick(wxCommandEvent &event) override
bool Show(bool show) override
void SetupStandardButtons(std::map< int, wxString > aLabels={})
bool IsQuasiModal() const
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)
static std::shared_ptr< ERC_ITEM > Create(int aErrorCode)
Constructs an ERC_ITEM for the given error code.
static std::vector< std::reference_wrapper< RC_ITEM > > GetItemsWithSeverities()
bool WriteJsonReport(const wxString &aFullFileName)
Writes a JSON formatted ERC Report to the given file path in the c-locale.
bool WriteTextReport(const wxString &aFullFileName)
Writes the text report also available via GetTextReport directly to a given file path.
Container for ERC settings.
SEVERITY GetSeverity(int aErrorCode) const
void SetSeverity(int aErrorCode, SEVERITY aSeverity)
void RunTests(DS_PROXY_VIEW_ITEM *aDrawingSheet, SCH_EDIT_FRAME *aEditFrame, KIFACE *aCvPcb, PROJECT *aProject, PROGRESS_REPORTER *aProgressReporter)
A specialisation of the RC_TREE_MODEL class to enable ERC errors / warnings to be resolved in a speci...
PROJECT & Prj() const
Return a reference to the PROJECT associated with this KIWAY.
std::shared_ptr< RC_ITEM > GetRCItem() const
void SetExcluded(bool aExcluded, const wxString &aComment=wxEmptyString)
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
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
Holds all the data relating to one schematic.
void RecordERCExclusions()
Scan existing markers and record data from any that are Excluded.
ERC_SETTINGS & ErcSettings() const
static TOOL_ACTION changeSheet
Schematic editor (Eeschema) main window.
SCHEMATIC & Schematic() const
Base class for any item which can be embedded within the SCHEMATIC container class,...
wxString GetClass() const override
Return the class name.
A helper to define a symbol's reference designator in a schematic.
const SCH_SHEET_PATH & GetSheetPath() const
SCH_SYMBOL * GetSymbol() const
Container class that holds multiple SCH_SCREEN objects in a hierarchy.
void DeleteMarkers(enum MARKER_BASE::MARKER_T aMarkerTyp, int aErrorCode, bool aIncludeExclusions=true)
Delete all markers of a particular type and error code.
void DeleteAllMarkers(enum MARKER_BASE::MARKER_T aMarkerType, bool aIncludeExclusions)
Delete all electronic rules check markers of aMarkerType from all the screens in the list.
void Append(SCH_ITEM *aItem, bool aUpdateLibSymbol=true)
Handle access to a stack of flattened SCH_SHEET objects by way of a path for creating a flattened sch...
bool empty() const
Forwarded method from std::vector.
SCH_SCREEN * LastScreen()
VECTOR2I GetPosition() const override
A KICAD version of wxTextEntryDialog which supports the various improvements/work-arounds from DIALOG...
wxString GetValue() const
void DisplayErrorMessage(wxWindow *aParent, const wxString &aText, const wxString &aExtraInfo)
Display an error message with aMessage.
This file is part of the common library.
wxDEFINE_EVENT(EDA_EVT_CLOSE_ERC_DIALOG, wxCommandEvent)
static std::vector< std::pair< wxString, int > > g_lastERCIgnored
static SCHEMATIC * g_lastERCSchematic
#define DIALOG_ERC_WINDOW_NAME
static int DEFAULT_SINGLE_COL_WIDTH
@ ERCE_ENDPOINT_OFF_GRID
Pin or wire-end off grid.
@ ERCE_PIN_TO_PIN_WARNING
static const std::string ReportFileExtension
static const std::string JsonFileExtension
static wxString JsonFileWildcard()
static wxString ReportFileWildcard()
T * GetAppSettings(const char *aFilename)
std::vector< FAB_LAYER_COLOR > dummy
Definition of file extensions used in Kicad.