KiCad PCB EDA Suite
erc.h File Reference

Go to the source code of this file.

Macros

#define ERCE_UNSPECIFIED   0
 DRC error codes: More...
 
#define ERCE_DUPLICATE_SHEET_NAME   1
 
#define ERCE_PIN_NOT_CONNECTED   2
 
#define ERCE_PIN_NOT_DRIVEN   3
 
#define ERCE_PIN_TO_PIN_WARNING   4
 
#define ERCE_PIN_TO_PIN_ERROR   5
 
#define ERCE_HIERACHICAL_LABEL   6
 
#define ERCE_NOCONNECT_CONNECTED   7
 
#define ERCE_GLOBLABEL   8
 
#define ERCE_SIMILAR_LABELS   9
 
#define ERCE_SIMILAR_GLBL_LABELS   10
 
#define NPI   4
 
#define DRV   3
 
#define NET_NC   2
 
#define NOD   1
 
#define NOC   0
 

Enumerations

enum  errortype { OK = 0, WAR, ERR, UNC }
 

Functions

bool WriteDiagnosticERC (const wxString &aFullFileName)
 Function WriteDiagnosticERC save the ERC errors to aFullFileName. More...
 
void Diagnose (NETLIST_OBJECT *NetItemRef, NETLIST_OBJECT *NetItemTst, int MinConnexion, int Diag)
 Performs ERC testing and creates an ERC marker to show the ERC problem for aNetItemRef or between aNetItemRef and aNetItemTst. More...
 
void TestOthersItems (NETLIST_OBJECT_LIST *aList, unsigned aNetItemRef, unsigned aNetStart, int *aMinConnexion)
 Perform ERC testing for electrical conflicts between NetItemRef and other items (mainly pin) on the same net. More...
 
int TestDuplicateSheetNames (bool aCreateMarker)
 Function TestDuplicateSheetNames( ) inside a given sheet, one cannot have sheets with duplicate names (file names can be duplicated). More...
 

Variables

const wxString CommentERC_H []
 
const wxString CommentERC_V []
 

Macro Definition Documentation

#define DRV   3

Definition at line 66 of file erc.h.

Referenced by TestOthersItems().

#define ERCE_DUPLICATE_SHEET_NAME   1

Definition at line 53 of file erc.h.

Referenced by TestDuplicateSheetNames().

#define ERCE_GLOBLABEL   8

Definition at line 60 of file erc.h.

Referenced by Diagnose().

#define ERCE_HIERACHICAL_LABEL   6

Definition at line 58 of file erc.h.

Referenced by Diagnose().

#define ERCE_NOCONNECT_CONNECTED   7

Definition at line 59 of file erc.h.

Referenced by Diagnose().

#define ERCE_PIN_NOT_CONNECTED   2

Definition at line 54 of file erc.h.

Referenced by Diagnose().

#define ERCE_PIN_NOT_DRIVEN   3

Definition at line 55 of file erc.h.

Referenced by Diagnose().

#define ERCE_PIN_TO_PIN_ERROR   5

Definition at line 57 of file erc.h.

Referenced by Diagnose().

#define ERCE_PIN_TO_PIN_WARNING   4

Definition at line 56 of file erc.h.

Referenced by Diagnose().

#define ERCE_SIMILAR_GLBL_LABELS   10

Definition at line 62 of file erc.h.

Referenced by SimilarLabelsDiagnose().

#define ERCE_SIMILAR_LABELS   9

Definition at line 61 of file erc.h.

Referenced by SimilarLabelsDiagnose().

#define ERCE_UNSPECIFIED   0

DRC error codes:

Definition at line 52 of file erc.h.

#define NET_NC   2

Definition at line 67 of file erc.h.

Referenced by DIALOG_ERC::TestErc(), and TestOthersItems().

#define NOC   0

Definition at line 69 of file erc.h.

Referenced by Diagnose(), DIALOG_ERC::TestErc(), and TestOthersItems().

#define NOD   1

Definition at line 68 of file erc.h.

Referenced by Diagnose().

#define NPI   4

Definition at line 65 of file erc.h.

Referenced by TestOthersItems().

