Ensure global labels get flagged as lonely in all circumstances
Fixes: lp:1827214 * https://bugs.launchpad.net/kicad/+bug/1827214
This commit is contained in:
parent
9f189ca71a
commit
4efed8a4dd
|
@ -2077,32 +2077,37 @@ bool CONNECTION_GRAPH::ercCheckLabels( const CONNECTION_SUBGRAPH* aSubgraph,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
bool is_global = text && ( text->Type() == SCH_GLOBAL_LABEL_T );
|
if( !text )
|
||||||
|
return true;
|
||||||
|
|
||||||
|
bool is_global = text->Type() == SCH_GLOBAL_LABEL_T;
|
||||||
|
|
||||||
// Global label check can be disabled independently
|
// Global label check can be disabled independently
|
||||||
if( !aCheckGlobalLabels && is_global )
|
if( !aCheckGlobalLabels && is_global )
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
if( text )
|
wxString name = text->GetShownText();
|
||||||
|
|
||||||
|
if( is_global)
|
||||||
{
|
{
|
||||||
wxString name = text->GetShownText();
|
// This will be set to true if the global is connected to a pin above, but we
|
||||||
|
// want to reset this to false so that globals get flagged if they only have a
|
||||||
|
// single instance
|
||||||
|
has_other_connections = false;
|
||||||
|
|
||||||
if( is_global)
|
if( m_net_name_to_subgraphs_map.count( name )
|
||||||
{
|
&& m_net_name_to_subgraphs_map.at( name ).size() > 1 )
|
||||||
if( m_net_name_to_subgraphs_map.count( name )
|
has_other_connections = true;
|
||||||
&& m_net_name_to_subgraphs_map.at( name ).size() > 1 )
|
}
|
||||||
has_other_connections = true;
|
else
|
||||||
}
|
{
|
||||||
else
|
auto pair = std::make_pair( aSubgraph->m_sheet, name );
|
||||||
{
|
|
||||||
auto pair = std::make_pair( aSubgraph->m_sheet, name );
|
|
||||||
|
|
||||||
if( m_local_label_cache.count( pair ) && m_local_label_cache.at( pair ).size() > 1 )
|
if( m_local_label_cache.count( pair ) && m_local_label_cache.at( pair ).size() > 1 )
|
||||||
has_other_connections = true;
|
has_other_connections = true;
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if( text && !has_other_connections )
|
if( !has_other_connections )
|
||||||
{
|
{
|
||||||
if( aCreateMarkers )
|
if( aCreateMarkers )
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in New Issue