28#include <wx/filename.h>
124 else if( layer >=
User_1 && layer & 1 )
137 int infinity = ( std::numeric_limits<int>::max() / 2 ) -
pcbIUScale.mmToIU( 1 );
221 if( aProject && !aReferenceOnly )
238 std::shared_ptr<NET_SETTINGS>& projectSettings =
project.NetSettings();
240 projectSettings->SetDefaultNetclass( legacySettings->GetDefaultNetclass() );
241 projectSettings->SetNetclasses( legacySettings->GetNetclasses() );
242 projectSettings->SetNetclassPatternAssignments(
243 std::move( legacySettings->GetNetclassPatternAssignments() ) );
263 project.m_BoardSettings =
nullptr;
275 return wxEmptyString;
279 return m_project->AbsolutePath( fn.GetFullName() );
285 std::unique_lock<std::shared_mutex> writeLock(
m_CachesMutex );
339 std::shared_lock<std::shared_mutex> readLock(
m_CachesMutex );
349 auto index = std::make_shared<FOOTPRINT_COURTYARD_INDEX>(
this );
351 std::unique_lock<std::shared_mutex> writeLock(
m_CachesMutex );
362 std::set<std::pair<KIID, KIID>> m_ratsnestExclusions;
368 const std::shared_ptr<RC_ITEM>& rcItem = marker->GetRCItem();
369 m_ratsnestExclusions.emplace( rcItem->GetMainItemID(), rcItem->GetAuxItemID() );
370 m_ratsnestExclusions.emplace( rcItem->GetAuxItemID(), rcItem->GetMainItemID() );
383 aEdge.
SetVisible( m_ratsnestExclusions.count( ids ) == 0 );
398 if( marker->IsExcluded() )
400 wxString serialized = marker->SerializeToString();
402 m_designSettings->m_DrcExclusionComments[serialized] = marker->GetComment();
413 prjSettings->m_DrcExclusionComments =
m_designSettings->m_DrcExclusionComments;
419std::set<wxString>::iterator
FindByFirstNFields( std::set<wxString>& strSet,
const wxString& searchStr,
char delimiter,
422 wxString searchPrefix = searchStr;
425 int delimiterCount = 0;
428 while( pos < searchPrefix.length() && delimiterCount < n )
430 if( searchPrefix[pos] == delimiter )
436 if( delimiterCount == n )
437 searchPrefix = searchPrefix.Left( pos - 1 );
439 for(
auto it = strSet.begin(); it != strSet.end(); ++it )
441 if( it->StartsWith( searchPrefix + delimiter ) || *it == searchPrefix )
451 std::map<wxString, wxString> comments =
m_designSettings->m_DrcExclusionComments;
458 std::set<wxString>::iterator it;
459 wxString serialized = marker->SerializeToString();
460 wxString matchedExclusion;
462 if( !serialized.Contains(
"unconnected_items" ) )
464 it = exclusions.find( serialized );
466 if( it != exclusions.end() )
467 matchedExclusion = *it;
471 const int numberOfFieldsExcludingIds = 3;
472 const char delimiter =
'|';
473 it =
FindByFirstNFields( exclusions, serialized, delimiter, numberOfFieldsExcludingIds );
475 if( it != exclusions.end() )
476 matchedExclusion = *it;
479 if( it != exclusions.end() )
481 marker->SetExcluded(
true, comments[matchedExclusion] );
485 m_designSettings->m_DrcExclusionComments[matchedExclusion] = comments[matchedExclusion];
487 exclusions.erase( it );
491 std::vector<PCB_MARKER*> newMarkers;
495 for(
const wxString& serialized : exclusions )
506 for(
const KIID& uuid : ids )
508 if( uuidCount < 1 || uuid !=
niluuid )
523 newMarkers.push_back( marker );
527 m_designSettings->m_DrcExclusionComments[serialized] = comments[serialized];
538 auto add = [&](
const wxString& aVar )
541 aVars->push_back( aVar );
544 add( wxT(
"LAYER" ) );
545 add( wxT(
"FILENAME" ) );
546 add( wxT(
"FILEPATH" ) );
547 add( wxT(
"PROJECTNAME" ) );
548 add( wxT(
"DRC_ERROR <message_text>" ) );
549 add( wxT(
"DRC_WARNING <message_text>" ) );
550 add( wxT(
"VARIANT" ) );
551 add( wxT(
"VARIANT_DESC" ) );
557 for( std::pair<wxString, wxString> entry :
GetProject()->GetTextVars() )
565 if( token->Contains(
':' ) )
568 wxString ref = token->BeforeFirst(
':', &remainder );
577 *token = std::move( remainder );
588 if( footprint->GetReference().CmpNoCase( ref ) == 0 )
590 wxString remainderCopy = remainder;
592 if( footprint->ResolveTextVar( &remainderCopy, aDepth + 1 ) )
594 *token = std::move( remainderCopy );
599 *token = wxString::Format( wxT(
"<Unresolved: %s:%s>" ), footprint->GetReference(), remainder );
607 *token = wxString::Format( wxT(
"<Unknown reference: %s>" ), ref );
612 if( token->IsSameAs( wxT(
"FILENAME" ) ) )
615 *token = fn.GetFullName();
618 else if( token->IsSameAs( wxT(
"FILEPATH" ) ) )
621 *token = fn.GetFullPath();
624 else if( token->IsSameAs( wxT(
"VARIANT" ) ) )
629 else if( token->IsSameAs( wxT(
"VARIANT_DESC" ) ) )
634 else if( token->IsSameAs( wxT(
"PROJECTNAME" ) ) &&
GetProject() )
640 wxString var = *token;
676 wxLogWarning( wxT(
"This should not be called on the BOARD object" ) );
691 board_item->
Move( aMoveVector );
722 aFunction( footprint );
730 aFunction( drawing );
736 catch( std::bad_function_call& )
738 wxFAIL_MSG( wxT(
"Error running BOARD::RunOnChildren" ) );
776 for(
auto& [layer_id, layer] :
m_layers )
778 if( layer.m_name == aLayerName || layer.m_userName == aLayerName )
803 if( it !=
m_layers.end() && !it->second.m_userName.IsEmpty() )
804 return it->second.m_userName;
813 if( aLayerName.IsEmpty() )
816 m_layers[aLayer].m_userName.clear();
822 if( aLayerName.Find( wxChar(
'"' ) ) != wxNOT_FOUND )
827 m_layers[aLayer].m_userName = aLayerName;
856 return it->second.m_type;
872 m_layers[aLayer].m_type = aLayerType;
890 case LT_AUX:
return "auxiliary";
899 if( strcmp( aType,
"signal" ) == 0 )
901 else if( strcmp( aType,
"power" ) == 0 )
903 else if( strcmp( aType,
"mixed" ) == 0 )
905 else if( strcmp( aType,
"jumper" ) == 0 )
907 else if( strcmp( aType,
"auxiliary" ) == 0 )
909 else if( strcmp( aType,
"front" ) == 0 )
911 else if( strcmp( aType,
"back" ) == 0 )
926 if(
m_layers[layer].m_opposite != layer )
932 wxString principalName =
m_layers[layer].m_userName.AfterFirst(
'.' );
945 wxString candidate =
m_layers[ii].m_userName.AfterFirst(
'.' );
947 if( !candidate.IsEmpty() && candidate == principalName )
959 int next = layer + 2;
1024 if( aStartLayer > aEndLayer )
1025 std::swap( aStartLayer, aEndLayer );
1027 if( aEndLayer ==
B_Cu )
1030 return aEndLayer - aStartLayer;
1069 m_project->GetLocalSettings().m_VisibleLayers = aLayerSet;
1078 for(
size_t i = 0; i < aSet.size(); i++ )
1119 track->SetLocalRatsnestVisible( isEnabled );
1123 for(
PAD*
pad : footprint->Pads() )
1124 pad->SetLocalRatsnestVisible( isEnabled );
1128 zone->SetLocalRatsnestVisible( isEnabled );
1144 default: wxFAIL_MSG( wxT(
"BOARD::IsModuleLayerVisible(): bad layer" ) );
return true;
1179 std::unique_lock<std::shared_mutex> writeLock(
m_CachesMutex );
1184 worstClearance = std::max( worstClearance, zone->GetLocalClearance().value() );
1188 for(
PAD*
pad : footprint->Pads() )
1190 std::optional<int>
override =
pad->GetClearanceOverrides(
nullptr );
1192 if(
override.has_value() )
1193 worstClearance = std::max( worstClearance,
override.value() );
1196 for(
ZONE* zone : footprint->Zones() )
1197 worstClearance = std::max( worstClearance, zone->GetLocalClearance().value() );
1209 std::vector<ZONE*> zones = aZones;
1218 aReporter->
Report(
_(
"Tessellating copper zones..." ) );
1221 std::vector<std::future<size_t>> returns;
1223 returns.reserve( zones.size() );
1226 [&
tp]( std::function<void()> aTask )
1228 tp.detach_task( std::move( aTask ) );
1231 auto cache_zones = [aReporter, &submitter](
ZONE* aZone ) ->
size_t
1244 for(
ZONE* zone : zones )
1245 returns.emplace_back(
tp.submit_task(
1248 return cache_zones( zone );
1252 for(
const std::future<size_t>& ret : returns )
1254 std::future_status status = ret.wait_for( std::chrono::milliseconds( 250 ) );
1256 while( status != std::future_status::ready )
1261 status = ret.wait_for( std::chrono::milliseconds( 250 ) );
1270 aFunction( footprint->GetEmbeddedFiles() );
1287 embeddedFile->data_hash = file->
data_hash;
1288 embeddedFile->is_valid = file->
is_valid;
1297 if( aBoardItem ==
nullptr )
1299 wxFAIL_MSG( wxT(
"BOARD::Add() param error: aBoardItem nullptr" ) );
1305 switch( aBoardItem->
Type() )
1335 wxFAIL_MSG( wxString::Format(
"BOARD::Add() Cannot place Track on non-copper layer: %d = %s",
1336 static_cast<int>( aBoardItem->
GetLayer() ),
1398 wxFAIL_MSG( wxString::Format( wxT(
"BOARD::Add() item type %s not handled" ), aBoardItem->
GetClass() ) );
1405 if( !aSkipConnectivity )
1427 for(
int ii = (
int)
m_zones.size() - 1; ii >= 0; --ii )
1445 wxASSERT( aBoardItem );
1450 parentGroup && !( parentGroup->AsEdaItem()->GetFlags() &
STRUCT_DELETED ) )
1452 parentGroup->RemoveItem( aBoardItem );
1457 switch( aBoardItem->
Type() )
1466 if( boardItem->GetNet() == netItem )
1467 boardItem->SetNet( unconnected );
1526 wxFAIL_MSG( wxString::Format( wxT(
"BOARD::Remove() item type %s not handled" ), aBoardItem->
GetClass() ) );
1540 std::vector<BOARD_ITEM*> removed;
1541 std::vector<NETINFO_ITEM*> removedNets;
1543 for(
const KICAD_T& type : aTypes )
1550 removed.emplace_back( item );
1551 removedNets.emplace_back( item );
1565 std::copy(
m_groups.begin(),
m_groups.end(), std::back_inserter( removed ) );
1570 std::copy(
m_points.begin(),
m_points.end(), std::back_inserter( removed ) );
1575 std::copy(
m_zones.begin(),
m_zones.end(), std::back_inserter( removed ) );
1590 std::copy(
m_tracks.begin(),
m_tracks.end(), std::back_inserter( removed ) );
1595 case PCB_VIA_T: wxFAIL_MSG( wxT(
"Use PCB_TRACE_T to remove all tracks, arcs, and vias" ) );
break;
1613 case PCB_BARCODE_T: wxFAIL_MSG( wxT(
"Use PCB_SHAPE_T to remove all graphics and text" ) );
break;
1615 default: wxFAIL_MSG( wxT(
"BOARD::RemoveAll() needs more ::Type() support" ) );
1642 for(
int i = 0; i < collector.
GetCount(); i++ )
1662 via->LayerPair( &top_layer, &bottom_layer );
1664 if( top_layer != aLayer && bottom_layer != aLayer )
1679 bool modified =
false;
1680 bool removedItemLayers =
false;
1686 for(
int i = 0; i < collector.
GetCount(); i++ )
1707 removedItemLayers =
true;
1710 else if(
via->IsOnLayer( aLayer ) )
1714 via->LayerPair( &top_layer, &bottom_layer );
1716 if( top_layer == aLayer || bottom_layer == aLayer )
1726 removedItemLayers =
true;
1733 layers.
reset( aLayer );
1746 removedItemLayers =
true;
1750 if( removedItemLayers )
1759 return wxString::Format(
_(
"PCB" ) );
1774 aView->
Update( dimension );
1780 aItem->
Visit( inspector,
nullptr,
1801 std::vector<PCB_MARKER*> remaining;
1813 remaining.push_back( marker );
1824 std::vector<FOOTPRINT*> footprints;
1829 for(
FOOTPRINT* footprint : footprints )
1836 std::vector<FOOTPRINT*> footprints;
1841 for(
FOOTPRINT* footprint : footprints )
1842 footprint->SetParent(
nullptr );
1859 if(
group->m_Uuid == aID )
1865 if( generator->m_Uuid == aID )
1871 if( track->m_Uuid == aID )
1877 if( footprint->m_Uuid == aID )
1880 for(
PAD*
pad : footprint->Pads() )
1882 if(
pad->m_Uuid == aID )
1886 for(
PCB_FIELD* field : footprint->GetFields() )
1888 wxCHECK2( field,
continue );
1890 if( field && field->m_Uuid == aID )
1894 for(
BOARD_ITEM* drawing : footprint->GraphicalItems() )
1896 if( drawing->m_Uuid == aID )
1902 if( zone->m_Uuid == aID )
1908 if(
group->m_Uuid == aID )
1912 for(
PCB_POINT* point : footprint->Points() )
1914 if( point->m_Uuid == aID )
1921 if( zone->m_Uuid == aID )
1931 if( cell->m_Uuid == aID )
1936 if( drawing->m_Uuid == aID )
1942 if( marker->m_Uuid == aID )
1948 if( point->m_Uuid == aID )
1954 if( netInfo->m_Uuid == aID )
1959 return const_cast<BOARD*
>( this );
1962 if( aAllowNullptrReturn )
1978 if( item && item->
m_Uuid == aId )
2080 if( it->second == aItem )
2090 wxCHECK_RET( aItem,
"BOARD::RebindItemUuid() requires a valid item" );
2095 if( aItem->
m_Uuid == aNewId )
2103 wxFAIL_MSG( wxString::Format(
"BOARD::RebindItemUuid() duplicate target UUID: %s",
2122 wxCHECK2( aItem,
return );
2124 if( ids.count( aItem->m_Uuid ) )
2130 ids.insert( aItem->m_Uuid );
2136 processItem( footprint );
2142 for(
PAD*
pad : footprint->Pads() )
2147 processItem( track );
2152 processItem( &footprint->Reference() );
2153 processItem( &footprint->Value() );
2155 for(
BOARD_ITEM* item : footprint->GraphicalItems() )
2156 processItem( item );
2158 for(
ZONE* zone : footprint->Zones() )
2159 processItem( zone );
2162 processItem(
group );
2169 switch( item->Type() )
2178 processItem( item );
2193 aMap[track->m_Uuid] = track;
2197 aMap[footprint->m_Uuid] = footprint;
2199 for(
PAD*
pad : footprint->Pads() )
2202 aMap[footprint->Reference().m_Uuid] = &footprint->Reference();
2203 aMap[footprint->Value().m_Uuid] = &footprint->Value();
2205 for(
BOARD_ITEM* drawing : footprint->GraphicalItems() )
2206 aMap[drawing->m_Uuid] = drawing;
2210 aMap[zone->m_Uuid] = zone;
2213 aMap[drawing->m_Uuid] = drawing;
2216 aMap[marker->m_Uuid] = marker;
2222 aMap[point->m_Uuid] = point;
2225 aMap[generator->m_Uuid] = generator;
2232 size_t sourceLen = aSource.length();
2234 for(
size_t i = 0; i < sourceLen; ++i )
2238 if( aSource[i] ==
'\\' && i + 2 < sourceLen && aSource[i + 2] ==
'{' &&
2239 ( aSource[i + 1] ==
'$' || aSource[i + 1] ==
'@' ) )
2242 newbuf.append( aSource[i] );
2243 newbuf.append( aSource[i + 1] );
2244 newbuf.append( aSource[i + 2] );
2249 for( i = i + 1; i < sourceLen && braceDepth > 0; ++i )
2251 if( aSource[i] ==
'{' )
2253 else if( aSource[i] ==
'}' )
2256 newbuf.append( aSource[i] );
2262 if( aSource[i] ==
'$' && i + 1 < sourceLen && aSource[i + 1] ==
'{' )
2265 bool isCrossRef =
false;
2267 for( i = i + 2; i < sourceLen; ++i )
2269 if( aSource[i] ==
'}' )
2272 if( aSource[i] ==
':' )
2275 token.append( aSource[i] );
2281 wxString ref = token.BeforeFirst(
':', &remainder );
2285 if( footprint->GetReference().CmpNoCase( ref ) == 0 )
2287 wxString
test( remainder );
2289 if( footprint->ResolveTextVar( &
test ) )
2290 token = footprint->m_Uuid.AsString() + wxT(
":" ) + remainder;
2297 newbuf.append( wxT(
"${" ) + token + wxT(
"}" ) );
2301 newbuf.append( aSource[i] );
2312 size_t sourceLen = aSource.length();
2314 for(
size_t i = 0; i < sourceLen; ++i )
2318 if( aSource[i] ==
'\\' && i + 2 < sourceLen && aSource[i + 2] ==
'{' &&
2319 ( aSource[i + 1] ==
'$' || aSource[i + 1] ==
'@' ) )
2322 newbuf.append( aSource[i] );
2323 newbuf.append( aSource[i + 1] );
2324 newbuf.append( aSource[i + 2] );
2329 for( i = i + 1; i < sourceLen && braceDepth > 0; ++i )
2331 if( aSource[i] ==
'{' )
2333 else if( aSource[i] ==
'}' )
2336 newbuf.append( aSource[i] );
2342 if( aSource[i] ==
'$' && i + 1 < sourceLen && aSource[i + 1] ==
'{' )
2345 bool isCrossRef =
false;
2347 for( i = i + 2; i < sourceLen; ++i )
2349 if( aSource[i] ==
'}' )
2352 if( aSource[i] ==
':' )
2355 token.append( aSource[i] );
2361 wxString ref = token.BeforeFirst(
':', &remainder );
2366 token =
static_cast<FOOTPRINT*
>( refItem )->GetReference() + wxT(
":" ) + remainder;
2370 newbuf.append( wxT(
"${" ) + token + wxT(
"}" ) );
2374 newbuf.append( aSource[i] );
2384 unsigned retval = 0;
2388 for(
PAD*
pad : footprint->Pads() )
2390 if( ( aNet == -1 &&
pad->GetNetCode() > 0 ) || aNet ==
pad->GetNetCode() )
2404 if( aPhysicalLayersOnly )
2412 if( aBoardEdgesOnly )
2421 if( ( item->GetLayerSet() & visible ).any() )
2422 bbox.
Merge( item->GetBoundingBox() );
2428 if( aBoardEdgesOnly )
2430 for(
const BOARD_ITEM* edge : footprint->GraphicalItems() )
2433 bbox.
Merge( edge->GetBoundingBox() );
2436 else if( ( footprint->GetLayerSet() & visible ).any() )
2438 bbox.
Merge( footprint->GetBoundingBox(
true ) );
2442 if( !aBoardEdgesOnly )
2447 if( ( track->GetLayerSet() & visible ).any() )
2448 bbox.
Merge( track->GetBoundingBox() );
2454 if( ( aZone->GetLayerSet() & visible ).any() )
2455 bbox.
Merge( aZone->GetBoundingBox() );
2460 bbox.
Merge( point->GetBoundingBox() );
2472 int trackSegmentCount = 0;
2473 std::set<int> netCodes;
2481 trackSegmentCount++;
2483 if( item->GetNetCode() > 0 )
2484 netCodes.insert( item->GetNetCode() );
2489 for(
PAD*
pad : footprint->Pads() )
2493 if(
pad->GetNetCode() > 0 )
2494 netCodes.insert(
pad->GetNetCode() );
2498 aList.emplace_back(
_(
"Pads" ), wxString::Format( wxT(
"%d" ), padCount ) );
2499 aList.emplace_back(
_(
"Vias" ), wxString::Format( wxT(
"%d" ), viaCount ) );
2500 aList.emplace_back(
_(
"Track Segments" ), wxString::Format( wxT(
"%d" ), trackSegmentCount ) );
2501 aList.emplace_back(
_(
"Nets" ), wxString::Format( wxT(
"%d" ), (
int) netCodes.size() ) );
2502 aList.emplace_back(
_(
"Unrouted" ), wxString::Format( wxT(
"%d" ), unconnected ) );
2508#if 0 && defined( DEBUG )
2509 std::cout <<
GetClass().mb_str() <<
' ';
2512 bool footprintsScanned =
false;
2513 bool drawingsScanned =
false;
2514 bool tracksScanned =
false;
2516 for(
KICAD_T scanType : scanTypes )
2548 if( !footprintsScanned )
2555 footprintsScanned =
true;
2558 if( !drawingsScanned )
2565 drawingsScanned =
true;
2573 if( !tracksScanned )
2580 tracksScanned =
true;
2604 if( !footprintsScanned )
2611 footprintsScanned =
true;
2623 if( !footprintsScanned )
2630 footprintsScanned =
true;
2666 return m_NetInfo.GetNetItem( aNetcode );
2672 return m_NetInfo.GetNetItem( aNetname );
2681 for(
auto it = aNetName.rbegin(); it != aNetName.rend() && rv == 0; ++it, ++count )
2685 if( ( ch >=
'0' && ch <=
'9' ) || ch ==
'_' )
2689 else if( ch ==
'+' )
2691 aComplementNet = wxT(
"-" );
2694 else if( ch ==
'-' )
2696 aComplementNet = wxT(
"+" );
2699 else if( ch ==
'N' )
2701 aComplementNet = wxT(
"P" );
2704 else if( ch ==
'P' )
2706 aComplementNet = wxT(
"N" );
2715 if( rv != 0 && count >= 1 )
2717 aComplementNet = aNetName.Left( aNetName.length() - count ) + aComplementNet + aNetName.Right( count - 1 );
2729 wxString coupledNetName;
2732 return FindNet( coupledNetName );
2743 if( aReference == footprint->GetReference() )
2755 if( footprint->GetPath() == aPath )
2767 if(
PAD*
pad = footprint->FindPadByUuid( aUuid ) )
2781 if( net->GetNetChain() == aNetChain )
2783 for(
int i = 0; i < 2; ++i )
2785 PAD*
pad = net->GetTerminalPad( i );
2787 if(
pad &&
pad->m_Uuid == aPrev )
2788 net->SetTerminalPad( i, newPad );
2797 std::set<wxString> names;
2801 if( !net->GetNetname().IsEmpty() )
2802 names.insert( net->GetNetname() );
2817 const wxString& aVariantName )
2819 for(
const wxString&
name : aNames )
2821 if(
name.CmpNoCase( aVariantName ) == 0 )
2825 return wxEmptyString;
2841 if( actualName.IsEmpty() )
2863 if( aVariantName.IsEmpty()
2878 [&](
const wxString&
name )
2880 return name.CmpNoCase( aVariantName ) == 0;
2885 wxString actualName = *it;
2895 fp->DeleteVariant( actualName );
2906 [&](
const wxString&
name )
2908 return name.CmpNoCase( aOldName ) == 0;
2913 wxString actualOldName = *it;
2918 if( !existingName.IsEmpty() && existingName.CmpNoCase( actualOldName ) != 0 )
2921 if( actualOldName == aNewName )
2931 if( !descIt->second.IsEmpty() )
2943 fp->RenameVariant( actualOldName, aNewName );
2951 return wxEmptyString;
2955 if( actualName.IsEmpty() )
2956 return wxEmptyString;
2963 return wxEmptyString;
2974 if( actualName.IsEmpty() )
2977 if( aDescription.IsEmpty() )
2986 wxArrayString names;
3017 if( aResetTrackAndViaSizes )
3039 settings->GetComponentClassAssignments(), settings->GetEnableSheetComponentClasses(), aNewSheetPaths );
3045 int error_count = 0;
3049 if( !zone->IsOnCopperLayer() )
3055 if( zone->GetNetCode() != 0 )
3068 zone->SetNetCode( -1 );
3083 if( footprint->HitTest( aPosition ) )
3084 pad = footprint->GetPad( aPosition, aLayerSet.any() ? aLayerSet :
LSET::AllCuMask() );
3100 return GetPad( aPosition, lset );
3108 int idxmax = aPadList.size() - 1;
3110 int delta = aPadList.size();
3123 PAD*
pad = aPadList[idx];
3125 if(
pad->GetPosition() == aPosition )
3128 if( ( aLayerSet &
pad->GetLayerSet() ).any() )
3135 for(
int ii = idx + 1; ii <= idxmax; ii++ )
3139 if(
pad->GetPosition() != aPosition )
3142 if( ( aLayerSet &
pad->GetLayerSet() ).any() )
3146 for(
int ii = idx - 1; ii >= 0; ii-- )
3150 if(
pad->GetPosition() != aPosition )
3153 if( ( aLayerSet &
pad->GetLayerSet() ).any() )
3161 if(
pad->GetPosition().x == aPosition.
x )
3163 if(
pad->GetPosition().y < aPosition.
y )
3178 else if(
pad->GetPosition().x < aPosition.
x )
3216 for(
PAD*
pad : footprint->Pads() )
3218 if( aNetCode < 0 || pad->GetNetCode() == aNetCode )
3219 aVector.push_back(
pad );
3241 std::vector<LENGTH_DELAY_CALCULATION_ITEM> items;
3247 if( item.
Type() != LENGTH_DELAY_CALCULATION_ITEM::TYPE::UNKNOWN )
3248 items.push_back( std::move( item ) );
3252 .OptimiseVias =
true, .MergeTracks =
true, .OptimiseTracesInPads =
true, .InferViaInPad =
false
3264 bool aIgnoreLocked )
const
3268 int min_dim = 0x7FFFFFFF;
3269 int alt_min_dim = 0x7FFFFFFF;
3270 bool current_layer_back =
IsBackLayer( aActiveLayer );
3275 if( !candidate->HitTest( aPosition ) )
3279 if( aIgnoreLocked && candidate->IsLocked() )
3287 BOX2I bb = candidate->GetBoundingBox(
false );
3294 ( aPosition.
x - offx ) * ( aPosition.
x - offx ) + ( aPosition.
y - offy ) * ( aPosition.
y - offy );
3298 if( dist <= min_dim )
3301 footprint = candidate;
3307 if( dist <= alt_min_dim )
3310 alt_footprint = candidate;
3321 return alt_footprint;
3329 std::list<ZONE*> zones;
3332 zones.push_back( zone );
3334 if( aIncludeZonesInFootprints )
3338 for(
ZONE* zone : footprint->Zones() )
3339 zones.push_back( zone );
3355 m_zones.push_back( new_area );
3374 bool aIncludeNPTHAsOutlines )
3380 aInferOutlineIfNecessary, aErrorHandler, aAllowUseArcsInPolygons );
3383 if( aIncludeNPTHAsOutlines )
3387 for(
PAD*
pad : fp->Pads() )
3435 std::set<KIFONT::OUTLINE_FONT*>
fonts;
3448 if( permission == PERMISSION::EDITABLE || permission == PERMISSION::INSTALLABLE )
3449 fonts.insert( outlineFont );
3470 std::vector<PAD*> allPads;
3474 for(
PAD*
pad : footprint->Pads() )
3475 allPads.push_back(
pad );
3484 std::vector<BOARD_CONNECTED_ITEM*> items;
3487 items.push_back( track );
3491 for(
PAD*
pad : footprint->Pads() )
3492 items.push_back(
pad );
3494 for(
ZONE* zone : footprint->Zones() )
3495 items.push_back( zone );
3497 for(
BOARD_ITEM* dwg : footprint->GraphicalItems() )
3500 items.push_back( bci );
3505 items.push_back( zone );
3510 items.push_back( bci );
3524 item->SetNet( netInfo );
3528 aDestBoard->
Add( newNet );
3529 item->SetNet( newNet );
3539 if(
FindNet( item->GetNetCode() ) ==
nullptr )
3583 std::vector<BOARD_ITEM*>& aChangedItems )
3614 bool already =
m_highLight.m_netCodes.count( aNetCode );
3645 return wxEmptyString;
3664 std::unordered_set<EDA_GROUP*> knownCycleFreeGroups;
3666 std::unordered_set<EDA_GROUP*> currentChainGroups;
3668 std::unordered_set<EDA_GROUP*> toCheckGroups;
3672 toCheckGroups.insert(
group );
3675 toCheckGroups.insert( gen );
3677 while( !toCheckGroups.empty() )
3679 currentChainGroups.clear();
3684 if( currentChainGroups.find(
group ) != currentChainGroups.end() )
3689 return "Cycle detected in group membership";
3691 else if( knownCycleFreeGroups.find(
group ) != knownCycleFreeGroups.end() )
3697 currentChainGroups.insert(
group );
3699 toCheckGroups.erase(
group );
3701 group =
group->AsEdaItem()->GetParentGroup();
3712 knownCycleFreeGroups.insert( currentChainGroups.begin(), currentChainGroups.end() );
3743 if( aFirst->
Type() != aSecond->
Type() )
3744 return aFirst->
Type() < aSecond->
Type();
3753 return shape->
Compare( other ) < 0;
3759 return text->Compare( other ) < 0;
3766 int shapeCmp = textbox->PCB_SHAPE::Compare( other );
3769 return shapeCmp < 0;
3771 return textbox->EDA_TEXT::Compare( other ) < 0;
3800 if( !track->IsOnLayer( aLayer ) )
3803 track->TransformShapeToPolygon( aOutlines, aLayer, 0, maxError,
ERROR_INSIDE );
3809 footprint->TransformPadsToPolySet( aOutlines, aLayer, 0, maxError,
ERROR_INSIDE );
3811 footprint->TransformFPShapesToPolySet( aOutlines, aLayer, 0, maxError,
ERROR_INSIDE,
true,
3815 for(
const ZONE* zone : footprint->Zones() )
3817 if( zone->GetLayerSet().test( aLayer ) )
3818 zone->TransformSolidAreasShapesToPolygon( aLayer, aOutlines );
3825 if( zone->GetLayerSet().test( aLayer ) )
3826 zone->TransformSolidAreasShapesToPolygon( aLayer, aOutlines );
3832 if( !item->IsOnLayer( aLayer ) )
3835 switch( item->Type() )
3863 textbox->PCB_SHAPE::TransformShapeToPolygon( aOutlines, aLayer, 0, maxError,
ERROR_INSIDE );
3872 table->TransformGraphicItemsToPolySet( aOutlines, maxError,
ERROR_INSIDE, aRenderSettings );
3898 std::copy(
m_tracks.begin(),
m_tracks.end(), std::inserter( items, items.end() ) );
3899 std::copy(
m_zones.begin(),
m_zones.end(), std::inserter( items, items.end() ) );
3903 std::copy(
m_markers.begin(),
m_markers.end(), std::inserter( items, items.end() ) );
3904 std::copy(
m_groups.begin(),
m_groups.end(), std::inserter( items, items.end() ) );
3905 std::copy(
m_points.begin(),
m_points.end(), std::inserter( items, items.end() ) );
3925 const BOARD& other =
static_cast<const BOARD&
>( aItem );
3936 for(
auto it1 = thisNetNames.begin(), it2 = otherNetNames.begin();
3937 it1 != thisNetNames.end() && it2 != otherNetNames.end(); ++it1, ++it2 )
3941 if( it1->first != it2->first )
3976 wxArrayString ourVars;
3977 m_titles.GetContextualTextVars( &ourVars );
3979 wxArrayString otherVars;
3982 if( ourVars != otherVars )
4006 for(
PAD*
pad : footprint->Pads() )
4024 for(
PAD*
pad : footprint->Pads() )
4045 wxString projPath =
project->GetProjectPath();
4047 if( projPath.IsEmpty() )
4051 if( !projPath.IsSameAs( aProjectPath ) )
4053 wxLogTrace(
traceAutoSave, wxS(
"[history] pcb saver skipping - project path mismatch: %s vs %s" ), projPath,
4060 if( boardPath.IsEmpty() )
4064 if( !boardPath.StartsWith( projPath ) )
4066 wxLogTrace(
traceAutoSave, wxS(
"[history] pcb saver skipping - board not under project: %s" ), boardPath );
4070 wxString rel = boardPath.Mid( projPath.length() );
4085 entry.
formatMode = KICAD_FORMAT::FORMAT_MODE::COMPACT_TEXT_PROPERTIES;
4087 aFileData.push_back( std::move( entry ) );
4089 wxLogTrace(
traceAutoSave, wxS(
"[history] pcb saver serialized %zu bytes for '%s'" ),
4090 aFileData.back().content.size(), rel );
4094 wxLogTrace(
traceAutoSave, wxS(
"[history] pcb saver serialize failed: %s" ), wxString::FromUTF8( ioe.
What() ) );
constexpr EDA_IU_SCALE pcbIUScale
bool sortPadsByXthenYCoord(PAD *const &aLH, PAD *const &aRH)
Used by #GetSortedPadListByXCoord to sort a pad list by X coordinate value.
std::set< wxString >::iterator FindByFirstNFields(std::set< wxString > &strSet, const wxString &searchStr, char delimiter, int n)
static wxString FindVariantNameCaseInsensitive(const std::vector< wxString > &aNames, const wxString &aVariantName)
#define DEFAULT_CHAINING_EPSILON_MM
BOARD_USE
Flags to specify how the board is being used.
LAYER_T
The allowed types of layers, same as Specctra DSN spec.
std::set< BOARD_ITEM *, CompareByUuid > BOARD_ITEM_SET
Set of BOARD_ITEMs ordered by UUID.
static const ADVANCED_CFG & GetCfg()
Get the singleton instance's config, which is shared by all consumers.
BASE_SET & reset(size_t pos)
BASE_SET & set(size_t pos)
A base class derived from BOARD_ITEM for items that can be connected and have a net,...
PCB_LAYER_ID GetLayer() const override
Return the primary layer this item is on.
Container for design settings for a BOARD object.
void UseCustomTrackViaSize(bool aEnabled)
Enables/disables custom track/via size settings.
void SetCustomDiffPairWidth(int aWidth)
Sets custom track width for differential pairs (i.e.
void SetEnabledLayers(const LSET &aMask)
Change the bit-mask of enabled layers to aMask.
std::shared_ptr< NET_SETTINGS > m_NetSettings
void SetCustomTrackWidth(int aWidth)
Sets custom width for track (i.e.
void SetCustomViaSize(int aSize)
Set custom size for via diameter (i.e.
const LSET & GetEnabledLayers() const
Return a bit-mask of all the layers that are enabled.
void SetCustomDiffPairGap(int aGap)
Sets custom gap for differential pairs (i.e.
bool IsLayerEnabled(PCB_LAYER_ID aLayerId) const
Test whether a given layer aLayerId is enabled.
void SetUserDefinedLayerCount(int aNewLayerCount)
Set the number of user defined layers to aNewLayerCount.
BOARD_STACKUP & GetStackupDescriptor()
void SetCustomViaDrill(int aDrill)
Sets custom size for via drill (i.e.
int GetCopperLayerCount() const
int GetUserDefinedLayerCount() const
void SetCopperLayerCount(int aNewLayerCount)
Set the copper layer count to aNewLayerCount.
void SetCustomDiffPairViaGap(int aGap)
Sets custom via gap for differential pairs (i.e.
BOARD_ITEM_CONTAINER(BOARD_ITEM *aParent, KICAD_T aType)
BOARD_ITEM(BOARD_ITEM *aParent, KICAD_T idtype, PCB_LAYER_ID aLayer=F_Cu)
virtual PCB_LAYER_ID GetLayer() const
Return the primary layer this item is on.
void SetUuidDirect(const KIID &aUuid)
Raw UUID assignment.
virtual void SetLayerSet(const LSET &aLayers)
virtual void Move(const VECTOR2I &aMoveVector)
Move this object.
virtual bool IsOnLayer(PCB_LAYER_ID aLayer) const
Test to see if this object is on the given layer.
virtual const BOARD * GetBoard() const
Return the BOARD in which this BOARD_ITEM resides, or NULL if none.
FOOTPRINT * GetParentFootprint() const
virtual LSET GetLayerSet() const
Return a std::bitset of all layers on which the item physically resides.
static VECTOR2I ZeroOffset
A value of wxPoint(0,0) which can be passed to the Draw() functions.
wxString GetLayerName() const
Return the name of the PCB layer on which the item resides.
virtual void OnBoardNetSettingsChanged(BOARD &aBoard)
virtual void OnBoardRatsnestChanged(BOARD &aBoard)
virtual void OnBoardItemsAdded(BOARD &aBoard, std::vector< BOARD_ITEM * > &aBoardItems)
virtual void OnBoardItemChanged(BOARD &aBoard, BOARD_ITEM *aBoardItem)
virtual void OnBoardItemRemoved(BOARD &aBoard, BOARD_ITEM *aBoardItem)
virtual void OnBoardItemAdded(BOARD &aBoard, BOARD_ITEM *aBoardItem)
virtual void OnBoardHighlightNetChanged(BOARD &aBoard)
virtual void OnBoardItemsRemoved(BOARD &aBoard, std::vector< BOARD_ITEM * > &aBoardItems)
virtual void OnBoardCompositeUpdate(BOARD &aBoard, std::vector< BOARD_ITEM * > &aAddedItems, std::vector< BOARD_ITEM * > &aRemovedItems, std::vector< BOARD_ITEM * > &aChangedItems)
virtual void OnBoardItemsChanged(BOARD &aBoard, std::vector< BOARD_ITEM * > &aBoardItems)
Manage layers needed to make a physical board.
void BuildDefaultStackupList(const BOARD_DESIGN_SETTINGS *aSettings, int aActiveCopperLayersCount=0)
Create a default stackup, according to the current BOARD_DESIGN_SETTINGS settings.
INSPECT_RESULT Visit(INSPECTOR inspector, void *testData, const std::vector< KICAD_T > &scanTypes) override
May be re-implemented for each derived class in order to handle all the types given by its member dat...
ZONE * m_SolderMaskBridges
void GetContextualTextVars(wxArrayString *aVars) const
bool IsFootprintLayerVisible(PCB_LAYER_ID aLayer) const
Expect either of the two layers on which a footprint can reside, and returns whether that layer is vi...
BOARD_STACKUP GetStackupOrDefault() const
std::map< ZONE *, std::map< PCB_LAYER_ID, ISOLATED_ISLANDS > > m_ZoneIsolatedIslandsMap
PCB_LAYER_ID GetCopperLayerStackMaxId() const
void OnItemChanged(BOARD_ITEM *aItem)
Notify the board and its listeners that an item on the board has been modified in some way.
bool m_LegacyDesignSettingsLoaded
True if the legacy board design settings were loaded from a file.
bool IsFootprintHolder() const
Find out if the board is being used to hold a single footprint for editing/viewing.
PAD * GetPad(const VECTOR2I &aPosition, const LSET &aLayerMask) const
Find a pad aPosition on aLayer.
SHARDED_CACHE< PTR_PTR_LAYER_CACHE_KEY, bool > m_IntersectsAreaCache
int GetUserDefinedLayerCount() const
void SetPosition(const VECTOR2I &aPos) override
std::map< wxString, wxString > m_properties
void CacheItemById(BOARD_ITEM *aItem) const
Add an item to the item-by-id cache.
SHARDED_CACHE< ITEM_SELECTOR_LAYER_CACHE_KEY, bool > m_IntersectsCourtyardResultCache
std::unordered_map< const BOARD_ITEM *, wxString > m_ItemNetclassCache
EMBEDDED_FILES * GetEmbeddedFiles() override
SHARDED_CACHE< PTR_PTR_LAYER_CACHE_KEY, bool > m_EnclosedByAreaCache
int m_fileFormatVersionAtLoad
NETINFO_ITEM * DpCoupledNet(const NETINFO_ITEM *aNet)
void UncacheItemById(const KIID &aId) const
Remove an item from the item-by-id cache.
void SetCurrentVariant(const wxString &aVariant)
std::vector< ZONE * > m_DRCCopperZones
void SetVisibleLayers(const LSET &aLayerMask)
A proxy function that calls the correspondent function in m_BoardSettings changes the bit-mask of vis...
void Add(BOARD_ITEM *aItem, ADD_MODE aMode=ADD_MODE::INSERT, bool aSkipConnectivity=false) override
Removes an item from the container.
SHARDED_CACHE< ITEM_SELECTOR_LAYER_CACHE_KEY, bool > m_EnclosedByAreaResultCache
void MapNets(BOARD *aDestBoard)
Map all nets in the given board to nets with the same name (if any) in the destination board.
GAL_SET m_LegacyVisibleItems
std::vector< wxString > m_variantNames
LENGTH_DELAY_CALCULATION * GetLengthCalculation() const
Returns the track length calculator.
wxArrayString GetVariantNamesForUI() const
Return the variant names for UI display.
void RunOnNestedEmbeddedFiles(const std::function< void(EMBEDDED_FILES *)> &aFunction) override
Provide access to nested embedded files, such as symbols in schematics and footprints in boards.
const GENERATORS & Generators() const
static wxString GetStandardLayerName(PCB_LAYER_ID aLayerId)
Return an "English Standard" name of a PCB layer when given aLayerNumber.
const std::vector< BOARD_CONNECTED_ITEM * > AllConnectedItems()
bool IsElementVisible(GAL_LAYER_ID aLayer) const
Test whether a given element category is visible.
int m_outlinesChainingEpsilon
the max distance between 2 end point to see them connected when building the board outlines
std::tuple< int, double, double, double, double > GetTrackLength(const PCB_TRACK &aTrack) const
Return data on the length and number of track segments connected to a given track.
std::set< wxString > GetNetClassAssignmentCandidates() const
Return the set of netname candidates for netclass assignment.
BOARD_USE m_boardUse
What is this board being used for.
void RemoveAllListeners()
Remove all listeners.
SHARDED_CACHE< PTR_PTR_CACHE_KEY, bool > m_IntersectsBCourtyardCache
std::unique_ptr< BOARD_DESIGN_SETTINGS > m_designSettings
All of the board design settings are stored as a JSON object inside the project file.
void ConvertBrdLayerToPolygonalContours(PCB_LAYER_ID aLayer, SHAPE_POLY_SET &aOutlines, KIGFX::RENDER_SETTINGS *aRenderSettings=nullptr) const
Build a set of polygons which are the outlines of copper items (pads, tracks, vias,...
void AddListener(BOARD_LISTENER *aListener)
Add a listener to the board to receive calls whenever something on the board has been modified.
void UpdateUserUnits(BOARD_ITEM *aItem, KIGFX::VIEW *aView)
Update any references within aItem (or its descendants) to the user units.
void SetProperties(const std::map< wxString, wxString > &aProps)
bool IsBackLayer(PCB_LAYER_ID aLayer) const
GAL_SET GetVisibleElements() const
Return a set of all the element categories that are visible.
void SetHighLightNet(int aNetCode, bool aMulti=false)
Select the netcode to be highlighted.
void CompileRatsnest()
Rebuild the entire board ratsnest.
HIGH_LIGHT_INFO m_highLight
std::map< wxString, wxString > m_variantDescriptions
bool SetLayerDescr(PCB_LAYER_ID aIndex, const LAYER &aLayer)
Return the type of the copper layer given by aLayer.
NETINFO_ITEM * FindNet(int aNetcode) const
Search for a net with the given netcode.
void UpdateBoardOutline()
const ZONES & Zones() const
void BulkRemoveStaleTeardrops(BOARD_COMMIT &aCommit)
Remove all teardrop zones with the STRUCT_DELETED flag set.
void DeleteVariant(const wxString &aVariantName)
void InvokeListeners(Func &&aFunc, Args &&... args)
void SetDesignSettings(const BOARD_DESIGN_SETTINGS &aSettings)
const LSET & GetVisibleLayers() const
A proxy function that calls the correspondent function in m_BoardSettings.
void InitializeClearanceCache()
Initialize the clearance cache for all board items.
EMBEDDED_FILES * m_embeddedFilesDelegate
ZONE * AddArea(PICKED_ITEMS_LIST *aNewZonesList, int aNetcode, PCB_LAYER_ID aLayer, VECTOR2I aStartPointPosition, ZONE_BORDER_DISPLAY_STYLE aHatch)
Add an empty copper area to board areas list.
bool IsFrontLayer(PCB_LAYER_ID aLayer) const
const GROUPS & Groups() const
The groups must maintain the following invariants.
void SaveToHistory(const wxString &aProjectPath, std::vector< HISTORY_FILE_DATA > &aFileData)
Serialize board into HISTORY_FILE_DATA for non-blocking history commit.
bool BuildConnectivity(PROGRESS_REPORTER *aReporter=nullptr)
Build or rebuild the board connectivity database for the board, especially the list of connected item...
bool IsLayerEnabled(PCB_LAYER_ID aLayer) const
A proxy function that calls the correspondent function in m_BoardSettings tests whether a given layer...
LAYER_T GetLayerType(PCB_LAYER_ID aLayer) const
Return the type of the copper layer given by aLayer.
void RecordDRCExclusions()
Scan existing markers and record data from any that are Excluded.
void OnItemsCompositeUpdate(std::vector< BOARD_ITEM * > &aAddedItems, std::vector< BOARD_ITEM * > &aRemovedItems, std::vector< BOARD_ITEM * > &aChangedItems)
Notify the board and its listeners that items on the board have been modified in a composite operatio...
int SetAreasNetCodesFromNetNames()
Set the .m_NetCode member of all copper areas, according to the area Net Name The SetNetCodesFromNetN...
void SynchronizeNetsAndNetClasses(bool aResetTrackAndViaSizes)
Copy NETCLASS info to each NET, based on NET membership in a NETCLASS.
void ResetNetHighLight()
Reset all high light data to the init state.
SHARDED_CACHE< PTR_PTR_CACHE_KEY, bool > m_IntersectsCourtyardCache
bool SetLayerName(PCB_LAYER_ID aLayer, const wxString &aLayerName)
Changes the name of the layer given by aLayer.
std::list< ZONE * > GetZoneList(bool aIncludeZonesInFootprints=false) const
bool ResolveTextVar(wxString *token, int aDepth) const
const MARKERS & Markers() const
void UncacheChildrenById(const BOARD_ITEM *aParent)
PCB_LAYER_ID FlipLayer(PCB_LAYER_ID aLayer) const
const std::vector< PAD * > GetPads() const
Return a reference to a list of all the pads.
void Move(const VECTOR2I &aMoveVector) override
Move this object.
std::unique_ptr< class BOARD_TEXT_VAR_ADAPTER > m_textVarAdapter
TITLE_BLOCK & GetTitleBlock()
void FixupEmbeddedData()
After loading a file from disk, the footprints do not yet contain the full data for their embedded fi...
int GetMaxClearanceValue() const
Returns the maximum clearance value for any object on the board.
void InvalidateClearanceCache(const KIID &aUuid)
Invalidate the clearance cache for a specific item.
PAD * FindPadByUuid(const KIID &aUuid) const
std::unordered_map< const BOARD_ITEM *, KIID > m_cachedIdByItem
PCB_LAYER_ID GetLayerID(const wxString &aLayerName) const
Return the ID of a layer.
HIGH_LIGHT_INFO m_highLightPrevious
LSET m_LegacyVisibleLayers
Visibility settings stored in board prior to 6.0, only used for loading legacy files.
void SetVisibleAlls()
Change the bit-mask of visible element categories and layers.
bool HasVariant(const wxString &aVariantName) const
void AddVariant(const wxString &aVariantName)
int GetCopperLayerCount() const
std::vector< BOARD_LISTENER * > m_listeners
bool RemoveAllItemsOnLayer(PCB_LAYER_ID aLayer)
Removes all owned items other than footprints existing on the given board layer, and modifies the sta...
void IncrementTimeStamp()
int MatchDpSuffix(const wxString &aNetName, wxString &aComplementNet)
Fetch the coupled netname for a given net.
std::unique_ptr< LENGTH_DELAY_CALCULATION > m_lengthDelayCalc
const FOOTPRINTS & Footprints() const
std::shared_ptr< CONNECTIVITY_DATA > m_connectivity
std::set< KIFONT::OUTLINE_FONT * > GetFonts() const override
Get the list of all outline fonts used in the board.
void RemoveAll(std::initializer_list< KICAD_T > aTypes={ PCB_NETINFO_T, PCB_MARKER_T, PCB_GROUP_T, PCB_ZONE_T, PCB_GENERATOR_T, PCB_FOOTPRINT_T, PCB_TRACE_T, PCB_SHAPE_T })
An efficient way to remove all items of a certain type from the board.
const BOARD_ITEM_SET GetItemSet()
Collect every owned item (tracks, zones, generators, footprints, drawings, markers,...
const TRACKS & Tracks() const
int m_DRCMaxPhysicalClearance
FOOTPRINT * FindFootprintByPath(const KIID_PATH &aPath) const
Search for a FOOTPRINT within this board with the given path.
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.
std::unordered_map< wxString, LSET > m_LayerExpressionCache
BOARD_ITEM * GetCachedItemById(const KIID &aId) const
Return a cached item for aId if the entry is still self-consistent.
wxString GroupsSanityCheckInternal(bool repair)
std::shared_ptr< const FOOTPRINT_COURTYARD_INDEX > m_footprintCourtyardIndex
void OnRatsnestChanged()
Notify the board and its listeners that the ratsnest has been recomputed.
wxString ConvertCrossReferencesToKIIDs(const wxString &aSource) const
Convert cross-references back and forth between ${refDes:field} and ${kiid:field}.
wxString GetClass() const override
Return the class name.
std::unique_ptr< COMPONENT_CLASS_MANAGER > m_componentClassManager
SHARDED_CACHE< PTR_PTR_CACHE_KEY, bool > m_IntersectsFCourtyardCache
bool GetBoardPolygonOutlines(SHAPE_POLY_SET &aOutlines, bool aInferOutlineIfNecessary, OUTLINE_ERROR_HANDLER *aErrorHandler=nullptr, bool aAllowUseArcsInPolygons=false, bool aIncludeNPTHAsOutlines=false)
Extract the board outlines and build a closed polygon from lines, arcs and circle items on edge cut l...
bool m_LegacyNetclassesLoaded
True if netclasses were loaded from the file.
void SetCopperLayerCount(int aCount)
std::unordered_map< const ZONE *, BOX2I > m_ZoneBBoxCache
std::unordered_map< const ZONE *, SHAPE_POLY_SET > m_DeflatedZoneOutlineCache
SHARDED_CACHE< ITEM_SELECTOR_LAYER_CACHE_KEY, bool > m_IntersectsFCourtyardResultCache
TRACKS TracksInNet(int aNetCode)
Collect all the TRACKs and VIAs that are members of a net given by aNetCode.
void SetProject(PROJECT *aProject, bool aReferenceOnly=false)
Link a board to a given project.
FOOTPRINT * GetFootprint(const VECTOR2I &aPosition, PCB_LAYER_ID aActiveLayer, bool aVisibleOnly, bool aIgnoreLocked=false) const
Get a footprint by its bounding rectangle at aPosition on aLayer.
bool HasItemsOnLayer(PCB_LAYER_ID aLayer)
const wxString & GetFileName() const
bool operator==(const BOARD_ITEM &aOther) const override
std::vector< PCB_MARKER * > ResolveDRCExclusions(bool aCreateMarkers)
Rebuild DRC markers from the serialized data in BOARD_DESIGN_SETTINGS.
int GetPadWithCastellatedAttrCount()
wxString GetVariantDescription(const wxString &aVariantName) const
FOOTPRINT * FindFootprintByReference(const wxString &aReference) const
Search for a FOOTPRINT within this board with the given reference designator.
unsigned GetNodesCount(int aNet=-1) const
void FillItemMap(std::map< KIID, EDA_ITEM * > &aMap)
SHARDED_CACHE< ITEM_FIELD_CACHE_KEY, wxString > m_ItemFieldCache
std::map< PCB_LAYER_ID, std::vector< ZONE * > > m_DRCCopperZonesByLayer
void SetElementVisibility(GAL_LAYER_ID aLayer, bool aNewState)
Change the visibility of an element category.
std::shared_ptr< DRC_RTREE > m_CopperItemRTreeCache
bool SetLayerType(PCB_LAYER_ID aLayer, LAYER_T aLayerType)
Change the type of the layer given by aLayer.
const wxString GetLayerName(PCB_LAYER_ID aLayer) const
Return the name of a aLayer.
void DetachAllFootprints()
Remove all footprints without deleting.
std::map< int, LAYER > m_layers
wxString GetCurrentVariant() const
void RunOnChildren(const std::function< void(BOARD_ITEM *)> &aFunction, RECURSE_MODE aMode) const override
Invoke a function on all children.
int GetOutlinesChainingEpsilon()
void GetSortedPadListByXthenYCoord(std::vector< PAD * > &aVector, int aNetCode=-1) const
First empties then fills the vector with all pads and sorts them by increasing x coordinate,...
bool IsLayerVisible(PCB_LAYER_ID aLayer) const
A proxy function that calls the correspondent function in m_BoardSettings tests whether a given layer...
SHARDED_CACHE< ITEM_SELECTOR_LAYER_CACHE_KEY, bool > m_IntersectsAreaResultCache
void ReplaceNetChainTerminalPad(const wxString &aNetChain, const KIID &aPrev, const KIID &aNew)
void UncacheItemByPtr(const BOARD_ITEM *aItem)
Remove every cache entry that still points to aItem.
std::unordered_map< ZONE *, std::unique_ptr< DRC_RTREE > > m_CopperZoneRTreeCache
void FinalizeBulkAdd(std::vector< BOARD_ITEM * > &aNewItems)
Must be used if Add() is used using a BULK_x ADD_MODE to generate a change event for listeners.
wxString m_currentVariant
int LayerDepth(PCB_LAYER_ID aStartLayer, PCB_LAYER_ID aEndLayer) const
void DeleteAllFootprints()
Remove all footprints from the deque and free the memory associated with them.
PROJECT * GetProject() const
int GetPadWithPressFitAttrCount()
void GetMsgPanelInfo(EDA_DRAW_FRAME *aFrame, std::vector< MSG_PANEL_ITEM > &aList) override
Populate aList of MSG_PANEL_ITEM objects with it's internal state for display purposes.
wxString GetDesignRulesPath() const
Return the absolute path to the design rules file for this board.
wxString GroupsSanityCheck(bool repair=false)
Consistency check of internal m_groups structure.
void RenameVariant(const wxString &aOldName, const wxString &aNewName)
BOARD_DESIGN_SETTINGS & GetDesignSettings() const
std::vector< ZONE * > m_DRCZones
const LSET & GetEnabledLayers() const
A proxy function that calls the corresponding function in m_BoardSettings.
void UpdateRatsnestExclusions()
Update the visibility flags on the current unconnected ratsnest lines.
wxString ConvertKIIDsToCrossReferences(const wxString &aSource) const
void RebindItemUuid(BOARD_ITEM *aItem, const KIID &aNewId)
Rebind the UUID of an attached item and keep the item-by-id cache coherent.
int RepairDuplicateItemUuids()
Rebind duplicate attached-item UUIDs so each live board item has a unique ID.
void SynchronizeProperties()
Copy the current project's text variables into the boards property cache.
std::unordered_map< KIID, BOARD_ITEM * > m_itemByIdCache
void RemoveListener(BOARD_LISTENER *aListener)
Remove the specified listener.
std::shared_mutex m_CachesMutex
BOX2I ComputeBoundingBox(bool aBoardEdgesOnly=false, bool aPhysicalLayersOnly=false) const
Calculate the bounding box containing all board items (or board edge segments).
std::shared_ptr< const FOOTPRINT_COURTYARD_INDEX > GetFootprintCourtyardIndex()
Return a spatial index of footprint courtyards, building it on first use.
bool SynchronizeComponentClasses(const std::unordered_set< wxString > &aNewSheetPaths) const
Copy component class / component class generator information from the project settings.
BOARD_ITEM * CacheAndReturnItemById(const KIID &aId, BOARD_ITEM *aItem) const
void DeleteMARKERs()
Delete all MARKERS from the board.
void Remove(BOARD_ITEM *aBoardItem, REMOVE_MODE aMode=REMOVE_MODE::NORMAL) override
Removes an item from the container.
std::unordered_map< wxString, std::vector< ZONE * > > m_ZonesByNameCache
std::optional< int > m_maxClearanceValue
void HighLightON(bool aValue=true)
Enable or disable net highlighting.
void SetEnabledLayers(const LSET &aLayerMask)
A proxy function that calls the correspondent function in m_BoardSettings.
void CacheChildrenById(const BOARD_ITEM *aParent)
void SynchronizeTuningProfileProperties()
Ensure that all time domain properties providers are in sync with current settings.
BOARD_ITEM * ResolveItem(const KIID &aID, bool aAllowNullptrReturn=false) const
bool m_LegacyCopperEdgeClearanceLoaded
void OnItemsChanged(std::vector< BOARD_ITEM * > &aItems)
Notify the board and its listeners that an item on the board has been modified in some way.
SHARDED_CACHE< ITEM_SELECTOR_LAYER_CACHE_KEY, bool > m_IntersectsBCourtyardResultCache
std::shared_ptr< CONNECTIVITY_DATA > GetConnectivity() const
Return a list of missing connections between components/tracks.
VECTOR2I GetPosition() const override
void SetVariantDescription(const wxString &aVariantName, const wxString &aDescription)
void CacheTriangulation(PROGRESS_REPORTER *aReporter=nullptr, const std::vector< ZONE * > &aZones={})
void SetVisibleElements(const GAL_SET &aMask)
A proxy function that calls the correspondent function in m_BoardSettings.
void EmbedFonts() override
Finds all fonts used in the board and embeds them in the file if permissions allow.
PCB_BOARD_OUTLINE * m_boardOutline
void SetUserDefinedLayerCount(int aCount)
const DRAWINGS & Drawings() const
wxString GetItemDescription(UNITS_PROVIDER *aUnitsProvider, bool aFull) const override
Return a user-visible description string of this item.
constexpr coord_type GetY() const
constexpr size_type GetWidth() const
constexpr coord_type GetX() const
constexpr BOX2< Vec > & Merge(const BOX2< Vec > &aRect)
Modify the position and size of the rectangle in order to contain aRect.
constexpr size_type GetHeight() 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
void SetVisible(bool aVisible)
std::shared_ptr< const CN_ANCHOR > GetTargetNode() const
int GetCount() const
Return the number of objects in the list.
COMMIT & Removed(EDA_ITEM *aItem, BASE_SCREEN *aScreen=nullptr)
A class to manage Component Classes in a board context.
void RecalculateRatsnest(BOARD_COMMIT *aCommit=nullptr)
Function RecalculateRatsnest() Updates the ratsnest for the board.
void RunOnUnconnectedEdges(std::function< bool(CN_EDGE &)> aFunc)
unsigned int GetUnconnectedCount(bool aVisibileOnly) const
static DELETED_BOARD_ITEM * GetInstance()
The base class for create windows for drawing purpose.
A set of EDA_ITEMs (i.e., without duplicates).
virtual VECTOR2I GetPosition() const
virtual void ClearEditFlags()
void SetFlags(EDA_ITEM_FLAGS aMask)
virtual EDA_GROUP * GetParentGroup() const
KICAD_T Type() const
Returns the type of object.
static INSPECT_RESULT IterateForward(std::deque< T > &aList, INSPECTOR inspector, void *testData, const std::vector< KICAD_T > &scanTypes)
This changes first parameter to avoid the DList and use the main queue instead.
virtual INSPECT_RESULT Visit(INSPECTOR inspector, void *testData, const std::vector< KICAD_T > &aScanTypes)
May be re-implemented for each derived class in order to handle all the types given by its member dat...
bool HasFlag(EDA_ITEM_FLAGS aFlag) const
virtual void SetParent(EDA_ITEM *aParent)
EDA_ITEM(EDA_ITEM *parent, KICAD_T idType, bool isSCH_ITEM=false, bool isBOARD_ITEM=false)
int Compare(const EDA_SHAPE *aOther) const
A mix-in class (via multiple inheritance) that handles texts such as labels, parts,...
EMBEDDED_FILE * GetEmbeddedFile(const wxString &aName) const
Returns the embedded file with the given name or nullptr if it does not exist.
EMBEDDED_FILE * AddFile(const wxFileName &aName, bool aOverwrite)
Load a file from disk and adds it to the collection.
const std::map< wxString, EMBEDDED_FILE * > & EmbeddedFileMap() const
Helper for storing and iterating over GAL_LAYER_IDs.
static GAL_SET DefaultVisible()
static const std::vector< KICAD_T > BoardLevelItems
A scan list for all primary board items, omitting items which are subordinate to a FOOTPRINT,...
static const std::vector< KICAD_T > Tracks
A scan list for only TRACKs and ARCs.
Hold an error message and may be used when throwing exceptions containing meaningful error messages.
virtual const wxString What() const
A composite of Problem() and Where()
FONT is an abstract base class for both outline and stroke fonts.
virtual bool IsOutline() const
Class OUTLINE_FONT implements outline font drawing.
EMBEDDING_PERMISSION GetEmbeddingPermission() const
Container for all the knowledge about how graphical objects are drawn on any output surface/device.
bool IsBOARD_ITEM() const
virtual wxString GetClass() const =0
Return the class name.
Hold a (potentially large) number of VIEW_ITEMs and renders them on a graphics device provided by the...
virtual void Update(const VIEW_ITEM *aItem, int aUpdateFlags) const
For dynamic VIEWs, inform the associated VIEW that the graphical representation of this item has chan...
wxString AsString() const
Lightweight class which holds a pad, via, or a routed trace outline.
TYPE Type() const
Gets the routing item type.
Class which calculates lengths (and associated routing statistics) in a BOARD context.
LENGTH_DELAY_STATS CalculateLengthDetails(std::vector< LENGTH_DELAY_CALCULATION_ITEM > &aItems, PATH_OPTIMISATIONS aOptimisations, const PAD *aStartPad=nullptr, const PAD *aEndPad=nullptr, LENGTH_DELAY_LAYER_OPT aLayerOpt=LENGTH_DELAY_LAYER_OPT::NO_LAYER_DETAIL, LENGTH_DELAY_DOMAIN_OPT aDomain=LENGTH_DELAY_DOMAIN_OPT::NO_DELAY_DETAIL, LENGTH_DELAY_ITEM_DETAILS *aPerItemLengthDelays=nullptr) const
Calculates the electrical length of the given items.
LENGTH_DELAY_CALCULATION_ITEM GetLengthCalculationItem(const BOARD_CONNECTED_ITEM *aBoardItem) const
Return a LENGTH_CALCULATION_ITEM constructed from the given BOARD_CONNECTED_ITEM.
LSET is a set of PCB_LAYER_IDs.
static LSET AllCuMask(int aCuLayerCount)
Return a mask holding the requested number of Cu PCB_LAYER_IDs.
static const LSET & AllLayersMask()
static const LSET & PhysicalLayersMask()
Return a mask holding all layers which are physically realized.
std::shared_ptr< RC_ITEM > GetRCItem() const
void SetExcluded(bool aExcluded, const wxString &aComment=wxEmptyString)
void SetParent(JSON_SETTINGS *aParent, bool aLoadFromFile=true)
static const char Default[]
the name of the default NETCLASS
void SetDescription(const wxString &aDesc)
Handle the data for a net.
wxString GetClass() const override
Return the class name.
const wxString & GetNetname() const
static const int UNCONNECTED
Constant that holds the "unconnected net" number (typically 0) all items "connected" to this net are ...
static const int ORPHANED
Constant that forces initialization of a netinfo item to the NETINFO_ITEM ORPHANED (typically -1) whe...
static NETINFO_ITEM * OrphanedItem()
NETINFO_ITEM meaning that there was no net assigned for an item, as there was no board storing net li...
unsigned GetNetCount() const
const NETNAMES_MAP & NetsByName() const
Return the name map, at least for python.
void ClearAllCaches()
Clears the effective netclass cache for all nets.
std::shared_ptr< NETCLASS > GetEffectiveNetClass(const wxString &aNetName)
Fetches the effective (may be aggregate) netclass for the given net name.
std::shared_ptr< NETCLASS > GetDefaultNetclass() const
Gets the default netclass for the project.
void SetDefaultNetclass(std::shared_ptr< NETCLASS > netclass)
Sets the default netclass for the project Calling user is responsible for resetting the effective net...
VECTOR2I GetPosition() const override
const VECTOR2D & GetSizeMils() const
wxPrintOrientation GetWxOrientation() const
static double GetCustomHeightMils()
wxPaperSize GetPaperId() const
static double GetCustomWidthMils()
static int Compare(const PCB_BARCODE *aBarcode, const PCB_BARCODE *aOther)
void TransformShapeToPolygon(SHAPE_POLY_SET &aBuffer, PCB_LAYER_ID aLayer, int aClearance, int aMaxError, ERROR_LOC aErrorLoc=ERROR_INSIDE, bool ignoreLineWidth=false) const override
Convert the barcode (text + symbol shapes) to polygonal geometry suitable for filling/collision tests...
void TransformShapeToPolygon(SHAPE_POLY_SET &aBuffer, PCB_LAYER_ID aLayer, int aClearance, int aError, ERROR_LOC aErrorLoc, bool aIgnoreLineWidth=false) const override
Convert the item shape to a closed polygon.
DIM_UNITS_MODE GetUnitsMode() const
A set of BOARD_ITEMs (i.e., without duplicates).
A #PLUGIN derivation for saving and loading Pcbnew s-expression formatted files.
void FormatBoardToFormatter(OUTPUTFORMATTER *aOut, BOARD *aBoard, const std::map< std::string, UTF8 > *aProperties=nullptr)
Serialize a BOARD to an OUTPUTFORMATTER without file I/O or Prettify.
Collect all BOARD_ITEM objects on a given layer.
void Collect(BOARD_ITEM *aBoard, const std::vector< KICAD_T > &aTypes)
Test a BOARD_ITEM using this class's Inspector method, which does the collection.
void SetLayerId(PCB_LAYER_ID aLayerId)
static PCB_MARKER * DeserializeFromString(const wxString &data)
A PCB_POINT is a 0-dimensional point that is used to mark a position on a PCB, or more usually a foot...
void TransformShapeToPolygon(SHAPE_POLY_SET &aBuffer, PCB_LAYER_ID aLayer, int aClearance, int aError, ERROR_LOC aErrorLoc, bool ignoreLineWidth=false) const override
Convert the shape to a closed polygon.
static int Compare(const PCB_TABLE *aTable, const PCB_TABLE *aOther)
void TransformTextToPolySet(SHAPE_POLY_SET &aBuffer, int aClearance, int aMaxError, ERROR_LOC aErrorLoc) const
Function TransformTextToPolySet Convert the text to a polygonSet describing the actual character stro...
void TransformTextToPolySet(SHAPE_POLY_SET &aBuffer, int aClearance, int aMaxError, ERROR_LOC aErrorLoc) const
Function TransformTextToPolySet Convert the text to a polygonSet describing the actual character stro...
const VECTOR2I & GetEndPoint(ENDPOINT_T aEndPoint) const
Return the selected endpoint (start or end)
A holder to handle information on schematic or board items.
void PushItem(const ITEM_PICKER &aItem)
Push aItem to the top of the list.
A progress reporter interface for use in multi-threaded environments.
virtual bool IsCancelled() const =0
virtual bool KeepRefreshing(bool aWait=false)=0
Update the UI (if any).
virtual void Report(const wxString &aMessage)=0
Display aMessage in the progress bar dialog.
virtual void AdvanceProgress()=0
Increment the progress bar length (inside the current virtual zone).
The backing store for a PROJECT, in JSON format.
std::shared_ptr< COMPONENT_CLASS_SETTINGS > & ComponentClassSettings()
Container for project specific data.
virtual const wxString GetProjectName() const
Return the short name of the project.
virtual PROJECT_FILE & GetProjectFile() const
std::vector< KIID > GetIDs() const
Represent a set of closed polygons.
void Simplify()
Simplify the polyset (merges overlapping polys, eliminates degeneracy/self-intersections)
int OutlineCount() const
Return the number of outlines in the set.
void BooleanSubtract(const SHAPE_POLY_SET &b)
Perform boolean polyset difference.
std::function< void(std::function< void()>)> TASK_SUBMITTER
Callback that submits a unit of work for asynchronous execution.
const wxString & GetComment(int aIdx) const
static void GetContextualTextVars(wxArrayString *aVars)
Handle a list of polygons defining a copper zone.
virtual void SetLayer(PCB_LAYER_ID aLayer) override
Set the layer this item is on.
void SetHatchStyle(ZONE_BORDER_DISPLAY_STYLE aStyle)
bool SetNetCode(int aNetCode, bool aNoAssert) override
Override that clamps the netcode to 0 when this zone is in copper-thieving fill mode.
bool IsTeardropArea() const
bool AppendCorner(VECTOR2I aPosition, int aHoleIdx, bool aAllowDuplication=false)
Add a new corner to the zone outline (to the main outline or a hole)
bool BuildBoardPolygonOutlines(BOARD *aBoard, SHAPE_POLY_SET &aOutlines, int aErrorMax, int aChainingEpsilon, bool aInferOutlineIfNecessary, OUTLINE_ERROR_HANDLER *aErrorHandler, bool aAllowUseArcsInPolygons)
Extract the board outlines and build a closed polygon from lines, arcs and circle items on edge cut l...
const std::function< void(const wxString &msg, BOARD_ITEM *itemA, BOARD_ITEM *itemB, const VECTOR2I &pt)> OUTLINE_ERROR_HANDLER
static bool empty(const wxTextEntryBase *aCtrl)
const INSPECTOR_FUNC & INSPECTOR
std::function passed to nested users by ref, avoids copying std::function.
std::function< INSPECT_RESULT(EDA_ITEM *aItem, void *aTestData) > INSPECTOR_FUNC
Used to inspect and possibly collect the (search) results of iterating over a list or tree of KICAD_T...
#define STRUCT_DELETED
flag indication structures to be erased
static const std::string DesignRulesFileExtension
const wxChar *const traceAutoSave
Flag to enable auto save feature debug tracing.
bool IsCopperLayer(int aLayerId)
Test whether a layer is a copper layer.
GAL_LAYER_ID
GAL layers are "virtual" layers, i.e.
@ LAYER_FOOTPRINTS_FR
Show footprints on front.
@ GAL_LAYER_ID_BITMASK_END
This is the end of the layers used for visibility bit masks in legacy board files.
@ LAYER_FOOTPRINTS_BK
Show footprints on back.
PCB_LAYER_ID
A quick note on layer IDs:
#define GAL_LAYER_INDEX(x)
Use this macro to convert a GAL layer to a 0-indexed offset from LAYER_VIAS.
PCB_LAYER_ID ToLAYER_ID(int aLayer)
bool contains(const _Container &__container, _Value __value)
Returns true if the container contains the given value.
std::map< wxString, NETINFO_ITEM * > NETNAMES_MAP
@ NPTH
like PAD_PTH, but not plated mechanical use only, no connection allowed
@ PRESSFIT
a PTH with a hole diameter with tight tolerances for press fit pin
@ CASTELLATED
a pad with a castellated through hole
BARCODE class definition.
Class to handle a set of BOARD_ITEMs.
std::deque< PCB_TRACK * > TRACKS
Class that computes missing connections on a PCB.
wxString GetDefaultVariantName()
int SortVariantNames(const wxString &aLhs, const wxString &aRhs)
bool operator()(const BOARD_ITEM *aFirst, const BOARD_ITEM *aSecond) const
bool operator()(const BOARD_ITEM *aFirst, const BOARD_ITEM *aSecond) const
std::vector< char > decompressedData
std::string compressedEncodedData
Data produced by a registered saver on the UI thread, consumed by either the background local-history...
std::string content
Serialized content (mutually exclusive with sourcePath)
KICAD_FORMAT::FORMAT_MODE formatMode
wxString relativePath
Destination path relative to the project root.
Container to hold information pertinent to a layer of a BOARD.
static LAYER_T ParseType(const char *aType)
Convert a string to a LAYER_T.
static const char * ShowType(LAYER_T aType)
Convert a LAYER_T enum to a string representation of the layer type.
Holds length measurement result details and statistics.
Struct to control which optimisations the length calculation code runs on the given path objects.
static const long long MM
std::vector< std::vector< std::string > > table
thread_pool & GetKiCadThreadPool()
Get a reference to the current thread pool.
BS::priority_thread_pool thread_pool
wxLogTrace helper definitions.
KICAD_T
The set of class identification values stored in EDA_ITEM::m_structType.
@ PCB_SHAPE_T
class PCB_SHAPE, a segment not on copper layers
@ PCB_DIM_ORTHOGONAL_T
class PCB_DIM_ORTHOGONAL, a linear dimension constrained to x/y
@ PCB_DIM_LEADER_T
class PCB_DIM_LEADER, a leader dimension (graphic item)
@ PCB_GENERATOR_T
class PCB_GENERATOR, generator on a layer
@ PCB_VIA_T
class PCB_VIA, a via (like a track segment on a copper layer)
@ PCB_DIM_CENTER_T
class PCB_DIM_CENTER, a center point marking (graphic item)
@ PCB_GROUP_T
class PCB_GROUP, a set of BOARD_ITEMs
@ PCB_TEXTBOX_T
class PCB_TEXTBOX, wrapped text on a layer
@ PCB_ZONE_T
class ZONE, a copper pour area
@ PCB_TEXT_T
class PCB_TEXT, text on a layer
@ PCB_REFERENCE_IMAGE_T
class PCB_REFERENCE_IMAGE, bitmap on a layer
@ PCB_FIELD_T
class PCB_FIELD, text associated with a footprint property
@ PCB_MARKER_T
class PCB_MARKER, a marker used to show something
@ PCB_BARCODE_T
class PCB_BARCODE, a barcode (graphic item)
@ PCB_TARGET_T
class PCB_TARGET, a target (graphic item)
@ PCB_TABLECELL_T
class PCB_TABLECELL, PCB_TEXTBOX for use in tables
@ PCB_FOOTPRINT_T
class FOOTPRINT, a footprint
@ PCB_DIM_ALIGNED_T
class PCB_DIM_ALIGNED, a linear dimension (graphic item)
@ PCB_PAD_T
class PAD, a pad in a footprint
@ PCB_ARC_T
class PCB_ARC, an arc track segment on a copper layer
@ PCB_TABLE_T
class PCB_TABLE, table of PCB_TABLECELLs
@ PCB_NETINFO_T
class NETINFO_ITEM, a description of a net
@ PCB_POINT_T
class PCB_POINT, a 0-dimensional point
@ PCB_TRACE_T
class PCB_TRACK, a track segment (segment on a copper layer)
@ PCB_DIM_RADIAL_T
class PCB_DIM_RADIAL, a radius or diameter dimension
VECTOR2< int32_t > VECTOR2I
ZONE_BORDER_DISPLAY_STYLE
Zone border styles.