Enumeration Type Documentation

enum errortype
Enumerator
OK 
WAR 
ERR 
UNC 

Definition at line 40 of file erc.h.

41 {
42  OK = 0,
43  WAR, // Error: severity = warning
44  ERR, // Error: severity = error
45  UNC // Error: unconnected pin
46 };
Definition: erc.h:43
Definition: erc.h:42
Definition: erc.h:44
Definition: erc.h:45

Function Documentation

void Diagnose ( NETLIST_OBJECT NetItemRef,
NETLIST_OBJECT NetItemTst,
int  MinConnexion,
int  Diag 
)

Performs ERC testing and creates an ERC marker to show the ERC problem for aNetItemRef or between aNetItemRef and aNetItemTst.

if MinConn < 0: this is an error on labels

Definition at line 228 of file erc.cpp.

References SCH_SCREEN::Append(), ERCE_GLOBLABEL, ERCE_HIERACHICAL_LABEL, ERCE_NOCONNECT_CONNECTED, ERCE_PIN_NOT_CONNECTED, ERCE_PIN_NOT_DRIVEN, ERCE_PIN_TO_PIN_ERROR, ERCE_PIN_TO_PIN_WARNING, ERR, GetChars(), NETLIST_OBJECT::GetComponentParent(), NETLIST_OBJECT::GetNet(), GetNewTimeStamp(), SCH_COMPONENT::GetRef(), GetText(), SCH_SHEET_PATH::LastScreen(), NETLIST_OBJECT::m_ElectricalPinType, NETLIST_OBJECT::m_Label, NETLIST_OBJECT::m_Link, NETLIST_OBJECT::m_PinNum, NETLIST_OBJECT::m_SheetPath, NETLIST_OBJECT::m_Start, NETLIST_OBJECT::m_Type, MARKER_BASE::MARKER_ERC, MARKER_BASE::MARKER_SEVERITY_ERROR, MARKER_BASE::MARKER_SEVERITY_WARNING, NET_GLOBLABEL, NET_HIERBUSLABELMEMBER, NET_HIERLABEL, NET_PIN, NOC, NOD, OK, MARKER_BASE::SetAuxiliaryData(), MARKER_BASE::SetData(), MARKER_BASE::SetErrorLevel(), MARKER_BASE::SetMarkerType(), EDA_ITEM::SetTimeStamp(), and UNC.

Referenced by DIALOG_ERC::TestErc(), NETLIST_OBJECT_LIST::TestforNonOrphanLabel(), and TestOthersItems().

