25#include <wx/mstream.h>
72using namespace PCB_KEYS_T;
97 THROW_IO_ERROR( wxString::Format(
_(
"Cannot create footprint library '%s'." ),
103 THROW_IO_ERROR( wxString::Format(
_(
"Footprint library '%s' is read only." ),
110 std::unique_ptr<FOOTPRINT>& footprint = fpCacheEntry->
GetFootprint();
112 if( aFootprintFilter && footprint.get() != aFootprintFilter )
117 if( footprint->GetAreFontsEmbedded() )
118 footprint->EmbedFonts();
120 footprint->GetEmbeddedFiles()->ClearEmbeddedFonts();
133 m_owner->SetOutputFormatter( &formatter );
134 m_owner->Format( footprint.get() );
145 if( !aFootprintFilter )
157 if( !dir.IsOpened() )
159 wxString msg = wxString::Format(
_(
"Footprint library '%s' not found." ),
171 if( dir.GetFirst( &fullName, fileSpec ) )
186 wxString fpName = fn.
GetName();
197 if( !cacheError.IsEmpty() )
198 cacheError += wxT(
"\n\n" );
200 cacheError += wxString::Format(
_(
"Warning in file '%s'" ) +
'\n',
202 cacheError += warning;
207 if( !cacheError.IsEmpty() )
208 cacheError += wxT(
"\n\n" );
210 cacheError += wxString::Format(
_(
"Unable to read file '%s'" ) +
'\n',
212 cacheError += ioe.
What();
214 }
while( dir.GetNext( &fullName ) );
218 if( !cacheError.IsEmpty() )
230 wxString msg = wxString::Format(
_(
"Library '%s' has no footprint '%s'." ),
237 wxString fullPath = it->second->GetFileName().GetFullPath();
239 wxRemoveFile( fullPath );
256 footprint.second->SetFilePath( aPath );
297 const std::map<std::string, UTF8>* aProperties )
304 _(
"Internal Group Data Error" ), wxICON_ERROR,
305 wxString::Format(
_(
"Please report this bug. Error validating group "
306 "structure: %s\n\nSave anyway?" ), sanityResult ),
307 _(
"Save Anyway" ) ) )
320 const std::map<std::string, UTF8>* aProperties )
328 if(
m_board->GetAreFontsEmbedded() )
331 m_board->GetEmbeddedFiles()->ClearEmbeddedFonts();
335 m_out->Print(
"(kicad_pcb (version %d) (generator \"pcbnew\") (generator_version %s)",
349 std::string input =
TO_UTF8( aClipboardSourceInput );
356 return parser.
Parse();
370 switch( aItem->
Type() )
405 format(
static_cast<const PAD*
>( aItem ) );
447 wxFAIL_MSG( wxT(
"Cannot format item " ) + aItem->
GetClass() );
503 return KiROUND( aValue / avg );
509 m_out->Print(
"(layer %s %s)",
511 aIsKnockout ?
"knockout" :
"" );
518 m_out->Print(
"(pts" );
520 for(
int ii = 0; ii < outline.
PointCount(); ++ii )
526 m_out->Print(
"(xy %s)",
532 m_out->Print(
"(arc (start %s) (mid %s) (end %s))",
556 m_out->Print(
"(render_cache %s %s",
557 m_out->Quotew( resolvedText ).c_str(),
566 m_out->Print(
"(polygon" );
572 callback_gal.DrawGlyphs( *cache );
581 m_out->Print(
"(setup" );
591 m_out->Print(
"(pad_to_mask_clearance %s)",
596 m_out->Print(
"(solder_mask_min_width %s)",
602 m_out->Print(
"(pad_to_paste_clearance %s)",
608 m_out->Print(
"(pad_to_paste_clearance_ratio %s)",
615 m_out->Print( 0,
" (tenting " );
618 m_out->Print( 0,
")" );
620 m_out->Print( 0,
" (covering " );
623 m_out->Print( 0,
")" );
625 m_out->Print( 0,
" (plugging " );
628 m_out->Print( 0,
")" );
636 m_out->Print( 0,
" (zone_defaults" );
639 format( properties, 0, layer );
641 m_out->Print( 0,
")\n" );
648 m_out->Print(
"(aux_axis_origin %s %s)",
657 m_out->Print(
"(grid_origin %s %s)",
672 m_out->Print(
"(general" );
674 m_out->Print(
"(thickness %s)",
688 m_out->Print(
"(layers" );
694 m_out->Print(
"(%d %s %s %s)",
700 :
m_out->Quotew(
m_board->GetLayerName( layer ) ).c_str() );
709 bool print_type =
false;
723 m_out->Print(
"(%d %s %s %s)",
731 :
m_out->Quotew(
m_board->GetLayerName( layer ) ).c_str() );
740 for(
const std::pair<const wxString, wxString>& prop : aBoard->
GetProperties() )
742 m_out->Print(
"(property %s %s)",
743 m_out->Quotew( prop.first ).c_str(),
744 m_out->Quotew( prop.second ).c_str() );
753 if( variantNames.empty() )
756 m_out->Print(
"(variants" );
758 for(
const wxString& variantName : variantNames )
760 m_out->Print(
"(variant (name %s)",
m_out->Quotew( variantName ).c_str() );
764 if( !description.IsEmpty() )
765 m_out->Print(
"(description %s)",
m_out->Quotew( description ).c_str() );
810 m_out->Print(
"(teardrops (best_length_ratio %s) (max_length %s) (best_width_ratio %s) "
819 m_out->Print(
"(filter_ratio %s)",
831 std::set<BOARD_ITEM*, BOARD_ITEM::ptr_cmp> sorted_footprints( aBoard->
Footprints().begin(),
833 std::set<BOARD_ITEM*, BOARD::cmp_drawings> sorted_drawings( aBoard->
Drawings().begin(),
835 std::set<PCB_TRACK*, PCB_TRACK::cmp_tracks> sorted_tracks( aBoard->
Tracks().begin(),
837 std::set<PCB_POINT*, PCB_POINT::cmp_points> sorted_points( aBoard->
Points().begin(),
839 std::set<BOARD_ITEM*, BOARD_ITEM::ptr_cmp> sorted_zones( aBoard->
Zones().begin(),
840 aBoard->
Zones().end() );
841 std::set<BOARD_ITEM*, BOARD_ITEM::ptr_cmp> sorted_groups( aBoard->
Groups().begin(),
843 std::set<BOARD_ITEM*, BOARD_ITEM::ptr_cmp> sorted_generators( aBoard->
Generators().begin(),
848 for(
BOARD_ITEM* footprint : sorted_footprints )
866 for(
auto zone : sorted_zones )
880 std::vector<NETINFO_ITEM*> nets;
881 PAD* pads[2] = {
nullptr,
nullptr };
885 auto cmp = [](
const wxString& a,
const wxString& b )
890 std::map<wxString, CHAIN_INFO,
decltype( cmp )> chains( cmp );
897 if( net->GetNetChain().IsEmpty() && !net->GetTerminalPad( 0 ) && !net->GetTerminalPad( 1 ) )
900 wxString chainName = net->GetNetChain();
902 if( chainName.IsEmpty() && ( net->GetTerminalPad( 0 ) || net->GetTerminalPad( 1 ) ) )
903 chainName = net->GetNetname();
905 CHAIN_INFO&
info = chains[chainName];
906 info.nets.push_back( net );
907 for(
int i = 0; i < 2; ++i )
909 if( net->GetTerminalPad( i ) && !
info.pads[i] )
910 info.pads[i] = net->GetTerminalPad( i );
915 for(
const auto&
kv : chains )
917 const CHAIN_INFO& si =
kv.second;
918 const wxString& chainName =
kv.first;
920 if( si.nets.size() > 1 || si.pads[0] || si.pads[1] || !chainName.IsEmpty() )
926 m_out->Print(
"(net_chains" );
927 for(
const auto&
kv : chains )
929 const wxString&
name =
kv.first;
930 const CHAIN_INFO& si =
kv.second;
932 if( si.nets.size() == 1 && !si.pads[0] && !si.pads[1] &&
name.IsEmpty() )
935 m_out->Print(
" (net_chain (name %s)",
m_out->Quotew(
name ).c_str() );
936 m_out->Print(
" (members" );
943 for(
int i = 0; i < 2; ++i )
946 m_out->Print(
" (terminal_pad %s)",
947 m_out->Quotew( si.pads[i]->m_Uuid.AsString() ).c_str() );
961 files_to_write.
AddFile( file.second );
968 files_to_write.
AddFile( file.second );
971 m_out->Print(
"(embedded_fonts %s)",
974 if( !files_to_write.
IsEmpty() )
990 m_out->Print(
"(dimension" );
994 m_out->Print(
"(type orthogonal)" );
996 m_out->Print(
"(type aligned)" );
998 m_out->Print(
"(type leader)" );
1000 m_out->Print(
"(type center)" );
1002 m_out->Print(
"(type radial)" );
1004 wxFAIL_MSG( wxT(
"Cannot format unknown dimension type!" ) );
1013 m_out->Print(
"(pts (xy %s %s) (xy %s %s))",
1024 m_out->Print(
"(leader_length %s)",
1029 m_out->Print(
"(orientation %d)",
static_cast<int>(
ortho->GetOrientation() ) );
1033 m_out->Print(
"(format (prefix %s) (suffix %s) (units %d) (units_format %d) (precision %d)",
1042 m_out->Print(
"(override_value %s)",
1049 m_out->Print(
")" );
1052 m_out->Print(
"(style (thickness %s) (arrow_length %s) (text_position_mode %d)",
1057 if(
ortho || aligned )
1062 m_out->Print(
"(arrow_direction outward)" );
1065 m_out->Print(
"(arrow_direction inward)" );
1073 m_out->Print(
"(extension_height %s)",
1080 m_out->Print(
"(extension_offset %s)",
1086 m_out->Print(
")" );
1093 m_out->Print(
")" );
1100 std::string prefix = parentFP ?
"fp" :
"gr";
1105 m_out->Print(
"(%s_line (start %s) (end %s)",
1112 m_out->Print(
"(%s_rect (start %s) (end %s)", prefix.c_str(),
1121 m_out->Print(
"(%s_circle (center %s) (end %s)", prefix.c_str(),
1127 m_out->Print(
"(%s_arc (start %s) (mid %s) (end %s)", prefix.c_str(),
1139 m_out->Print(
"(%s_poly", prefix.c_str() );
1150 m_out->Print(
"(%s_curve (pts (xy %s) (xy %s) (xy %s) (xy %s))",
1159 m_out->Print(
"(%s_ellipse (center %s) (major_radius %s) (minor_radius %s) "
1160 "(rotation_angle %s)",
1169 m_out->Print(
"(%s_ellipse_arc (center %s) (major_radius %s) (minor_radius %s) "
1170 "(rotation_angle %s) (start_angle %s) (end_angle %s)",
1198 m_out->Print(
"(fill hatch)" );
1202 m_out->Print(
"(fill reverse_hatch)" );
1206 m_out->Print(
"(fill cross_hatch)" );
1231 m_out->Print(
"(solder_mask_margin %s)",
1239 m_out->Print(
")" );
1245 wxCHECK_RET( aBitmap !=
nullptr &&
m_out !=
nullptr,
"" );
1251 wxCHECK_RET(
image !=
nullptr,
"wxImage* is NULL" );
1253 m_out->Print(
"(image (at %s %s)",
1265 wxMemoryOutputStream ostream;
1271 m_out->Print(
")" );
1283 m_out->Print(
")" );
1289 m_out->Print(
"(target %s (at %s) (size %s)",
1290 ( aTarget->
GetShape() ) ?
"x" :
"plus",
1299 m_out->Print(
")" );
1309 if( initial_comments )
1311 for(
unsigned i = 0; i < initial_comments->GetCount(); ++i )
1312 m_out->Print(
"%s\n",
TO_UTF8( (*initial_comments)[i] ) );
1318 m_out->Print(
"(footprint %s",
1323 m_out->Print(
"(footprint %s",
1329 m_out->Print(
"(version %d) (generator \"pcbnew\") (generator_version %s)",
1347 m_out->Print(
"(transform (translate %s) (rotate %s) (scale %s %s))",
1365 m_out->Print(
"(property %s %s",
1366 m_out->Quotew( field->GetCanonicalName() ).c_str(),
1367 m_out->Quotew( field->GetText() ).c_str() );
1371 m_out->Print(
")" );
1376 if( !compClass->IsEmpty() )
1378 m_out->Print(
"(component_classes" );
1381 m_out->Print(
"(class %s)",
m_out->Quotew( constituent->GetName() ).c_str() );
1383 m_out->Print(
")" );
1389 m_out->Print(
"(property ki_fp_filters %s)",
1405 m_out->Print(
"(units" );
1409 m_out->Print(
"(unit (name %s)",
m_out->Quotew( u.m_unitName ).c_str() );
1410 m_out->Print(
"(pins" );
1412 for(
const wxString& n : u.m_pins )
1413 m_out->Print(
" %s",
m_out->Quotew( n ).c_str() );
1415 m_out->Print(
")" );
1416 m_out->Print(
")" );
1419 m_out->Print(
")" );
1424 m_out->Print(
"(solder_mask_margin %s)",
1430 m_out->Print(
"(solder_paste_margin %s)",
1436 m_out->Print(
"(solder_paste_margin_ratio %s)",
1442 m_out->Print(
"(clearance %s)",
1448 m_out->Print(
"(zone_connect %d)",
1457 m_out->Print(
"(attr" );
1460 m_out->Print(
" smd" );
1463 m_out->Print(
" through_hole" );
1466 m_out->Print(
" board_only" );
1469 m_out->Print(
" exclude_from_pos_files" );
1472 m_out->Print(
" exclude_from_bom" );
1475 m_out->Print(
" allow_missing_courtyard" );
1478 m_out->Print(
" dnp" );
1481 m_out->Print(
" allow_soldermask_bridges" );
1483 m_out->Print(
")" );
1489 m_out->Print(
"(stackup" );
1494 wxString canonicalName(
LSET::Name( layer ) );
1495 m_out->Print(
"(layer %s)",
m_out->Quotew( canonicalName ).c_str() );
1498 m_out->Print(
")" );
1503 m_out->Print(
"(private_layers" );
1507 wxString canonicalName(
LSET::Name( layer ) );
1508 m_out->Print(
" %s",
m_out->Quotew( canonicalName ).c_str() );
1511 m_out->Print(
")" );
1516 m_out->Print(
"(net_tie_pad_groups" );
1521 m_out->Print(
")" );
1527 const std::vector<std::set<wxString>>& jumperGroups = aFootprint->
JumperPadGroups();
1529 if( !jumperGroups.empty() )
1531 m_out->Print(
"(jumper_pad_groups" );
1533 for(
const std::set<wxString>&
group : jumperGroups )
1535 m_out->Print(
"(" );
1537 for(
const wxString& padName :
group )
1538 m_out->Print(
"%s ",
m_out->Quotew( padName ).c_str() );
1540 m_out->Print(
")" );
1543 m_out->Print(
")" );
1549 std::set<PAD*, FOOTPRINT::cmp_pads> sorted_pads( aFootprint->
Pads().begin(),
1550 aFootprint->
Pads().end() );
1551 std::set<BOARD_ITEM*, FOOTPRINT::cmp_drawings> sorted_drawings(
1554 std::set<PCB_POINT*, PCB_POINT::cmp_points> sorted_points(
1555 aFootprint->
Points().begin(),
1556 aFootprint->
Points().end() );
1557 std::set<ZONE*, FOOTPRINT::cmp_zones> sorted_zones( aFootprint->
Zones().begin(),
1558 aFootprint->
Zones().end() );
1559 std::set<BOARD_ITEM*, PCB_GROUP::ptr_cmp> sorted_groups( aFootprint->
Groups().begin(),
1560 aFootprint->
Groups().end() );
1571 for(
PAD*
pad : sorted_pads )
1583 const bool baseDnp = aFootprint->
IsDNP();
1587 for(
const auto& [variantName, variant] : aFootprint->
GetVariants() )
1589 m_out->Print(
"(variant (name %s)",
m_out->Quotew( variantName ).c_str() );
1591 if( variant.GetDNP() != baseDnp )
1594 if( variant.GetExcludedFromBOM() != baseExcludedFromBOM )
1597 if( variant.GetExcludedFromPosFiles() != baseExcludedFromPosFiles )
1600 variant.GetExcludedFromPosFiles() );
1603 for(
const auto& [fieldName, fieldValue] : variant.GetFields() )
1606 const wxString baseValue = baseField ? baseField->
GetText() : wxString();
1608 if( fieldValue == baseValue )
1611 m_out->Print(
"(field (name %s) (value %s))",
1612 m_out->Quotew( fieldName ).c_str(),
1613 m_out->Quotew( fieldValue ).c_str() );
1616 m_out->Print(
")" );
1628 m_out->Print(
"(model" );
1629 m_out->Print(
"(type extruded)" );
1635 m_out->Print(
"(layer pad_bbox)" );
1639 m_out->Print(
"(layer auto)" );
1642 static const char* matNames[] = {
"plastic",
"matte",
"metal",
"copper" };
1643 m_out->Print(
"(material %s)", matNames[
static_cast<int>( body->m_material )] );
1654 m_out->Print(
"(color unspecified)" );
1666 m_out->Print(
")" );
1670 auto bs3D = aFootprint->
Models().begin();
1671 auto es3D = aFootprint->
Models().end();
1673 while( bs3D != es3D )
1675 if( !bs3D->m_Filename.IsEmpty() )
1677 m_out->Print(
"(model %s",
m_out->Quotew( bs3D->m_Filename ).c_str() );
1682 if( bs3D->m_Opacity != 1.0 )
1683 m_out->Print(
"%s", fmt::format(
"(opacity {:.4f})", bs3D->m_Opacity).c_str() );
1685 m_out->Print(
"(offset (xyz %s %s %s))",
1690 m_out->Print(
"(scale (xyz %s %s %s))",
1695 m_out->Print(
"(rotate (xyz %s %s %s))",
1700 m_out->Print(
")" );
1706 m_out->Print(
")" );
1725 if( !aEnumerateLayers )
1728 if( ( aLayerMask & cu_board_mask ) == cu_board_mask )
1735 aLayerMask &= ~cu_all;
1737 else if( ( aLayerMask & cu_board_mask ) == fr_bk )
1744 aLayerMask &= ~fr_bk;
1747 if( ( aLayerMask & adhes ) == adhes )
1750 aLayerMask &= ~adhes;
1759 if( ( aLayerMask & silks ) == silks )
1762 aLayerMask &= ~silks;
1765 if( ( aLayerMask & mask ) == mask )
1768 aLayerMask &= ~mask;
1771 if( ( aLayerMask & crt_yd ) == crt_yd )
1774 aLayerMask &= ~crt_yd;
1777 if( ( aLayerMask & fab ) == fab )
1787 if( aLayerMask[layer] )
1829 THROW_IO_ERROR( wxString::Format( wxT(
"unknown pad attribute: %d" ),
1833 const char*
property =
nullptr;
1848 THROW_IO_ERROR( wxString::Format( wxT(
"unknown pad property: %d" ),
1852 const char* simElectricalType =
nullptr;
1858 default: simElectricalType =
nullptr;
break;
1861 m_out->Print(
"(pad %s %s %s",
1866 m_out->Print(
"(at %s %s)",
1887 bool forceShapeOffsetOutput =
false;
1892 if( aPad->
GetOffset( layer ) != shapeoffset )
1893 forceShapeOffsetOutput =
true;
1896 if( drill.
x > 0 || drill.
y > 0 || shapeoffset.
x != 0 || shapeoffset.
y != 0 || forceShapeOffsetOutput )
1898 m_out->Print(
"(drill" );
1901 m_out->Print(
" oval" );
1906 if( drill.
y > 0 && drill.
x != drill.
y )
1913 if( shapeoffset.
x != 0 || shapeoffset.
y != 0 || forceShapeOffsetOutput )
1914 m_out->Print(
"(offset %s)",
1917 m_out->Print(
")" );
1922 m_out->Print(
"(backdrill (size %s) (layers %s %s))",
1930 m_out->Print(
"(tertiary_drill (size %s) (layers %s %s))",
1936 auto formatPostMachining =
1942 m_out->Print(
"(%s %s",
1947 if( aProps.size > 0 )
1950 if( aProps.depth > 0 )
1953 if( aProps.angle > 0 )
1956 m_out->Print(
")" );
1964 m_out->Print(
"(property %s)", property );
1966 if( simElectricalType )
1967 m_out->Print(
"(sim_electrical_type %s)", simElectricalType );
1981 m_out->Print(
"(zone_layer_connections" );
1989 m_out->Print(
")" );
1994 auto formatCornerProperties =
2001 m_out->Print(
"(roundrect_rratio %s)",
2008 m_out->Print(
"(chamfer_ratio %s)",
2011 m_out->Print(
"(chamfer" );
2014 m_out->Print(
" top_left" );
2017 m_out->Print(
" top_right" );
2020 m_out->Print(
" bottom_left" );
2023 m_out->Print(
" bottom_right" );
2025 m_out->Print(
")" );
2051 m_out->Print(
"(die_length %s)",
2057 m_out->Print(
"(die_delay %s)",
2063 m_out->Print(
"(solder_mask_margin %s)",
2069 m_out->Print(
"(solder_paste_margin %s)",
2075 m_out->Print(
"(solder_paste_margin_ratio %s)",
2081 m_out->Print(
"(clearance %s)",
2087 m_out->Print(
"(zone_connect %d)",
2093 m_out->Print(
"(thermal_bridge_width %s)",
2103 defaultThermalSpokeAngle =
ANGLE_45;
2108 m_out->Print(
"(thermal_bridge_angle %s)",
2114 m_out->Print(
"(thermal_gap %s)",
2129 auto formatPrimitives =
2132 m_out->Print(
"(primitives" );
2135 for(
const std::shared_ptr<PCB_SHAPE>& primitive : aPad->
GetPrimitives( aLayer ) )
2137 const SHAPE_T libShape = primitive->GetLibraryShape();
2142 if( primitive->IsProxyItem() )
2144 m_out->Print(
"(gr_vector (start %s) (end %s)",
2150 m_out->Print(
"(gr_line (start %s) (end %s)",
2157 if( primitive->IsProxyItem() )
2159 m_out->Print(
"(gr_bbox (start %s) (end %s)",
2165 m_out->Print(
"(gr_rect (start %s) (end %s)",
2169 if( primitive->GetCornerRadius() > 0 )
2171 m_out->Print(
" (radius %s)",
2178 m_out->Print(
"(gr_arc (start %s) (mid %s) (end %s)",
2185 m_out->Print(
"(gr_circle (center %s) (end %s)",
2193 m_out->Print(
"(gr_curve (pts (xy %s) (xy %s) (xy %s) (xy %s))",
2201 if( primitive->IsPolyShapeValid() )
2206 m_out->Print(
"(gr_poly" );
2215 if( !primitive->IsProxyItem() )
2225 m_out->Print(
")" );
2228 m_out->Print(
")" );
2233 m_out->Print(
"(options" );
2236 m_out->Print(
"(clearance convexhull)" );
2238 m_out->Print(
"(clearance outline)" );
2255 m_out->Print( 0,
" (tenting " );
2260 m_out->Print( 0,
")" );
2266 auto formatPadLayer =
2271 m_out->Print(
"(shape %s)", shapeName( aLayer ) );
2280 shapeoffset = aPad->
GetOffset( aLayer );
2282 if( shapeoffset.
x != 0 || shapeoffset.
y != 0 )
2285 formatCornerProperties( aLayer );
2289 m_out->Print(
"(options" );
2292 m_out->Print(
"(anchor %s)", anchorShape( aLayer ) );
2294 m_out->Print(
")" );
2297 formatPrimitives( aLayer );
2311 if( layerSpokeAngle != defaultLayerAngle )
2313 m_out->Print(
"(thermal_bridge_angle %s)",
2317 if( padstack.
ThermalGap( aLayer ).has_value() )
2319 m_out->Print(
"(thermal_gap %s)",
2325 m_out->Print(
"(thermal_bridge_width %s)",
2329 if( padstack.
Clearance( aLayer ).has_value() )
2331 m_out->Print(
"(clearance %s)",
2337 m_out->Print(
"(zone_connect %d)",
2347 m_out->Print(
"(padstack (mode front_inner_back)" );
2349 m_out->Print(
"(layer \"Inner\"" );
2351 m_out->Print(
")" );
2352 m_out->Print(
"(layer \"B.Cu\"" );
2353 formatPadLayer(
B_Cu );
2354 m_out->Print(
")" );
2358 m_out->Print(
"(padstack (mode custom)" );
2368 formatPadLayer( layer );
2369 m_out->Print(
")" );
2373 m_out->Print(
")" );
2376 m_out->Print(
")" );
2382 wxCHECK_RET( aBarcode !=
nullptr &&
m_out !=
nullptr,
"" );
2384 m_out->Print(
"(barcode" );
2389 m_out->Print(
"(at %s %s)",
2395 m_out->Print(
"(size %s %s)",
2403 const char* typeStr =
"code39";
2414 m_out->Print(
"(type %s)", typeStr );
2419 const char* eccStr =
"L";
2428 m_out->Print(
"(ecc_level %s)", eccStr );
2442 m_out->Print(
")" );
2472 m_out->Print(
"(%s_text %s %s",
2481 m_out->Print(
"(at %s %s)",
2508 if( mutateThickness )
2511 aText->EDA_TEXT::Format(
m_out, ctl_flags );
2515 if( mutateThickness )
2520 aText->EDA_TEXT::Format(
m_out, ctl_flags );
2527 m_out->Print(
")" );
2535 m_out->Print(
"(%s %s",
2537 : parentFP ?
"fp_text_box"
2568 m_out->Print(
"(margins %s %s %s %s)",
2575 m_out->Print(
"(span %d %d)", cell->GetColSpan(), cell->GetRowSpan() );
2592 aTextBox->EDA_TEXT::Format(
m_out, 0 );
2605 m_out->Print(
")" );
2611 wxCHECK_RET( aTable !=
nullptr &&
m_out !=
nullptr,
"" );
2622 m_out->Print(
"(border" );
2629 m_out->Print(
")" );
2631 m_out->Print(
"(separators" );
2638 m_out->Print(
")" );
2640 m_out->Print(
"(column_widths" );
2642 for(
int col = 0; col < aTable->
GetColCount(); ++col )
2645 m_out->Print(
")" );
2647 m_out->Print(
"(row_heights" );
2649 for(
int row = 0; row < aTable->
GetRowCount(); ++row )
2652 m_out->Print(
")" );
2654 m_out->Print(
"(cells" );
2659 m_out->Print(
")" );
2660 m_out->Print(
")" );
2666 wxArrayString memberIds;
2673 bool validateAgainstBoard =
false;
2674 std::unordered_set<const EDA_ITEM*> validPtrs;
2678 const auto& cache =
m_board->GetItemByIdCache();
2680 for(
const auto& [uuid, item] : cache )
2681 validPtrs.insert( item );
2683 validateAgainstBoard = validPtrs.count( aGroup ) > 0;
2686 if( validateAgainstBoard )
2690 if( validPtrs.count( member ) )
2691 memberIds.Add( member->m_Uuid.AsString() );
2697 memberIds.Add( member->m_Uuid.AsString() );
2700 if( memberIds.empty() )
2715 m_out->Print(
"(members" );
2717 for(
const wxString& memberId : memberIds )
2718 m_out->Print(
" %s",
m_out->Quotew( memberId ).c_str() );
2720 m_out->Print(
")" );
2721 m_out->Print(
")" );
2729 && aGenerator->
GetItems().empty() )
2734 m_out->Print(
"(generated" );
2738 m_out->Print(
"(type %s) (name %s) (layer %s)",
2746 for(
const auto& [key, value] : aGenerator->
GetProperties() )
2748 if( value.CheckType<
double>() || value.CheckType<
int>() || value.CheckType<
long>()
2749 || value.CheckType<
long long>() )
2753 if( !value.GetAs( &val ) )
2756 std::string buf = fmt::format(
"{:.10g}", val );
2759 m_out->Print(
"(%s %s)", key.c_str(), buf.c_str() );
2761 else if( value.CheckType<
bool>() )
2764 value.GetAs( &val );
2768 else if( value.CheckType<
VECTOR2I>() )
2771 value.GetAs( &val );
2773 m_out->Print(
"(%s (xy %s))",
2780 value.GetAs( &val );
2782 m_out->Print(
"(%s ", key.c_str() );
2784 m_out->Print(
")" );
2790 if( value.CheckType<wxString>() )
2792 value.GetAs( &val );
2794 else if( value.CheckType<std::string>() )
2797 value.GetAs( &str );
2799 val = wxString::FromUTF8( str );
2802 m_out->Print(
"(%s %s)", key.c_str(),
m_out->Quotew( val ).c_str() );
2806 wxArrayString memberIds;
2809 memberIds.Add( member->m_Uuid.AsString() );
2813 m_out->Print(
"(members" );
2815 for(
const wxString& memberId : memberIds )
2816 m_out->Print(
" %s",
m_out->Quotew( memberId ).c_str() );
2818 m_out->Print(
")" );
2819 m_out->Print(
")" );
2830 const BOARD* board =
via->GetBoard();
2832 wxCHECK_RET( board !=
nullptr, wxT(
"Via has no parent." ) );
2834 m_out->Print(
"(via" );
2836 via->LayerPair( &layer1, &layer2 );
2838 switch(
via->GetViaType() )
2844 m_out->Print(
" blind " );
2848 m_out->Print(
" buried " );
2852 m_out->Print(
" micro " );
2859 m_out->Print(
"(at %s) (size %s)",
2873 if(
via->Padstack().SecondaryDrill().size.x > 0 )
2875 m_out->Print(
"(backdrill (size %s) (layers %s %s))",
2881 if(
via->Padstack().TertiaryDrill().size.x > 0 )
2883 m_out->Print(
"(tertiary_drill (size %s) (layers %s %s))",
2894 m_out->Print(
"(%s %s", aName,
2897 if( aProps.size > 0 )
2900 if( aProps.depth > 0 )
2903 if( aProps.angle > 0 )
2906 m_out->Print(
")" );
2909 formatPostMachining(
"front_post_machining",
via->Padstack().FrontPostMachining() );
2910 formatPostMachining(
"back_post_machining",
via->Padstack().BackPostMachining() );
2912 m_out->Print(
"(layers %s %s)",
2916 switch(
via->Padstack().UnconnectedLayerMode() )
2936 if(
via->IsLocked() )
2939 if(
via->GetIsFree() )
2942 if(
via->GetRemoveUnconnected() )
2944 m_out->Print(
"(zone_layer_connections" );
2952 m_out->Print(
")" );
2960 m_out->Print( 0,
" (tenting " );
2965 m_out->Print( 0,
")" );
2974 m_out->Print( 0,
" (covering " );
2979 m_out->Print( 0,
")" );
2985 m_out->Print( 0,
" (plugging " );
2990 m_out->Print( 0,
")" );
2998 m_out->Print(
"(padstack" );
3002 m_out->Print(
"(mode front_inner_back)" );
3004 m_out->Print(
"(layer \"Inner\"" );
3005 m_out->Print(
"(size %s)",
3007 m_out->Print(
")" );
3008 m_out->Print(
"(layer \"B.Cu\"" );
3009 m_out->Print(
"(size %s)",
3011 m_out->Print(
")" );
3015 m_out->Print(
"(mode custom)" );
3023 m_out->Print(
"(size %s)",
3025 m_out->Print(
")" );
3029 m_out->Print(
")" );
3041 m_out->Print(
"(arc (start %s) (mid %s) (end %s) (width %s)",
3049 m_out->Print(
"(segment (start %s) (end %s) (width %s)",
3067 m_out->Print(
"(solder_mask_margin %s)",
3076 m_out->Print(
")" );
3082 m_out->Print(
"(zone" );
3100 if( layers.count() > 1 )
3122 m_out->Print(
"(hatch %s %s)", hatch.c_str(),
3133 m_out->Print(
"(attr (teardrop (type %s)))",
3138 m_out->Print(
"(connect_pads" );
3147 m_out->Print(
" thru_hole_only" );
3151 m_out->Print(
" yes" );
3155 m_out->Print(
" no" );
3159 m_out->Print(
"(clearance %s)",
3162 m_out->Print(
")" );
3164 m_out->Print(
"(min_thickness %s)",
3170 m_out->Print(
"(keepout (tracks %s) (vias %s) (pads %s) (copperpour %s) (footprints %s))",
3178 m_out->Print(
"(placement" );
3197 m_out->Print(
")" );
3200 m_out->Print(
"(fill" );
3204 m_out->Print(
" yes" );
3208 m_out->Print(
"(mode hatch)" );
3210 m_out->Print(
"(mode thieving)" );
3214 m_out->Print(
"(thermal_gap %s) (thermal_bridge_width %s)",
3224 m_out->Print(
"(smoothing chamfer)" );
3228 m_out->Print(
"(smoothing fillet)" );
3232 THROW_IO_ERROR( wxString::Format(
_(
"unknown zone corner smoothing type %d" ),
3240 m_out->Print(
"(island_removal_mode %d)",
3245 m_out->Print(
"(island_area_min %s)",
3251 m_out->Print(
"(hatch_thickness %s) (hatch_gap %s) (hatch_orientation %s)",
3258 m_out->Print(
"(hatch_smoothing_level %d) (hatch_smoothing_value %s)",
3263 m_out->Print(
"(hatch_border_algorithm %s) (hatch_min_hole_area %s)",
3270 const char* patternStr =
"dots";
3277 default: patternStr =
"dots";
break;
3280 m_out->Print(
"(thieving (type %s) (size %s) (gap %s) (width %s) "
3281 "(stagger %s) (orientation %s))",
3286 thieving.
stagger ?
"yes" :
"no",
3290 m_out->Print(
")" );
3294 format( properties, 0, layer );
3303 if(
chain.PointCount() == 0 )
3306 m_out->Print(
"(polygon" );
3308 m_out->Print(
")" );
3317 for(
int ii = 0; ii < fv->OutlineCount(); ++ii )
3319 m_out->Print(
"(filled_polygon" );
3328 m_out->Print(
")" );
3332 m_out->Print(
")" );
3343 m_out->Print( aNestLevel,
"(property\n" );
3348 m_out->Print( aNestLevel,
"(hatch_position (xy %s))",
3352 m_out->Print( aNestLevel,
")\n" );
3358 m_ctl( aControlFlags )
3372 const std::map<std::string, UTF8>* aProperties,
3377 unsigned lineCount = 0;
3406 const std::map<std::string, UTF8>* aProperties,
3409 init( aProperties );
3411 bool preserveDestinationStackup =
3415 preserveDestinationStackup );
3423 board =
dynamic_cast<BOARD*
>( parser.
Parse() );
3442 parser.CurLine(), parser.CurLineNumber(), parser.CurOffset() );
3477 const wxString& aLibPath,
bool aBestEfforts,
3478 const std::map<std::string, UTF8>* aProperties )
3480 wxDir dir( aLibPath );
3483 init( aProperties );
3491 errorMsg = ioe.
What();
3497 for(
const auto& footprint :
m_cache->GetFootprints() )
3498 aFootprintNames.Add( footprint.first );
3500 if( !errorMsg.IsEmpty() && !aBestEfforts )
3506 const wxString& aFootprintName,
3507 const std::map<std::string, UTF8>* aProperties,
3508 bool checkModified )
3510 init( aProperties );
3521 auto it =
m_cache->GetFootprints().find( aFootprintName );
3523 if( it ==
m_cache->GetFootprints().end() )
3526 return it->second->GetFootprint().get();
3531 const wxString& aFootprintName,
3532 const std::map<std::string, UTF8>* aProperties )
3534 return getFootprint( aLibraryPath, aFootprintName, aProperties,
false );
3539 const wxString& aFootprintName,
3540 const std::map<std::string, UTF8>* aProperties )
3551 return footprintFile.Exists();
3556 wxString& aFootprintNameOut,
3557 const std::map<std::string, UTF8>* aProperties )
3560 wxFFile f( aFootprintPath );
3568 f.ReadAll( &fcontents );
3570 aFootprintNameOut = wxFileName( aFootprintPath ).GetName();
3577 const wxString& aFootprintName,
3579 const std::map<std::string, UTF8>* aProperties )
3595 copy->SetParent(
nullptr );
3604 const std::map<std::string, UTF8>* aProperties )
3606 init( aProperties );
3614 wxString libPath = aLibraryPath;
3615 wxString singleFileBaseName;
3616 bool saveSingleFile =
false;
3619 wxFileName asFile( aLibraryPath );
3623 saveSingleFile =
true;
3624 libPath = asFile.GetPath();
3625 singleFileBaseName = asFile.GetName();
3629 validateCache( libPath, !aProperties || !aProperties->contains(
"skip_cache_validation" ) );
3635 const wxString msg = wxString::Format(
_(
"Library '%s' does not exist.\n"
3636 "Would you like to create it?"),
3639 if( !
Pgm().IsGUI() || wxMessageBox( msg,
_(
"Library Not Found" ), wxYES_NO | wxICON_QUESTION ) != wxYES )
3647 wxString msg = wxString::Format(
_(
"Library '%s' is read only." ), libPath );
3653 wxString footprintName = saveSingleFile ? singleFileBaseName
3656 wxString fpName = saveSingleFile ? singleFileBaseName
3668 THROW_IO_ERROR( wxString::Format(
_(
"Footprint file name '%s' is not valid." ), fn.GetFullPath() ) );
3671 if( fn.FileExists() && !fn.IsFileWritable() )
3673 THROW_IO_ERROR( wxString::Format(
_(
"Insufficient permissions to delete '%s'." ),
3674 fn.GetFullPath() ) );
3677 wxString fullPath = fn.GetFullPath();
3678 wxString fullName = fn.GetFullName();
3679 auto it =
m_cache->GetFootprints().find( footprintName );
3681 if( it !=
m_cache->GetFootprints().end() )
3685 m_cache->GetFootprints().erase( footprintName );
3713 wxLogTrace(
traceKicadPcbPlugin, wxT(
"Creating s-expr footprint file '%s'." ), fullPath );
3714 m_cache->GetFootprints().insert( footprintName,
3722 const wxString& aFootprintName,
3723 const std::map<std::string, UTF8>* aProperties )
3725 init( aProperties );
3732 aLibraryPath.GetData() ) );
3735 m_cache->Remove( aFootprintName );
3756 const std::map<std::string, UTF8>* aProperties )
3758 if( wxDir::Exists( aLibraryPath ) )
3760 THROW_IO_ERROR( wxString::Format(
_(
"Cannot overwrite library path '%s'." ),
3761 aLibraryPath.GetData() ) );
3764 init( aProperties );
3773 const std::map<std::string, UTF8>* aProperties )
3776 fn.SetPath( aLibraryPath );
3779 if( !fn.DirExists() )
3782 if( !fn.IsDirWritable() )
3784 THROW_IO_ERROR( wxString::Format(
_(
"Insufficient permissions to delete folder '%s'." ),
3785 aLibraryPath.GetData() ) );
3788 wxDir dir( aLibraryPath );
3790 if( dir.HasSubDirs() )
3792 THROW_IO_ERROR( wxString::Format(
_(
"Library folder '%s' has unexpected sub-folders." ),
3793 aLibraryPath.GetData() ) );
3797 if( dir.HasFiles() )
3801 wxArrayString files;
3805 for( i = 0; i < files.GetCount(); i++ )
3811 THROW_IO_ERROR( wxString::Format(
_(
"Unexpected file '%s' found in library "
3814 aLibraryPath.GetData() ) );
3818 for( i = 0; i < files.GetCount(); i++ )
3819 wxRemoveFile( files[i] );
3823 aLibraryPath.GetData() );
3827 if( !wxRmdir( aLibraryPath ) )
3829 THROW_IO_ERROR( wxString::Format(
_(
"Footprint library '%s' cannot be deleted." ),
3830 aLibraryPath.GetData() ) );
3837 wxMilliSleep( 250L );
constexpr EDA_IU_SCALE pcbIUScale
KIFACE_BASE & Kiface()
Global KIFACE_BASE "get" accessor.
constexpr BOX2I KiROUND(const BOX2D &aBoxD)
wxString GetMajorMinorVersion()
Get only the major and minor version in a string major.minor.
bool SaveImageData(wxOutputStream &aOutStream) const
Write the bitmap data to aOutStream.
wxString GetNetname() const
PCB_LAYER_ID GetLayer() const override
Return the primary layer this item is on.
TEARDROP_PARAMETERS & GetTeardropParams()
Container for design settings for a BOARD object.
std::map< PCB_LAYER_ID, ZONE_LAYER_PROPERTIES > m_ZoneLayerProperties
const VECTOR2I & GetGridOrigin() const
int GetBoardThickness() const
The full thickness of the board including copper and masks.
bool m_AllowSoldermaskBridgesInFPs
const VECTOR2I & GetAuxOrigin() const
int m_SolderMaskExpansion
BOARD_STACKUP & GetStackupDescriptor()
double m_SolderPasteMarginRatio
A base class for any item which can be embedded within the BOARD container class, and therefore insta...
virtual PCB_LAYER_ID GetLayer() const
Return the primary layer this item is on.
virtual bool IsKnockout() const
bool IsLocked() const override
virtual const BOARD * GetBoard() const
Return the BOARD in which this BOARD_ITEM resides, or NULL if none.
FOOTPRINT * GetParentFootprint() const
VECTOR2I GetFPRelativePosition() const
Manage layers needed to make a physical board.
void FormatBoardStackup(OUTPUTFORMATTER *aFormatter, const BOARD *aBoard) const
Write the stackup info on board file.
Information pertinent to a Pcbnew printed circuit board.
const NETINFO_LIST & GetNetInfo() const
EMBEDDED_FILES * GetEmbeddedFiles() override
const std::vector< wxString > & GetVariantNames() const
const GENERATORS & Generators() const
void SetFileName(const wxString &aFileName)
const PCB_POINTS & Points() const
const PAGE_INFO & GetPageSettings() const
const ZONES & Zones() const
const GROUPS & Groups() const
The groups must maintain the following invariants.
LAYER_T GetLayerType(PCB_LAYER_ID aLayer) const
Return the type of the copper layer given by aLayer.
TITLE_BLOCK & GetTitleBlock()
int GetCopperLayerCount() const
const std::map< wxString, wxString > & GetProperties() const
const FOOTPRINTS & Footprints() const
const TRACKS & Tracks() const
wxString GetVariantDescription(const wxString &aVariantName) const
const PCB_PLOT_PARAMS & GetPlotOptions() const
bool LegacyTeardrops() const
wxString GroupsSanityCheck(bool repair=false)
Consistency check of internal m_groups structure.
BOARD_DESIGN_SETTINGS & GetDesignSettings() const
const LSET & GetEnabledLayers() const
A proxy function that calls the corresponding function in m_BoardSettings.
const DRAWINGS & Drawings() const
A lightweight representation of a component class.
const std::vector< COMPONENT_CLASS * > & GetConstituentClasses() const
Fetches a vector of the constituent classes for this (effective) class.
const LIB_ID & GetDesignBlockLibId() const
std::unordered_set< EDA_ITEM * > & GetItems()
bool HasDesignBlockLink() const
A base class for most all the KiCad significant classes used in schematics and boards.
KICAD_T Type() const
Returns the type of object.
virtual void SetParentGroup(EDA_GROUP *aGroup)
virtual void SetParent(EDA_ITEM *aParent)
const VECTOR2I & GetBezierC2() const
FILL_T GetFillMode() const
SHAPE_POLY_SET & GetPolyShape()
const VECTOR2I & GetEnd() const
Return the ending point of the graphic.
const VECTOR2I & GetStart() const
Return the starting point of the graphic.
wxString SHAPE_T_asString() const
const VECTOR2I & GetBezierC1() const
int GetCornerRadius() const
bool IsPolyShapeValid() const
A mix-in class (via multiple inheritance) that handles texts such as labels, parts,...
virtual VECTOR2I GetTextSize() const
virtual void SetTextSize(VECTOR2I aNewSize, bool aEnforceMinTextSize=true)
virtual const wxString & GetText() const
Return the string associated with the text object.
bool IsKeepUpright() const
virtual bool IsVisible() const
KIFONT::FONT * GetFont() const
std::vector< std::unique_ptr< KIFONT::GLYPH > > * GetRenderCache(const KIFONT::FONT *aFont, const wxString &forResolvedText, const VECTOR2I &aOffset={ 0, 0 }) const
virtual EDA_ANGLE GetDrawRotation() const
bool GetAutoThickness() const
virtual void SetTextThickness(int aWidth)
The TextThickness is that set by the user.
virtual wxString GetShownText(bool aAllowExtraText, int aDepth=0) const
Return the string actually shown after processing of the base text.
virtual int GetTextThickness() const
void WriteEmbeddedFiles(OUTPUTFORMATTER &aOut, bool aWriteData) const
Output formatter for the embedded files.
void ClearEmbeddedFiles(bool aDeleteFiles=true)
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
bool GetAreFontsEmbedded() const
A LINE_READER that reads from an open file.
void Rewind()
Rewind the file and resets the line number back to zero.
char * ReadLine() override
Read a line of text into the buffer and increments the line number counter.
RAII class to set and restore the fontconfig reporter.
Helper class for creating a footprint library cache.
std::unique_ptr< FOOTPRINT > m_footprint
FP_CACHE_ENTRY(FOOTPRINT *aFootprint, const WX_FILENAME &aFileName)
const WX_FILENAME & GetFileName() const
std::unique_ptr< FOOTPRINT > & GetFootprint()
static long long GetTimestamp(const wxString &aLibPath)
Generate a timestamp representing all source files in the cache (including the parent directory).
boost::ptr_map< wxString, FP_CACHE_ENTRY > m_footprints
PCB_IO_KICAD_SEXPR * m_owner
bool IsModified()
Return true if the cache is not up-to-date.
long long m_cache_timestamp
void SetPath(const wxString &aPath)
bool IsPath(const wxString &aPath) const
Check if aPath is the same as the current cache path.
void Save(FOOTPRINT *aFootprintFilter=nullptr)
Save the footprint cache or a single footprint from it to disk.
FP_CACHE(PCB_IO_KICAD_SEXPR *aOwner, const wxString &aLibraryPath)
boost::ptr_map< wxString, FP_CACHE_ENTRY > & GetFootprints()
void Remove(const wxString &aFootprintName)
PROGRESS_REPORTER * m_progressReporter
Progress reporter to track the progress of the operation, may be nullptr.
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()
APP_SETTINGS_BASE * KifaceSettings() const
virtual bool IsOutline() const
static const COLOR4D UNSPECIFIED
For legacy support; used as a value to indicate color hasn't been set yet.
virtual void SetLineWidth(float aLineWidth)
Set the line width.
virtual wxString GetClass() const =0
Return the class name.
wxString AsString() const
LAYER_MAPPING_HANDLER m_layer_mapping_handler
Callback to get layer mapping.
A logical library item identifier and consists of various portions much like a URI.
const wxString GetUniStringLibItemName() const
Get strings for display messages in dialogs.
const UTF8 & GetLibItemName() const
An abstract class from which implementation specific LINE_READERs may be derived to read single lines...
static LOAD_INFO_REPORTER & GetInstance()
REPORTER & Report(const wxString &aMsg, SEVERITY aSeverity=RPT_SEVERITY_UNDEFINED) override
Report a string with a given severity.
LSEQ is a sequence (and therefore also a set) of PCB_LAYER_IDs.
LSET is a set of PCB_LAYER_IDs.
static const LSET & AllCuMask()
return AllCuMask( MAX_CU_LAYERS );
LSEQ CuStack() const
Return a sequence of copper layers in starting from the front/top and extending to the back/bottom.
LSEQ TechAndUserUIOrder() const
Return the technical and user layers in the order shown in layer widget.
LSEQ Seq(const LSEQ &aSequence) const
Return an LSEQ from the union of this LSET and a desired sequence.
static LSET AllCuMask(int aCuLayerCount)
Return a mask holding the requested number of Cu PCB_LAYER_IDs.
static wxString Name(PCB_LAYER_ID aLayerId)
Return the fixed name association with aLayerId.
Handle the data for a net.
const wxString & GetNetname() const
A PADSTACK defines the characteristics of a single or multi-layer pad, in the IPC sense of the word.
std::optional< int > & Clearance(PCB_LAYER_ID aLayer=F_Cu)
MASK_LAYER_PROPS & FrontOuterLayers()
void ForEachUniqueLayer(const std::function< void(PCB_LAYER_ID)> &aMethod) const
Runs the given callable for each active unique copper layer in this padstack, meaning F_Cu for MODE::...
std::optional< int > & ThermalSpokeWidth(PCB_LAYER_ID aLayer=F_Cu)
VECTOR2I & Offset(PCB_LAYER_ID aLayer)
EDA_ANGLE ThermalSpokeAngle(PCB_LAYER_ID aLayer=F_Cu) const
POST_MACHINING_PROPS & FrontPostMachining()
std::optional< int > & ThermalGap(PCB_LAYER_ID aLayer=F_Cu)
DRILL_PROPS & TertiaryDrill()
const VECTOR2I & Size(PCB_LAYER_ID aLayer) const
@ NORMAL
Shape is the same on all layers.
@ FRONT_INNER_BACK
Up to three shapes can be defined (F_Cu, inner copper layers, B_Cu)
DRILL_PROPS & SecondaryDrill()
POST_MACHINING_PROPS & BackPostMachining()
MASK_LAYER_PROPS & BackOuterLayers()
static constexpr PCB_LAYER_ID ALL_LAYERS
! Temporary layer identifier to identify code that is not padstack-aware
static constexpr PCB_LAYER_ID INNER_LAYERS
! The layer identifier to use for "inner layers" on top/inner/bottom padstacks
std::optional< ZONE_CONNECTION > & ZoneConnection(PCB_LAYER_ID aLayer=F_Cu)
PAD_PROP GetProperty() const
bool GetRemoveUnconnected() const
LSET GetLayerSet() const override
Return a std::bitset of all layers on which the item physically resides.
const std::vector< std::shared_ptr< PCB_SHAPE > > & GetPrimitives(PCB_LAYER_ID aLayer) const
Accessor to the basic shape list for custom-shaped pads.
const ZONE_LAYER_OVERRIDE & GetZoneLayerOverride(PCB_LAYER_ID aLayer) const
std::optional< double > GetLocalSolderPasteMarginRatio() const
const wxString & GetPinType() const
PAD_ATTRIB GetAttribute() const
const wxString & GetPinFunction() const
const wxString & GetNumber() const
const VECTOR2I & GetDelta(PCB_LAYER_ID aLayer) const
EDA_ANGLE GetThermalSpokeAngle() const
VECTOR2I GetOffset(PCB_LAYER_ID aLayer) const
VECTOR2I GetDrillSize() const
double GetRoundRectRadiusRatio(PCB_LAYER_ID aLayer) const
PAD_SHAPE GetShape(PCB_LAYER_ID aLayer) const
bool GetKeepTopBottom() const
int GetPadToDieDelay() const
std::optional< int > GetLocalClearance() const override
Return any local clearances set in the "classic" (ie: pre-rule) system.
const PADSTACK & Padstack() const
EDA_ANGLE GetOrientation() const
Return the rotation angle of the pad.
PAD_DRILL_SHAPE GetDrillShape() const
int GetChamferPositions(PCB_LAYER_ID aLayer) const
std::optional< int > GetLocalSolderPasteMargin() const
PAD_SIM_ELECTRICAL_TYPE GetSimElectricalType() const
std::optional< int > GetLocalSolderMaskMargin() const
double GetChamferRectRatio(PCB_LAYER_ID aLayer) const
std::optional< int > GetLocalThermalSpokeWidthOverride() const
ZONE_CONNECTION GetLocalZoneConnection() const
CUSTOM_SHAPE_ZONE_MODE GetCustomShapeInZoneOpt() const
int GetLocalThermalGapOverride(wxString *aSource) const
PAD_SHAPE GetAnchorPadShape(PCB_LAYER_ID aLayer) const
int GetPadToDieLength() const
void Format(OUTPUTFORMATTER *aFormatter) const
Output the page class to aFormatter in s-expression form.
FLIP_DIRECTION m_FlipDirection
const VECTOR2I & GetMid() const
const VECTOR2I & GetMargin() const
Get the barcode margin (in internal units).
VECTOR2I GetPosition() const override
Get the position (center) of the barcode in internal units.
bool IsKnockout() const override
int GetHeight() const
Get the barcode height (in internal units).
BARCODE_ECC_T GetErrorCorrection() const
EDA_ANGLE GetAngle() const
BARCODE_T GetKind() const
Returns the type of the barcode (QR, CODE_39, etc.).
int GetWidth() const
Get the barcode width (in internal units).
wxString GetOverrideText() const
wxString GetSuffix() const
int GetLineThickness() const
DIM_TEXT_POSITION GetTextPositionMode() const
bool GetKeepTextAligned() const
DIM_PRECISION GetPrecision() const
wxString GetPrefix() const
DIM_UNITS_MODE GetUnitsMode() const
DIM_UNITS_FORMAT GetUnitsFormat() const
DIM_ARROW_DIRECTION GetArrowDirection() const
virtual VECTOR2I GetEnd() const
bool GetSuppressZeroes() const
int GetExtensionOffset() const
virtual VECTOR2I GetStart() const
The dimension's origin is the first feature point for the dimension.
int GetArrowLength() const
bool GetOverrideTextEnabled() const
For better understanding of the points that make a dimension:
int GetExtensionHeight() const
Mark the center of a circle or arc with a cross shape.
A leader is a dimension-like object pointing to a specific point.
DIM_TEXT_BORDER GetTextBorder() const
An orthogonal dimension is like an aligned dimension, but the extension lines are locked to the X or ...
A radial dimension indicates either the radius or diameter of an arc or circle.
int GetLeaderLength() const
virtual const STRING_ANY_MAP GetProperties() const
virtual wxString GetGeneratorType() const
A set of BOARD_ITEMs (i.e., without duplicates).
Read a Pcbnew s-expression formatted LINE_READER object and returns the appropriate BOARD_ITEM object...
const std::vector< wxString > & GetParseWarnings() const
Return any non-fatal parse warnings that occurred during parsing.
void SetLayerMappingHandler(LAYER_MAPPING_HANDLER aHandler)
Handler to remap an appended board's layers onto the destination board, used on mismatch.
bool IsTooRecent()
Return whether a version number, if any was parsed, was too recent.
bool IsValidBoardHeader()
Partially parse the input and check if it matches expected header.
wxString GetRequiredVersion()
Return a string representing the version of KiCad required to open this file.
A #PLUGIN derivation for saving and loading Pcbnew s-expression formatted files.
BOARD * DoLoad(LINE_READER &aReader, BOARD *aAppendToMe, const std::map< std::string, UTF8 > *aProperties, PROGRESS_REPORTER *aProgressReporter, unsigned aLineCount)
bool CanReadBoard(const wxString &aFileName) const override
Checks if this PCB_IO can read the specified board file.
void formatProperties(const BOARD *aBoard) const
formats the Nets and Netclasses
FOOTPRINT * ImportFootprint(const wxString &aFootprintPath, wxString &aFootprintNameOut, const std::map< std::string, UTF8 > *aProperties=nullptr) override
Load a single footprint from aFootprintPath and put its name in aFootprintNameOut.
void FootprintDelete(const wxString &aLibraryPath, const wxString &aFootprintName, const std::map< std::string, UTF8 > *aProperties=nullptr) override
Delete aFootprintName from the library at aLibraryPath.
long long GetLibraryTimestamp(const wxString &aLibraryPath) const override
Generate a timestamp representing all the files in the library (including the library directory).
bool IsLibraryWritable(const wxString &aLibraryPath) override
Return true if the library at aLibraryPath is writable.
void formatTeardropParameters(const TEARDROP_PARAMETERS &tdParams) const
bool DeleteLibrary(const wxString &aLibraryPath, const std::map< std::string, UTF8 > *aProperties=nullptr) override
Delete an existing library and returns true, or if library does not exist returns false,...
const FOOTPRINT * GetEnumeratedFootprint(const wxString &aLibraryPath, const wxString &aFootprintName, const std::map< std::string, UTF8 > *aProperties=nullptr) override
A version of FootprintLoad() for use after FootprintEnumerate() for more efficient cache management.
void CreateLibrary(const wxString &aLibraryPath, const std::map< std::string, UTF8 > *aProperties=nullptr) override
Create a new empty library at aLibraryPath empty.
void FootprintEnumerate(wxArrayString &aFootprintNames, const wxString &aLibraryPath, bool aBestEfforts, const std::map< std::string, UTF8 > *aProperties=nullptr) override
Return a list of footprint names contained within the library at aLibraryPath.
void formatPolyPts(const SHAPE_LINE_CHAIN &outline, const FOOTPRINT *aParentFP=nullptr) const
FP_CACHE * m_cache
Footprint library cache.
void formatBoardLayers(const BOARD *aBoard) const
formats the board layer information
FOOTPRINT * FootprintLoad(const wxString &aLibraryPath, const wxString &aFootprintName, bool aKeepUUID=false, const std::map< std::string, UTF8 > *aProperties=nullptr) override
Load a footprint having aFootprintName from the aLibraryPath containing a library format that this PC...
BOARD * LoadBoard(const wxString &aFileName, BOARD *aAppendToMe, const std::map< std::string, UTF8 > *aProperties=nullptr, PROJECT *aProject=nullptr) override
Load information from some input file format that this PCB_IO implementation knows about into either ...
bool FootprintExists(const wxString &aLibraryPath, const wxString &aFootprintName, const std::map< std::string, UTF8 > *aProperties=nullptr) override
Check for the existence of a footprint.
void FootprintSave(const wxString &aLibraryPath, const FOOTPRINT *aFootprint, const std::map< std::string, UTF8 > *aProperties=nullptr) override
Write aFootprint to an existing library located at aLibraryPath.
void format(const BOARD *aBoard) const
void SaveBoard(const wxString &aFileName, BOARD *aBoard, const std::map< std::string, UTF8 > *aProperties=nullptr) override
Write aBoard to a storage file in a format that this PCB_IO implementation knows about or it can be u...
void formatLayers(LSET aLayerMask, bool aEnumerateLayers, bool aIsZone=false) const
void formatGeneral(const BOARD *aBoard) const
formats the General section of the file
void formatVariants(const BOARD *aBoard) const
formats the board variant registry
void ClearCachedFootprints(const wxString &aLibraryPath) override
Clear any cached footprint data for the given library path.
void formatSetup(const BOARD *aBoard) const
formats the board setup information
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.
std::function< bool(wxString aTitle, int aIcon, wxString aMsg, wxString aAction)> m_queryUserCallback
BOARD_ITEM * Parse(const wxString &aClipboardSourceInput)
void init(const std::map< std::string, UTF8 > *aProperties)
void Format(const BOARD_ITEM *aItem) const
Output aItem to aFormatter in s-expression format.
void formatLayer(PCB_LAYER_ID aLayer, bool aIsKnockout=false) const
void formatHeader(const BOARD *aBoard) const
writes everything that comes before the board_items, like settings and layers etc
const FOOTPRINT * getFootprint(const wxString &aLibraryPath, const wxString &aFootprintName, const std::map< std::string, UTF8 > *aProperties, bool checkModified)
PCB_IO_KICAD_SEXPR(int aControlFlags=CTL_FOR_BOARD)
OUTPUTFORMATTER * m_out
output any Format()s to this, no ownership
void validateCache(const wxString &aLibraryPath, bool checkModified=true)
virtual ~PCB_IO_KICAD_SEXPR()
void formatRenderCache(const EDA_TEXT *aText) const
LINE_READER * m_reader
no ownership
BOARD * m_board
The board BOARD being worked on, no ownership here.
virtual bool CanReadBoard(const wxString &aFileName) const
Checks if this PCB_IO can read the specified board file.
PCB_IO(const wxString &aName)
const std::map< std::string, UTF8 > * m_props
Properties passed via Save() or Load(), no ownership, may be NULL.
void Format(OUTPUTFORMATTER *aFormatter) const
A PCB_POINT is a 0-dimensional point that is used to mark a position on a PCB, or more usually a foot...
VECTOR2I GetLibraryPosition() const
Object to handle a bitmap image that can be inserted in a PCB.
VECTOR2I GetPosition() const override
Get the position of the image (this is the center of the image).
REFERENCE_IMAGE & GetReferenceImage()
EDA_ANGLE GetLibraryEllipseEndAngle() const
std::optional< int > GetLocalSolderMaskMargin() const
bool HasSolderMask() const
int GetLibraryEllipseMinorRadius() const
EDA_ANGLE GetLibraryEllipseStartAngle() const
int GetLibraryEllipseMajorRadius() const
EDA_ANGLE GetLibraryEllipseRotation() const
SHAPE_T GetLibraryShape() const
VECTOR2I GetLibraryEllipseCenter() const
VECTOR2I GetLibraryEnd() const
const SHAPE_POLY_SET & GetLibPoly() const
VECTOR2I GetLibraryStart() const
virtual LSET GetLayerSet() const override
Return a std::bitset of all layers on which the item physically resides.
STROKE_PARAMS GetStroke() const override
VECTOR2I GetLibraryArcMid() const
PCB_LAYER_ID GetLayer() const override
Return the primary layer this item is on.
bool StrokeHeaderSeparator() const
bool StrokeColumns() const
bool StrokeExternal() const
std::vector< PCB_TABLECELL * > GetCells() const
const STROKE_PARAMS & GetSeparatorsStroke() const
const STROKE_PARAMS & GetBorderStroke() const
int GetColWidth(int aCol) const
int GetRowHeight(int aRow) const
VECTOR2I GetPosition() const override
bool IsBorderEnabled() const
Disables the border, this is done by changing the stroke internally.
int GetMarginBottom() const
EDA_ANGLE GetTextAngle() const override
int GetMarginLeft() const
int GetMarginRight() const
EDA_ANGLE GetTextAngle() const override
VECTOR2I GetTextPos() const override
virtual LSET GetLayerSet() const override
Return a std::bitset of all layers on which the item physically resides.
bool HasSolderMask() const
std::optional< int > GetLocalSolderMaskMargin() const
const VECTOR2I & GetStart() const
const VECTOR2I & GetEnd() const
virtual int GetWidth() const
A progress reporter interface for use in multi-threaded environments.
Container for project specific data.
A REFERENCE_IMAGE is a wrapper around a BITMAP_IMAGE that is displayed in an editor as a reference fo...
const BITMAP_BASE & GetImage() const
Get the underlying image.
double GetImageScale() const
const VECTOR2I & GetArcMid() const
const VECTOR2I & GetP1() const
const VECTOR2I & GetP0() const
Represent a polyline containing arcs as well as line segments: A chain of connected line and/or arc s...
const SHAPE_ARC & Arc(size_t aArc) const
int PointCount() const
Return the number of points (vertices) in this line chain.
ssize_t ArcIndex(size_t aSegment) const
Return the arc index for the given segment index.
const VECTOR2I & CPoint(int aIndex) const
Return a reference to a given point in the line chain.
Represent a set of closed polygons.
POLYGON & Polygon(int aIndex)
Return the aIndex-th subpolygon in the set.
std::vector< SHAPE_LINE_CHAIN > POLYGON
represents a single polygon outline with holes.
SHAPE_LINE_CHAIN & Outline(int aIndex)
Return the reference to aIndex-th outline in the set.
int OutlineCount() const
Return the number of outlines in the set.
Is a LINE_READER that reads from a multiline 8 bit wide std::string.
Simple container to manage line stroke parameters.
void SetWidth(int aWidth)
void Format(OUTPUTFORMATTER *out, const EDA_IU_SCALE &aIuScale) const
TEARDROP_PARAMETARS is a helper class to handle parameters needed to build teardrops for a board thes...
double m_BestWidthRatio
The height of a teardrop as ratio between height and size of pad/via.
int m_TdMaxLen
max allowed length for teardrops in IU. <= 0 to disable
bool m_AllowUseTwoTracks
True to create teardrops using 2 track segments if the first in too small.
int m_TdMaxWidth
max allowed height for teardrops in IU. <= 0 to disable
double m_BestLengthRatio
The length of a teardrop as ratio between length and size of pad/via.
double m_WidthtoSizeFilterRatio
The ratio (H/D) between the via/pad size and the track width max value to create a teardrop 1....
bool m_TdOnPadsInZones
A filter to exclude pads inside zone fills.
bool m_Enabled
Flag to enable teardrops.
bool m_CurvedEdges
True if the teardrop should be curved.
virtual void Format(OUTPUTFORMATTER *aFormatter) const
Output the object to aFormatter in s-expression form.
const char * c_str() const
A wrapper around a wxFileName which is much more performant with a subset of the API.
void SetFullName(const wxString &aFileNameAndExtension)
static void ResolvePossibleSymlinks(wxFileName &aFilename)
wxString GetFullPath() const
Handle a list of polygons defining a copper zone.
int GetHatchBorderAlgorithm() const
bool GetIsRuleArea() const
Accessors to parameters used in Rule Area zones:
std::optional< int > GetLocalClearance() const override
const THIEVING_SETTINGS & GetThievingSettings() const
bool GetDoNotAllowVias() const
ZONE_LAYER_PROPERTIES & LayerProperties(PCB_LAYER_ID aLayer)
wxString GetPlacementAreaSource() const
std::shared_ptr< SHAPE_POLY_SET > GetFilledPolysList(PCB_LAYER_ID aLayer) const
bool GetDoNotAllowPads() const
PLACEMENT_SOURCE_T GetPlacementAreaSourceType() const
bool GetDoNotAllowTracks() const
ISLAND_REMOVAL_MODE GetIslandRemovalMode() const
SHAPE_POLY_SET * Outline()
bool IsIsland(PCB_LAYER_ID aLayer, int aPolyIdx) const
Check if a given filled polygon is an insulated island.
long long int GetMinIslandArea() const
const wxString & GetZoneName() const
int GetMinThickness() const
ZONE_CONNECTION GetPadConnection() const
int GetHatchThickness() const
double GetHatchHoleMinArea() const
bool GetPlacementAreaEnabled() const
bool IsTeardropArea() const
int GetThermalReliefSpokeWidth() const
int GetBorderHatchPitch() const
HatchBorder related methods.
ZONE_BORDER_DISPLAY_STYLE GetHatchStyle() const
EDA_ANGLE GetHatchOrientation() const
bool GetDoNotAllowFootprints() const
ZONE_FILL_MODE GetFillMode() const
virtual LSET GetLayerSet() const override
Return a std::bitset of all layers on which the item physically resides.
TEARDROP_TYPE GetTeardropAreaType() const
double GetHatchSmoothingValue() const
bool GetDoNotAllowZoneFills() const
int GetHatchSmoothingLevel() const
unsigned int GetCornerRadius() const
int GetCornerSmoothingType() const
bool IsOnCopperLayer() const override
PCB_LAYER_ID GetFirstLayer() const
int GetThermalReliefGap() const
unsigned GetAssignedPriority() const
int GetNumCorners(void) const
Access to m_Poly parameters.
This file is part of the common library.
@ RECT_CHAMFER_BOTTOM_RIGHT
@ RECT_CHAMFER_BOTTOM_LEFT
#define CTL_OMIT_HYPERLINK
Omit the hyperlink attribute in .kicad_xxx files.
#define CTL_OMIT_UUIDS
Omit component unique ids (useless in library)
#define CTL_OMIT_FOOTPRINT_VERSION
Omit the version string from the (footprint) sexpr group.
#define CTL_OMIT_INITIAL_COMMENTS
Omit FOOTPRINT initial comments.
#define CTL_OMIT_LIBNAME
Omit lib alias when saving (used for board/not library).
#define CTL_OMIT_PATH
Omit component sheet time stamp (useless in library).
#define CTL_OMIT_AT
Omit position and rotation.
#define CTL_OMIT_PAD_NETS
Omit pads net names (useless in library).
#define CTL_OMIT_COLOR
Omit the color attribute in .kicad_xxx files.
static constexpr EDA_ANGLE ANGLE_0
static constexpr EDA_ANGLE ANGLE_90
static constexpr EDA_ANGLE ANGLE_45
#define IGNORE_PARENT_GROUP
@ RECTANGLE
Use RECTANGLE instead of RECT to avoid collision in a Windows header.
@ FILLED_SHAPE
Fill with object color.
EDA_DATA_TYPE
The type of unit.
void CollectFilesLoopSafe(const wxString &aRoot, wxArrayString &aFiles, const wxString &aFileSpec, int aFlags)
Recursively collect every file under aRoot, deduplicating subdirectories by their resolved path.
static const std::string KiCadFootprintFileExtension
const wxChar *const traceKicadPcbPlugin
Flag to enable KiCad PCB plugin debug output.
#define THROW_IO_ERROR(msg)
macro which captures the "call site" values of FILE_, __FUNCTION & LINE
#define THROW_PARSE_ERROR(aProblem, aSource, aInputLine, aLineNumber, aByteIndex)
bool IsCopperLayer(int aLayerId)
Test whether a layer is a copper layer.
bool IsExternalCopperLayer(int aLayerId)
Test whether a layer is an external (F_Cu or B_Cu) copper layer.
PCB_LAYER_ID
A quick note on layer IDs:
This file contains miscellaneous commonly used macros and functions.
#define UNIMPLEMENTED_FOR(type)
@ TOP_BOTTOM
Flip top to bottom (around the X axis)
KICOMMON_API std::string FormatAngle(const EDA_ANGLE &aAngle)
Convert aAngle from board units to a string appropriate for writing to file.
KICOMMON_API std::string FormatInternalUnits(const EDA_IU_SCALE &aIuScale, int aValue, EDA_DATA_TYPE aDataType=EDA_DATA_TYPE::DISTANCE)
Converts aValue from internal units to a string appropriate for writing to file.
constexpr char APPEND_PRESERVE_DESTINATION_STACKUP[]
@ NPTH
like PAD_PTH, but not plated mechanical use only, no connection allowed
@ SMD
Smd pad, appears on the solder paste layer (default)
@ PTH
Plated through hole pad.
@ CONN
Like smd, does not appear on the solder paste layer (default) Note: also has a special attribute in G...
@ FIDUCIAL_LOCAL
a fiducial (usually a smd) local to the parent footprint
@ FIDUCIAL_GLBL
a fiducial (usually a smd) for the full board
@ MECHANICAL
a pad used for mechanical support
@ PRESSFIT
a PTH with a hole diameter with tight tolerances for press fit pin
@ HEATSINK
a pad used as heat sink, usually in SMD footprints
@ NONE
no special fabrication property
@ TESTPOINT
a test point pad
@ CASTELLATED
a pad with a castellated through hole
@ BGA
Smd pad, used in BGA footprints.
@ REMOVE_EXCEPT_START_AND_END
BARCODE class definition.
Class to handle a set of BOARD_ITEMs.
bool isDefaultTeardropParameters(const TEARDROP_PARAMETERS &tdParams)
static VECTOR2I unbakeSize(const VECTOR2I &aSize, const FOOTPRINT *aParentFP)
std::string formatInternalUnits(const int aValue, const EDA_DATA_TYPE aDataType=EDA_DATA_TYPE::DISTANCE)
static int unbakeLinear(int aValue, const FOOTPRINT *aParentFP)
static VECTOR2I unbakeSizeUniform(const VECTOR2I &aSize, const FOOTPRINT *aParentFP)
#define SEXPR_BOARD_FILE_VERSION
Current s-expression file format version. 2 was the last legacy format version.
#define CTL_FOR_BOARD
The zero arg constructor when PCB_PLUGIN is used for PLUGIN::Load() and PLUGIN::Save()ing a BOARD fil...
#define CTL_FOR_LIBRARY
Format output for a footprint library instead of clipboard or BOARD.
Pcbnew s-expression file format parser definition.
#define UNDEFINED_DRILL_DIAMETER
PGM_BASE & Pgm()
The global program "get" accessor.
std::string FormatDouble2Str(double aValue)
Print a float number without using scientific notation and no trailing 0 This function is intended in...
bool ReplaceIllegalFileNameChars(std::string &aName, int aReplaceChar)
Checks aName for illegal file name characters.
int ValueStringCompare(const wxString &strFWord, const wxString &strSWord)
Compare strings like the strcmp function but handle numbers and modifiers within the string text corr...
#define TO_UTF8(wxstring)
Convert a wxString to a UTF8 encoded C string for all wxWidgets build modes.
VECTOR2I size
Drill diameter (x == y) or slot dimensions (x != y)
std::optional< bool > is_capped
True if the drill hole should be capped.
std::optional< bool > is_filled
True if the drill hole should be filled completely.
std::optional< bool > has_covering
True if the pad on this side should have covering.
std::optional< bool > has_solder_mask
True if this outer layer has mask (is not tented)
std::optional< bool > has_plugging
True if the drill hole should be plugged on this side.
A filename or source description, a problem input line, a line number, a byte offset,...
Parameters that drive copper-thieving fill generation.
std::optional< VECTOR2I > hatching_offset
const SHAPE_LINE_CHAIN chain
wxLogTrace helper definitions.
@ 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_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_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
Definition of file extensions used in Kicad.
@ THERMAL
Use thermal relief for pads.
@ THT_THERMAL
Thermal relief only for THT pads.
@ NONE
Pads are not covered.
@ FULL
pads are covered by copper