2013-05-26 04:36:44 +00:00
|
|
|
/*
|
|
|
|
* This program source code file is part of KiCad, a free EDA CAD application.
|
|
|
|
*
|
|
|
|
* Copyright (C) 2007 KiCad Developers, see change_log.txt for contributors.
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU General Public License
|
|
|
|
* as published by the Free Software Foundation; either version 2
|
|
|
|
* of the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program; if not, you may find one here:
|
|
|
|
* http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
|
|
|
|
* or you may search the http://www.gnu.org website for the version 2 license,
|
|
|
|
* or you may write to the Free Software Foundation, Inc.,
|
|
|
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
/******************************************************************/
|
|
|
|
/* class_drc_erc_item.cpp - DRC_ITEM class functions for eeschema */
|
|
|
|
/******************************************************************/
|
|
|
|
#include <fctsys.h>
|
|
|
|
#include <common.h>
|
|
|
|
|
2018-01-28 21:02:31 +00:00
|
|
|
#include <drc_item.h>
|
2013-05-26 04:36:44 +00:00
|
|
|
#include <erc.h>
|
|
|
|
#include <base_units.h>
|
|
|
|
|
|
|
|
wxString DRC_ITEM::GetErrorText() const
|
|
|
|
{
|
|
|
|
switch( m_ErrorCode )
|
|
|
|
{
|
|
|
|
case ERCE_UNSPECIFIED:
|
|
|
|
return wxString( _("ERC err unspecified") );
|
|
|
|
case ERCE_DUPLICATE_SHEET_NAME:
|
|
|
|
return wxString( _("Duplicate sheet names within a given sheet") );
|
|
|
|
case ERCE_PIN_NOT_CONNECTED:
|
2018-05-28 13:47:05 +00:00
|
|
|
return wxString( _("Pin not connected (use a \"no connection\" flag to suppress this error)") );
|
2013-05-26 04:36:44 +00:00
|
|
|
case ERCE_PIN_NOT_DRIVEN:
|
2019-01-29 21:49:44 +00:00
|
|
|
return wxString( _( "Pin connected to other pins, but not driven by any pin" ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
case ERCE_PIN_TO_PIN_WARNING:
|
|
|
|
return wxString( _("Conflict problem between pins. Severity: warning") );
|
|
|
|
case ERCE_PIN_TO_PIN_ERROR:
|
|
|
|
return wxString( _("Conflict problem between pins. Severity: error") );
|
|
|
|
case ERCE_HIERACHICAL_LABEL:
|
2019-04-12 01:22:19 +00:00
|
|
|
return wxString( _("Mismatch between hierarchical labels and pins sheets") );
|
2013-05-26 04:36:44 +00:00
|
|
|
case ERCE_NOCONNECT_CONNECTED:
|
2019-04-12 01:22:19 +00:00
|
|
|
return wxString( _("A pin with a \"no connection\" flag is connected") );
|
|
|
|
case ERCE_NOCONNECT_NOT_CONNECTED:
|
|
|
|
return wxString( _("A \"no connection\" flag is not connected to anything") );
|
2019-03-11 21:32:05 +00:00
|
|
|
case ERCE_LABEL_NOT_CONNECTED:
|
2019-04-25 19:10:19 +00:00
|
|
|
return wxString( _("Label not connected anywhere else in the schematic") );
|
2015-12-20 12:40:17 +00:00
|
|
|
case ERCE_SIMILAR_LABELS:
|
2019-04-12 01:22:19 +00:00
|
|
|
return wxString( _("Labels are similar (lower/upper case difference only)" ) );
|
2015-12-20 12:40:17 +00:00
|
|
|
case ERCE_SIMILAR_GLBL_LABELS:
|
2019-04-12 01:22:19 +00:00
|
|
|
return wxString( _("Global labels are similar (lower/upper case difference only)" ) );
|
2018-01-19 15:12:36 +00:00
|
|
|
case ERCE_DIFFERENT_UNIT_FP:
|
2019-04-12 01:22:19 +00:00
|
|
|
return wxString( _("Different footprint assigned in another unit of the same component" ) );
|
2018-03-15 01:03:26 +00:00
|
|
|
case ERCE_DIFFERENT_UNIT_NET:
|
|
|
|
return wxString( _("Different net assigned to a shared pin in another unit of the same component" ) );
|
2019-03-11 21:32:05 +00:00
|
|
|
case ERCE_BUS_ALIAS_CONFLICT:
|
|
|
|
return wxString( _("Conflict between bus alias definitions across schematic sheets") );
|
|
|
|
case ERCE_DRIVER_CONFLICT:
|
|
|
|
return wxString( _( "More than one name given to this bus or net" ) );
|
|
|
|
case ERCE_BUS_ENTRY_CONFLICT:
|
|
|
|
return wxString( _( "Net is graphically connected to a bus but not a bus member" ) );
|
|
|
|
case ERCE_BUS_LABEL_ERROR:
|
|
|
|
return wxString( _( "Label attached to bus item does not describe a bus" ) );
|
|
|
|
case ERCE_BUS_TO_BUS_CONFLICT:
|
|
|
|
return wxString( _( "No nets are shared between two bus items" ) );
|
|
|
|
case ERCE_BUS_TO_NET_CONFLICT:
|
|
|
|
return wxString( _( "Invalid connection between bus and net items" ) );
|
2019-04-12 01:22:19 +00:00
|
|
|
case ERCE_GLOBLABEL:
|
2019-04-25 19:10:19 +00:00
|
|
|
return wxString( _( "Global label not connected anywhere else in the schematic" ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
default:
|
2018-01-19 15:12:36 +00:00
|
|
|
wxFAIL_MSG( "Missing ERC error description" );
|
2018-02-25 12:17:27 +00:00
|
|
|
return wxString( wxT("Unknown.") );
|
2013-05-26 04:36:44 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-12-20 14:11:39 +00:00
|
|
|
wxString DRC_ITEM::ShowCoord( EDA_UNITS aUnits, const wxPoint& aPos )
|
2013-05-26 04:36:44 +00:00
|
|
|
{
|
2018-07-28 10:47:23 +00:00
|
|
|
return wxString::Format( "@(%s, %s)",
|
2018-04-10 10:52:12 +00:00
|
|
|
MessageTextFromValue( aUnits, aPos.x ),
|
|
|
|
MessageTextFromValue( aUnits, aPos.y ) );
|
2013-05-26 04:36:44 +00:00
|
|
|
}
|
2018-01-30 14:13:34 +00:00
|
|
|
|
|
|
|
|
2019-12-20 14:11:39 +00:00
|
|
|
wxString DRC_ITEM::ShowHtml( EDA_UNITS aUnits ) const
|
2018-01-30 14:13:34 +00:00
|
|
|
{
|
|
|
|
wxString mainText = m_MainText;
|
|
|
|
// a wxHtmlWindows does not like < and > in the text to display
|
|
|
|
// because these chars have a special meaning in html
|
|
|
|
mainText.Replace( wxT("<"), wxT("<") );
|
|
|
|
mainText.Replace( wxT(">"), wxT(">") );
|
|
|
|
|
|
|
|
wxString errText = GetErrorText();
|
|
|
|
errText.Replace( wxT("<"), wxT("<") );
|
|
|
|
errText.Replace( wxT(">"), wxT(">") );
|
|
|
|
|
|
|
|
wxColour hrefColour = wxSystemSettings::GetColour( wxSYS_COLOUR_HOTLIGHT );
|
|
|
|
|
|
|
|
if( m_noCoordinate )
|
|
|
|
{
|
|
|
|
// omit the coordinate, a NETCLASS has no location
|
2018-07-28 10:47:23 +00:00
|
|
|
return wxString::Format( "<p><b>%s</b><br> %s", errText, mainText );
|
2018-01-30 14:13:34 +00:00
|
|
|
}
|
|
|
|
else if( m_hasSecondItem )
|
|
|
|
{
|
|
|
|
wxString auxText = m_AuxiliaryText;
|
|
|
|
auxText.Replace( wxT("<"), wxT("<") );
|
|
|
|
auxText.Replace( wxT(">"), wxT(">") );
|
|
|
|
|
|
|
|
// an html fragment for the entire message in the listbox. feel free
|
|
|
|
// to add color if you want:
|
2018-07-28 10:47:23 +00:00
|
|
|
return wxString::Format( "<p><b>%s</b><br> <font color='%s'><a href=''>%s</a></font>: %s<br> %s: %s",
|
2018-04-10 10:52:12 +00:00
|
|
|
errText,
|
|
|
|
hrefColour.GetAsString( wxC2S_HTML_SYNTAX ),
|
2018-06-15 04:49:50 +00:00
|
|
|
ShowCoord( aUnits, m_MainPosition ),
|
2018-04-10 10:52:12 +00:00
|
|
|
mainText,
|
2018-06-15 04:49:50 +00:00
|
|
|
ShowCoord( aUnits, m_AuxiliaryPosition ),
|
2018-04-10 10:52:12 +00:00
|
|
|
auxText );
|
2018-01-30 14:13:34 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2018-07-28 10:47:23 +00:00
|
|
|
return wxString::Format( "<p><b>%s</b><br> <font color='%s'><a href=''>%s</a></font>: %s",
|
2018-04-10 10:52:12 +00:00
|
|
|
errText,
|
|
|
|
hrefColour.GetAsString( wxC2S_HTML_SYNTAX ),
|
2018-06-15 04:49:50 +00:00
|
|
|
ShowCoord( aUnits, m_MainPosition ),
|
2018-04-10 10:52:12 +00:00
|
|
|
mainText );
|
2018-01-30 14:13:34 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-12-20 14:11:39 +00:00
|
|
|
wxString DRC_ITEM::ShowReport( EDA_UNITS aUnits ) const
|
2018-01-30 14:13:34 +00:00
|
|
|
{
|
|
|
|
if( m_hasSecondItem )
|
|
|
|
{
|
2018-04-10 10:52:12 +00:00
|
|
|
return wxString::Format( wxT( "ErrType(%d): %s\n %s: %s\n %s: %s\n" ),
|
|
|
|
m_ErrorCode,
|
|
|
|
GetErrorText(),
|
2018-06-15 04:49:50 +00:00
|
|
|
ShowCoord( aUnits, m_MainPosition ),
|
2018-04-10 10:52:12 +00:00
|
|
|
m_MainText,
|
2018-06-15 04:49:50 +00:00
|
|
|
ShowCoord( aUnits, m_AuxiliaryPosition ),
|
2018-04-10 10:52:12 +00:00
|
|
|
m_AuxiliaryText );
|
2018-01-30 14:13:34 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2018-04-10 10:52:12 +00:00
|
|
|
return wxString::Format( wxT( "ErrType(%d): %s\n %s: %s\n" ),
|
|
|
|
m_ErrorCode,
|
|
|
|
GetErrorText(),
|
2018-06-15 04:49:50 +00:00
|
|
|
ShowCoord( aUnits, m_MainPosition ),
|
2018-04-10 10:52:12 +00:00
|
|
|
m_MainText );
|
2018-01-30 14:13:34 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|