230 {
231  SCH_MARKER* marker = NULL;
232  SCH_SCREEN* screen;
233  ELECTRICAL_PINTYPE ii, jj;
234 
235  if( aDiag == OK )
236  return;
237 
238  /* Create new marker for ERC error. */
239  marker = new SCH_MARKER();
240  marker->SetTimeStamp( GetNewTimeStamp() );
241 
244  screen = aNetItemRef->m_SheetPath.LastScreen();
245  screen->Append( marker );
246 
247  wxString msg;
248 
249  if( aMinConn < 0 )
250  {
251  if( aNetItemRef->m_Type == NET_HIERLABEL || aNetItemRef->m_Type == NET_HIERBUSLABELMEMBER )
252  {
253  msg.Printf( _( "Hierarchical label %s is not connected to a sheet label." ),
254  GetChars( aNetItemRef->m_Label ) );
256  aNetItemRef->m_Start,
257  msg,
258  aNetItemRef->m_Start );
259  }
260  else if( aNetItemRef->m_Type == NET_GLOBLABEL )
261  {
262  msg.Printf( _( "Global label %s is not connected to any other global label." ),
263  GetChars( aNetItemRef->m_Label ) );
264  marker->SetData( ERCE_GLOBLABEL,
265  aNetItemRef->m_Start,
266  msg,
267  aNetItemRef->m_Start );
268  }
269  else
270  {
271  msg.Printf( _( "Sheet label %s is not connected to a hierarchical label." ),
272  GetChars( aNetItemRef->m_Label ) );
274  aNetItemRef->m_Start,
275  msg,
276  aNetItemRef->m_Start );
277  }
278 
279  return;
280  }
281 
282  ii = aNetItemRef->m_ElectricalPinType;
283 
284  wxString cmp_ref( "?" );
285 
286  if( aNetItemRef->m_Type == NET_PIN && aNetItemRef->m_Link )
287  cmp_ref = aNetItemRef->GetComponentParent()->GetRef( &aNetItemRef->m_SheetPath );
288 
289  if( aNetItemTst == NULL )
290  {
291  if( aMinConn == NOC ) /* Only 1 element in the net. */
292  {
293  msg.Printf( _( "Pin %s (%s) of component %s is unconnected." ),
294  aNetItemRef->m_PinNum,
295  GetChars( GetText( ii ) ),
296  GetChars( cmp_ref ) );
298  aNetItemRef->m_Start,
299  msg,
300  aNetItemRef->m_Start );
301  return;
302  }
303 
304  if( aMinConn == NOD ) /* Nothing driving the net. */
305  {
306  if( aNetItemRef->m_Type == NET_PIN && aNetItemRef->m_Link )
307  cmp_ref = aNetItemRef->GetComponentParent()->GetRef(
308  &aNetItemRef->m_SheetPath );
309 
310  msg.Printf( _( "Pin %s (%s) of component %s is not driven (Net %d)." ),
311  aNetItemRef->m_PinNum,
312  GetChars( GetText( ii ) ),
313  GetChars( cmp_ref ),
314  aNetItemRef->GetNet() );
315  marker->SetData( ERCE_PIN_NOT_DRIVEN,
316  aNetItemRef->m_Start,
317  msg,
318  aNetItemRef->m_Start );
319  return;
320  }
321 
322  if( aDiag == UNC )
323  {
324  msg.Printf( _( "More than 1 pin connected to an UnConnect symbol." ) );
326  aNetItemRef->m_Start,
327  msg,
328  aNetItemRef->m_Start );
329  return;
330  }
331  }
332 
333  if( aNetItemTst ) /* Error between 2 pins */
334  {
335  jj = aNetItemTst->m_ElectricalPinType;
337 
338  if( aDiag == ERR )
339  {
341  errortype = ERCE_PIN_TO_PIN_ERROR;
342  }
343 
344  wxString alt_cmp( "?" );
345 
346  if( aNetItemTst->m_Type == NET_PIN && aNetItemTst->m_Link )
347  alt_cmp = aNetItemTst->GetComponentParent()->GetRef( &aNetItemTst->m_SheetPath );
348 
349  msg.Printf( _( "Pin %s (%s) of component %s is connected to " ),
350  aNetItemRef->m_PinNum,
351  GetChars( GetText( ii ) ),
352  GetChars( cmp_ref ) );
353  marker->SetData( errortype, aNetItemRef->m_Start, msg, aNetItemRef->m_Start );
354  msg.Printf( _( "pin %s (%s) of component %s (net %d)." ),
355  aNetItemTst->m_PinNum,
356  GetChars( GetText( jj ) ),
357  GetChars( alt_cmp ),
358  aNetItemRef->GetNet() );
359  marker->SetAuxiliaryData( msg, aNetItemTst->m_Start );
360  }
361 }
#define ERCE_HIERACHICAL_LABEL
Definition: erc.h:58
#define ERCE_PIN_NOT_DRIVEN
Definition: erc.h:55
#define ERCE_PIN_NOT_CONNECTED
Definition: erc.h:54
void SetData(int aErrorCode, const wxPoint &aMarkerPos, const wxString &aText, const wxPoint &aPos, const wxString &bText, const wxPoint &bPos)
Function SetData fills in all the reportable data associated with a MARKER.
Definition: erc.h:42
timestamp_t GetNewTimeStamp()
Definition: common.cpp:166
Definition: erc.h:44
#define ERCE_GLOBLABEL
Definition: erc.h:60
wxString GetText(GRAPHIC_PINSHAPE shape)
Definition: pin_shape.cpp:33
Definition: erc.h:45
#define ERCE_PIN_TO_PIN_ERROR
Definition: erc.h:57
void SetMarkerType(enum TYPEMARKER aMarkerType)
accessors to set/get marker type (DRC, ERC, or other)
#define NOC
Definition: erc.h:69
static const wxChar * GetChars(const wxString &s)
Function GetChars returns a wxChar* to the actual wxChar* data within a wxString, and is helpful for ...
Definition: macros.h:92
ELECTRICAL_PINTYPE
The component library pin object electrical types used in ERC tests.
Definition: pin_type.h:37
void Append(SCH_ITEM *aItem)
void SetErrorLevel(MARKER_SEVERITY aErrorLevel)
accessors to set/get error levels (warning, error, fatal error..)
errortype
Definition: erc.h:40
#define ERCE_NOCONNECT_CONNECTED
Definition: erc.h:59
#define ERCE_PIN_TO_PIN_WARNING
Definition: erc.h:56
void SetAuxiliaryData(const wxString &aAuxiliaryText, const wxPoint &aAuxiliaryPos)
Function SetAuxiliaryData initialize data for the second (auxiliary) item.
#define NOD
Definition: erc.h:68
void SetTimeStamp(timestamp_t aNewTimeStamp)
Definition: base_struct.h:230
int TestDuplicateSheetNames ( bool  aCreateMarker)

Function TestDuplicateSheetNames( ) inside a given sheet, one cannot have sheets with duplicate names (file names can be duplicated).

Returns
the error count
Parameters
aCreateMarkertrue = create error markers in schematic, false = calculate error count only

Definition at line 177 of file erc.cpp.

178 {
179  SCH_SCREEN* screen;
180  SCH_ITEM* item;
181  SCH_ITEM* test_item;
182  int err_count = 0;
183  SCH_SCREENS screenList; // Created the list of screen
184 
185  for( screen = screenList.GetFirst(); screen != NULL; screen = screenList.GetNext() )
186  {
187  for( item = screen->GetDrawItems(); item != NULL; item = item->Next() )
188  {
189  // search for a sheet;
190  if( item->Type() != SCH_SHEET_T )
191  continue;
192 
193  for( test_item = item->Next(); test_item != NULL; test_item = test_item->Next() )
194  {
195  if( test_item->Type() != SCH_SHEET_T )
196  continue;
197 
198  // We have found a second sheet: compare names
199  // we are using case insensitive comparison to avoid mistakes between
200  // similar names like Mysheet and mysheet
201  if( ( (SCH_SHEET*) item )->GetName().CmpNoCase(
202  ( ( SCH_SHEET* ) test_item )->GetName() ) == 0 )
203  {
204  if( aCreateMarker )
205  {
206  /* Create a new marker type ERC error*/
207  SCH_MARKER* marker = new SCH_MARKER();
208  marker->SetTimeStamp( GetNewTimeStamp() );
210  ( (SCH_SHEET*) test_item )->GetPosition(),
211  _( "Duplicate sheet name" ),
212  ( (SCH_SHEET*) test_item )->GetPosition() );
215  screen->Append( marker );
216  }
217 
218  err_count++;
219  }
220  }
221  }
222  }
223 
224  return err_count;
225 }
KICAD_T Type() const
Function Type()
Definition: base_struct.h:225
SCH_SCREEN * GetNext()
SCH_ITEM * Next() const
void SetData(int aErrorCode, const wxPoint &aMarkerPos, const wxString &aText, const wxPoint &aPos, const wxString &bText, const wxPoint &bPos)
Function SetData fills in all the reportable data associated with a MARKER.
timestamp_t GetNewTimeStamp()
Definition: common.cpp:166
#define ERCE_DUPLICATE_SHEET_NAME
Definition: erc.h:53
void SetMarkerType(enum TYPEMARKER aMarkerType)
accessors to set/get marker type (DRC, ERC, or other)
Sheet symbol placed in a schematic, and is the entry point for a sub schematic.
Definition: sch_sheet.h:209
SCH_ITEM * GetDrawItems() const
void Append(SCH_ITEM *aItem)
void SetErrorLevel(MARKER_SEVERITY aErrorLevel)
accessors to set/get error levels (warning, error, fatal error..)
SCH_SCREEN * GetFirst()
Class SCH_ITEM is a base class for any item which can be embedded within the SCHEMATIC container clas...
Container class that holds multiple SCH_SCREEN objects in a hierarchy.
void SetTimeStamp(timestamp_t aNewTimeStamp)
Definition: base_struct.h:230
void TestOthersItems ( NETLIST_OBJECT_LIST aList,
unsigned  aNetItemRef,
unsigned  aNetStart,
int *  aMinConnexion 
)

Perform ERC testing for electrical conflicts between NetItemRef and other items (mainly pin) on the same net.

Parameters
aList= a reference to the list of connected objects
aNetItemRef= index in list of the current object
aNetStart= index in list of net objects of the first item
aMinConnexion= a pointer to a variable to store the minimal connection found( NOD, DRV, NPI, NET_NC)

Definition at line 364 of file erc.cpp.

References DiagErc, Diagnose(), DRV, NETLIST_OBJECT_LIST::GetConnectionType(), NETLIST_OBJECT_LIST::GetItem(), NETLIST_OBJECT_LIST::GetItemNet(), NETLIST_OBJECT_LIST::GetItemType(), NETLIST_OBJECT::m_ElectricalPinType, NETLIST_OBJECT::m_Link, NETLIST_OBJECT::m_PinNum, NETLIST_OBJECT::m_SheetPath, max, MinimalReq, NET_BUS, NET_BUSLABELMEMBER, NET_GLOBBUSLABELMEMBER, NET_GLOBLABEL, NET_HIERBUSLABELMEMBER, NET_HIERLABEL, NET_ITEM_UNSPECIFIED, NET_JUNCTION, NET_LABEL, NET_NC, NET_NOCONNECT, NET_PIN, NET_PINLABEL, NET_SEGMENT, NET_SHEETBUSLABELMEMBER, NET_SHEETLABEL, NOC, NOCONNECT_SYMBOL_PRESENT, NPI, OK, PIN_NC, NETLIST_OBJECT_LIST::SetConnectionType(), UNCONNECTED, and WAR.

Referenced by DIALOG_ERC::TestErc().

367 {
368  unsigned netItemTst = aNetStart;
370  int erc = OK;
371 
372  /* Analysis of the table of connections. */
373  ELECTRICAL_PINTYPE ref_elect_type = aList->GetItem( aNetItemRef )->m_ElectricalPinType;
374  int local_minconn = NOC;
375 
376  if( ref_elect_type == PIN_NC )
377  local_minconn = NPI;
378 
379  /* Test pins connected to NetItemRef */
380  for( ; ; netItemTst++ )
381  {
382  if( aNetItemRef == netItemTst )
383  continue;
384 
385  // We examine only a given net. We stop the search if the net changes
386  if( ( netItemTst >= aList->size() ) // End of list
387  || ( aList->GetItemNet( aNetItemRef ) !=
388  aList->GetItemNet( netItemTst ) ) ) // End of net
389  {
390  /* End net code found: minimum connection test. */
391  if( ( *aMinConnexion < NET_NC ) && ( local_minconn < NET_NC ) )
392  {
393  /* Not connected or not driven pin. */
394  bool seterr = true;
395 
396  if( local_minconn == NOC &&
397  aList->GetItemType( aNetItemRef ) == NET_PIN )
398  {
399  /* This pin is not connected: for multiple part per
400  * package, and duplicated pin,
401  * search for an other instance of this pin
402  * this will be flagged only if all instances of this pin
403  * are not connected
404  * TODO test also if instances connected are connected to
405  * the same net
406  */
407  for( unsigned duplicate = 0; duplicate < aList->size(); duplicate++ )
408  {
409  if( aList->GetItemType( duplicate ) != NET_PIN )
410  continue;
411 
412  if( duplicate == aNetItemRef )
413  continue;
414 
415  if( aList->GetItem( aNetItemRef )->m_PinNum !=
416  aList->GetItem( duplicate )->m_PinNum )
417  continue;
418 
419  if( ( (SCH_COMPONENT*) aList->GetItem( aNetItemRef )->
420  m_Link )->GetRef( &aList->GetItem( aNetItemRef )-> m_SheetPath ) !=
421  ( (SCH_COMPONENT*) aList->GetItem( duplicate )->m_Link )
422  ->GetRef( &aList->GetItem( duplicate )->m_SheetPath ) )
423  continue;
424 
425  // Same component and same pin. Do dot create error for this pin
426  // if the other pin is connected (i.e. if duplicate net has an other
427  // item)
428  if( (duplicate > 0)
429  && ( aList->GetItemNet( duplicate ) ==
430  aList->GetItemNet( duplicate - 1 ) ) )
431  seterr = false;
432 
433  if( (duplicate < aList->size() - 1)
434  && ( aList->GetItemNet( duplicate ) ==
435  aList->GetItemNet( duplicate + 1 ) ) )
436  seterr = false;
437  }
438  }
439 
440  if( seterr )
441  Diagnose( aList->GetItem( aNetItemRef ), NULL, local_minconn, WAR );
442 
443  *aMinConnexion = DRV; // inhibiting other messages of this
444  // type for the net.
445  }
446  return;
447  }
448 
449  switch( aList->GetItemType( netItemTst ) )
450  {
452  case NET_SEGMENT:
453  case NET_BUS:
454  case NET_JUNCTION:
455  case NET_LABEL:
456  case NET_HIERLABEL:
457  case NET_BUSLABELMEMBER:
460  case NET_SHEETLABEL:
461  case NET_GLOBLABEL:
463  case NET_PINLABEL:
464  break;
465 
466  case NET_NOCONNECT:
467  local_minconn = std::max( NET_NC, local_minconn );
468  break;
469 
470  case NET_PIN:
471  jj = aList->GetItem( netItemTst )->m_ElectricalPinType;
472  local_minconn = std::max( MinimalReq[ref_elect_type][jj], local_minconn );
473 
474  if( netItemTst <= aNetItemRef )
475  break;
476 
477  if( erc == OK )
478  {
479  erc = DiagErc[ref_elect_type][jj];
480 
481  if( erc != OK )
482  {
483  if( aList->GetConnectionType( netItemTst ) == UNCONNECTED )
484  {
485  Diagnose( aList->GetItem( aNetItemRef ),
486  aList->GetItem( netItemTst ),
487  0, erc );
488  aList->SetConnectionType( netItemTst, NOCONNECT_SYMBOL_PRESENT );
489  }
490  }
491  }
492 
493  break;
494  }
495  }
496 }
Definition: erc.h:43
NETLIST_ITEM_T GetItemType(unsigned aIdx) const
Acces to an item type.
NETLIST_OBJECT * GetItem(unsigned aIdx) const
Acces to an item in list.
int DiagErc[PINTYPE_COUNT][PINTYPE_COUNT]
Definition: erc.cpp:124
void Diagnose(NETLIST_OBJECT *aNetItemRef, NETLIST_OBJECT *aNetItemTst, int aMinConn, int aDiag)
Performs ERC testing and creates an ERC marker to show the ERC problem for aNetItemRef or between aNe...
Definition: erc.cpp:228
SCH_SHEET_PATH m_SheetPath
ELECTRICAL_PINTYPE m_ElectricalPinType
void SetConnectionType(unsigned aIdx, NET_CONNECTION_T aFlg=UNCONNECTED)
Set the item connection type: UNCONNECTED Pin or Label not connected (error) NOCONNECT_SYMBOL_PRESENT...
#define DRV
Definition: erc.h:66
Definition: erc.h:42
#define NOC
Definition: erc.h:69
NET_CONNECTION_T GetConnectionType(unsigned aIdx)
static int MinimalReq[PINTYPE_COUNT][PINTYPE_COUNT]
Look up table which gives the minimal drive for a pair of connected pins on a net.
Definition: erc.cpp:160
ELECTRICAL_PINTYPE
The component library pin object electrical types used in ERC tests.
Definition: pin_type.h:37
#define max(a, b)
Definition: auxiliary.h:86
#define NPI
Definition: erc.h:65
Class SCH_COMPONENT describes a real schematic component.
Definition: sch_component.h:69
int GetItemNet(unsigned aIdx) const
Acces to an item net code.
#define NET_NC
Definition: erc.h:67
bool WriteDiagnosticERC ( const wxString &  aFullFileName)

Function WriteDiagnosticERC save the ERC errors to aFullFileName.

Parameters
aFullFileNameA wxString object containing the file name and path.

Definition at line 517 of file erc.cpp.

References DateAndTime(), Format(), g_RootSheet, GetChars(), MARKER_BASE::GetErrorLevel(), MARKER_BASE::GetMarkerType(), MARKER_BASE::GetReporter(), MARKER_BASE::MARKER_ERC, MARKER_BASE::MARKER_SEVERITY_ERROR, MARKER_BASE::MARKER_SEVERITY_WARNING, SCH_MARKER_T, and DRC_ITEM::ShowReport().

Referenced by DIALOG_ERC::TestErc().

518 {
519  wxString msg;
520 
521  wxFFile file( aFullFileName, wxT( "wt" ) );
522 
523  if( !file.IsOpened() )
524  return false;
525 
526  msg = _( "ERC report" );
527  msg << wxT(" (") << DateAndTime() << wxT( ", " )
528  << _( "Encoding UTF8" ) << wxT( " )\n" );
529 
530  int err_count = 0;
531  int warn_count = 0;
532  int total_count = 0;
533  SCH_SHEET_LIST sheetList( g_RootSheet );
534 
535  for( unsigned i = 0; i < sheetList.size(); i++ )
536  {
537  msg << wxString::Format( _( "\n***** Sheet %s\n" ),
538  GetChars( sheetList[i].PathHumanReadable() ) );
539 
540  for( SCH_ITEM* item = sheetList[i].LastDrawList(); item != NULL; item = item->Next() )
541  {
542  if( item->Type() != SCH_MARKER_T )
543  continue;
544 
545  SCH_MARKER* marker = (SCH_MARKER*) item;
546 
547  if( marker->GetMarkerType() != MARKER_BASE::MARKER_ERC )
548  continue;
549 
550  total_count++;
551 
553  err_count++;
554 
556  warn_count++;
557 
558  msg << marker->GetReporter().ShowReport();
559  }
560  }
561 
562  msg << wxString::Format( _( "\n ** ERC messages: %d Errors %d Warnings %d\n" ),
563  total_count, err_count, warn_count );
564 
565  // Currently: write report using UTF8 (as usual in Kicad).
566  // TODO: see if we can use the current encoding page (mainly for Windows users),
567  // Or other format (HTML?)
568  file.Write( msg );
569 
570  // wxFFile dtor will close the file.
571 
572  return true;
573 }
Class SCH_SHEET_LIST.
wxString ShowReport() const
Function ShowReport translates this object into a text string suitable for saving to disk in a report...
SCH_ITEM * Next() const
enum TYPEMARKER GetMarkerType() const
MARKER_SEVERITY GetErrorLevel() const
SCH_SHEET * g_RootSheet
Definition: eeschema.cpp:55
const DRC_ITEM & GetReporter() const
Function GetReporter returns the DRC_ITEM held within this MARKER so that its interface may be used...
static const wxChar * GetChars(const wxString &s)
Function GetChars returns a wxChar* to the actual wxChar* data within a wxString, and is helpful for ...
Definition: macros.h:92
void Format(OUTPUTFORMATTER *out, int aNestLevel, int aCtl, CPTREE &aTree)
Function Format outputs a PTREE into s-expression format via an OUTPUTFORMATTER derivative.
Definition: ptree.cpp:205
Class SCH_ITEM is a base class for any item which can be embedded within the SCHEMATIC container clas...
wxString DateAndTime()
Function DateAndTime.
Definition: string.cpp:229

Variable Documentation

const wxString CommentERC_H[]

Definition at line 87 of file erc.cpp.

Referenced by DIALOG_ERC::ReBuildMatrixPanel().

const wxString CommentERC_V[]

Definition at line 103 of file erc.cpp.

Referenced by DIALOG_ERC::ReBuildMatrixPanel().