92 return std::optional<int>();
95 return std::optional<int>( stackup.
GetLayerDistance( aStartLayer, aEndLayer ) );
98 if( !aGenerateNPTH_list )
115 std::max( aDrill.start, aDrill.end ) );
117 if( drillPair != aSpan.
Pair() )
126 if( aDrill.size.x <= 0 && aDrill.size.y <= 0 )
140 int diameter = aDrill.size.x;
142 if( aDrill.size.y > 0 )
143 diameter = ( diameter > 0 ) ? std::min( diameter, aDrill.size.y )
150 && aDrill.size.x != aDrill.size.y )
180 hole.
m_StubLength = computeStubLength( aDrill.start, aDrill.end );
189 tryEmitBackdrill(
via->Padstack().SecondaryDrill() );
190 tryEmitBackdrill(
via->Padstack().TertiaryDrill() );
194 int hole_sz =
via->GetDrillValue();
201 via->LayerPair( &top_layer, &bottom_layer );
256 for(
PAD*
pad : footprint->Pads() )
267 if(
pad->GetDrillSize().x == 0 )
293 &&
pad->GetDrillSizeX() !=
pad->GetDrillSizeY() )
313 bool last_notplated_opt =
false;
389 std::set<DRILL_SPAN> unique;
391 for(
int i = 0; i < vias.
GetCount(); ++i )
397 via->LayerPair( &top_layer, &bottom_layer );
400 unique.emplace( top_layer, bottom_layer,
false,
false );
407 if( aDrill.size.x <= 0 && aDrill.size.y <= 0 )
410 unique.emplace( aDrill.start, aDrill.end,
true,
false );
413 addBackdrillSpan(
via->Padstack().SecondaryDrill() );
414 addBackdrillSpan(
via->Padstack().TertiaryDrill() );
417 std::vector<DRILL_SPAN> ret;
419 ret.emplace_back(
F_Cu,
B_Cu,
false,
false );
424 ret.push_back( span );
443 int ly_id = ( aLayer -
B_Cu ) / 2;
444 return fmt::format(
"in{}", ly_id );
452 std::string ret =
layerName( aPair.first );
461 bool aMerge_PTH_NPTH )
const
469 int conventional_layer_num = 1;
473 if( layer == aLayer )
474 return conventional_layer_num;
476 conventional_layer_num++;
479 return conventional_layer_num;
484 extend.Printf( wxT(
"_Backdrills_Drill_%d_%d" ),
490 extend = wxT(
"-NPTH" );
494 if( !aMerge_PTH_NPTH )
495 extend = wxT(
"-PTH" );
504 wxFileName fn =
m_pcb->GetFileName();
506 fn.SetName( fn.GetName() + extend );
509 wxString ret = fn.GetFullName();
525 extend << wxT(
"-filling-" );
529 extend << wxT(
"-capping-" );
533 extend << wxT(
"-covering-" );
537 extend << wxT(
"-covering-" );
541 extend << wxT(
"-plugging-" );
545 extend << wxT(
"-plugging-" );
549 extend << wxT(
"-tenting-" );
553 extend << wxT(
"-tenting-" );
558 wxFileName fn =
m_pcb->GetFileName();
560 fn.SetName( fn.GetName() + extend );
563 wxString ret = fn.GetFullName();
577 hole_sets.emplace_back(
F_Cu,
B_Cu,
false,
true );
579 for( std::vector<DRILL_SPAN>::const_iterator it = hole_sets.begin(); it != hole_sets.end(); ++it )
589 fn.SetPath( aPlotDirectory );
591 fn.SetExt( wxEmptyString );
592 wxString fullfilename = fn.GetFullPath() + wxT(
"-drl_map" );
601 msg.Printf(
_(
"Failed to create file '%s'." ), fullfilename );
611 msg.Printf(
_(
"Created file '%s'." ), fullfilename );
624 bool aCompatNCdrill )
const
631 text = wxT(
"; #@! " );
635 text << wxT(
"TF.FileFunction," );
638 text << wxT(
"NonPlated," );
640 text << wxT(
"MixedPlating," );
642 text << wxT(
"Plated," );
644 int layer1 = aSpan.
Pair().first;
645 int layer2 = aSpan.
Pair().second;
655 else if( layer1 ==
B_Cu )
656 layer1 =
m_pcb->GetCopperLayerCount();
658 layer1 = ( ( layer1 -
B_Cu ) / 2 ) + 1;
662 else if( layer2 ==
B_Cu )
663 layer2 =
m_pcb->GetCopperLayerCount();
665 layer2 = ( ( layer2 -
B_Cu ) / 2) + 1;
668 if( layer1 > layer2 )
669 std::swap( layer1, layer2 );
671 text << layer1 << wxT(
"," ) << layer2;
675 int bottomlayer =
m_pcb->GetCopperLayerCount();
678 text << wxT(
",Blind" );
680 text << wxT(
",NPTH" );
683 else if( layer1 == toplayer && layer2 == bottomlayer )
684 text << wxT(
",PTH" );
685 else if( layer1 == toplayer || layer2 == bottomlayer )
686 text << wxT(
",Blind" );
688 text << wxT(
",Buried" );
699 bool hasOblong =
false;
700 bool hasDrill =
false;
712 if( hasOblong && hasDrill )
713 text << wxT(
",Mixed" );
715 text << wxT(
",Drill" );
717 text << wxT(
",Rout" );
745 int bestsize = aMarkerDiameter / 10;
747 const double MIN_SIZE_MM = 0.1;
748 bestsize = std::max( bestsize,
pcbIUScale.mmToIU( MIN_SIZE_MM ) );
757 const double SKETCH_LINE_WIDTH_MM = 0.1;
758 return pcbIUScale.mmToIU( SKETCH_LINE_WIDTH_MM );
765 const double DEFAULT_LINE_WIDTH_MM = 0.2;
766 return pcbIUScale.mmToIU( DEFAULT_LINE_WIDTH_MM );
780 int bottom_limit = 0;
788 LSET visibleLayers =
m_pcb->GetVisibleLayers();
790 BOX2I bbbox =
m_pcb->GetBoardEdgesBoundingBox();
791 m_pcb->SetVisibleLayers( visibleLayers );
821 double Xscale = double( pageSizeIU.
x - ( 2 * margin ) ) / bbbox.
GetWidth();
825 int ypagesize_for_board =
KiROUND( pageSizeIU.
y * 0.6 );
826 double Yscale = double( ypagesize_for_board - margin ) / bbbox.
GetHeight();
828 scale = std::min( Xscale, Yscale );
841 bottom_limit = ( pageSizeIU.
y - margin ) / std::min(
scale, 1.0 );
861 plotter = dxf_plotter;
876 if( !plotter->
OpenFile( aFullFileName ) )
899 text =
"%TF.FileFunction,Drillmap*%";
903 text = wxT(
"%TF.FilePolarity,Positive*%" );
921 switch( item->Type() )
939 for(
BOARD_ITEM* item : footprint->GraphicalItems() )
944 switch( item->Type() )
960 int plotX, plotY, TextWidth;
964 int textmarginaftersymbol =
pcbIUScale.mmToIU( 2 );
980 double charScale = std::min( 1.0, 1.0 /
scale );
982 TextWidth =
KiROUND( ( charSize * charScale ) / 10.0 );
983 intervalle =
KiROUND( charSize * charScale ) + TextWidth;
986 plotX =
KiROUND( bbbox.
GetX() + textmarginaftersymbol * charScale );
990 wxString Text = wxT(
"Drill Map:" );
995 attrs.
m_Size =
KiROUND( charSize * charScale, charSize * charScale );
1006 int max_line_len = 0;
1015 plotY += intervalle;
1018 if( bottom_limit && ( plotY + intervalle > bottom_limit ) )
1021 plotX += max_line_len +
pcbIUScale.mmToIU( 10 );
1028 plot_diam = std::min( plot_diam,
KiROUND( charSize * charScale ) );
1029 int x =
KiROUND( plotX - textmarginaftersymbol * charScale - plot_diam / 2.0 );
1030 int y =
KiROUND( plotY + charSize * charScale );
1044 extraInfo += wxT(
", castellated" );
1046 extraInfo += wxT(
", press-fit" );
1057 extraInfo += wxString::Format( wxT(
", backdrill stub %.3f-%.3fmm" ), minStub, maxStub );
1061 extraInfo += wxString::Format( wxT(
", backdrill stub %.3fmm" ), minStub );
1066 extraInfo += wxT(
", backdrill" );
1071 extraInfo += wxT(
", post-machined" );
1076 counts.Printf( wxT(
"(1 hole%s)" ), extraInfo );
1078 counts.Printf( wxT(
"(1 slot%s)" ), extraInfo );
1080 counts.Printf( wxT(
"(%d holes%s)" ), tool.
m_TotalCount, extraInfo );
1082 counts.Printf( wxT(
"(%d holes + 1 slot%s)" ), tool.
m_TotalCount - 1, extraInfo );
1090 msg += wxT(
" (not plated)" );
1095 intervalle =
KiROUND( ( ( charSize * charScale ) + TextWidth ) * 1.2 );
1097 if( intervalle < ( plot_diam + ( 1 *
pcbIUScale.IU_PER_MM /
scale ) + TextWidth ) )
1098 intervalle = plot_diam + ( 1 *
pcbIUScale.IU_PER_MM /
scale ) + TextWidth;
1102 int text_len = msg.Len() * ( ( charSize * charScale ) + TextWidth );
1103 max_line_len = std::max( max_line_len, text_len + plot_diam );
1115 wxFFile out( aFullFileName,
"wb" );
1117 if( !out.IsOpened() )
1121 wxString msg = wxString::Format(
_(
"Error creating drill report file '%s'" ),
1129 FILE* outFp = out.fp();
1131 static const char separator[] =
1132 " =============================================================\n";
1136 unsigned totalHoleCount;
1137 wxFileName brdFilename(
m_pcb->GetFileName() );
1141 bool writeError =
false;
1145 fmt::print( outFp,
"Drill report for {}\n",
TO_UTF8( brdFilename.GetFullName() ) );
1149 fmt::print( outFp,
"Copper Layer Stackup:\n" );
1150 fmt::print( outFp,
"{}", separator );
1152 int conventional_layer_num = 1;
1156 fmt::print( outFp,
" L{:<2}: {:<25} {}\n", conventional_layer_num++,
1161 fmt::print( outFp,
"\n\n" );
1169 bool buildNPTHlist =
false;
1172 for(
unsigned pair_ndx = 0; pair_ndx < hole_sets.size(); ++pair_ndx )
1174 const DRILL_SPAN& span = hole_sets[pair_ndx];
1180 fmt::print( outFp,
"Drill file '{}' contains\n",
1183 fmt::print( outFp,
" plated through holes:\n" );
1184 fmt::print( outFp,
"{}", separator );
1186 fmt::print( outFp,
" Total plated holes count {}\n", totalHoleCount );
1190 fmt::print( outFp,
"Drill file '{}' contains\n",
1193 fmt::print( outFp,
" backdrill span: '{}' to '{}':\n",
1197 fmt::print( outFp,
"{}", separator );
1199 fmt::print( outFp,
" Total backdrilled holes count {}\n", totalHoleCount );
1203 fmt::print( outFp,
"Drill file '{}' contains\n",
1206 fmt::print( outFp,
" holes connecting layer pair: '{} and {}' ({} vias):\n",
1209 span.
Pair().first ==
F_Cu || span.
Pair().second ==
B_Cu ?
"blind" :
"buried" );
1211 fmt::print( outFp,
"{}", separator );
1213 fmt::print( outFp,
" Total plated holes count {}\n", totalHoleCount );
1216 fmt::print( outFp,
"\n\n" );
1222 buildNPTHlist =
true;
1230 fmt::print( outFp,
"Not plated through holes are merged with plated holes\n" );
1232 fmt::print( outFp,
"Drill file '{}' contains\n",
1235 fmt::print( outFp,
" unplated through holes:\n" );
1236 fmt::print( outFp,
"{}", separator );
1238 fmt::print( outFp,
" Total unplated holes count {}\n", totalHoleCount );
1240 catch(
const std::system_error& )
1244 catch(
const fmt::format_error& )
1249 if( writeError && aReporter )
1251 wxString msg = wxString::Format(
_(
"Error writing drill report file '%s'" ), aFullFileName );
1287 unsigned totalHoleCount = 0;
1300 int tool_number = ii+1;
1301 fmt::print( out,
" T{} {:2.3f}mm {:2.4f}\" ", tool_number,
1307 fmt::print( out,
"(1 hole" );
1309 fmt::print( out,
"(1 hole) (with 1 slot" );
1313 fmt::print( out,
"({} holes) (with 1 slot", tool.
m_TotalCount );
1318 fmt::print( out,
", castellated" );
1321 fmt::print( out,
", press-fit" );
1323 fmt::print( out,
")\n" );
1328 fmt::print( out,
"\n" );
1330 return totalHoleCount;
constexpr EDA_IU_SCALE pcbIUScale
constexpr BOX2I KiROUND(const BOX2D &aBoxD)
A base class for any item which can be embedded within the BOARD container class, and therefore insta...
Manage layers needed to make a physical board.
int GetLayerDistance(PCB_LAYER_ID aFirstLayer, PCB_LAYER_ID aSecondLayer) const
Calculate the distance (height) between the two given copper layers.
constexpr size_type GetWidth() const
constexpr Vec Centre() const
constexpr coord_type GetX() const
constexpr size_type GetHeight() const
constexpr coord_type GetBottom() const
void SetLayerSet(const LSET &aLayerMask)
void PlotShape(const PCB_SHAPE *aShape)
int GetCount() const
Return the number of objects in the list.
static const COLOR4D UNSPECIFIED
For legacy support; used as a value to indicate color hasn't been set yet.
void SetUnits(DXF_UNITS aUnit)
Set the units to use for plotting the DXF file.
virtual void SetParentGroup(EDA_GROUP *aGroup)
virtual const wxString getProtectionFileName(const DRILL_SPAN &aSpan, IPC4761_FEATURES aFeature) const
const PAGE_INFO * m_pageInfo
wxString m_drillFileExtension
std::vector< HOLE_INFO > m_holeListBuffer
void buildHolesList(const DRILL_SPAN &aSpan, bool aGenerateNPTH_list)
Create the list of holes and tools for a given board.
bool genDrillMapFile(const wxString &aFullFileName, PLOT_FORMAT aFormat)
Plot a map of drill marks for holes.
VECTOR2I GetOffset()
Return the plot offset (usually the position of the drill/place origin).
std::vector< DRILL_SPAN > getUniqueLayerPairs() const
Get unique layer pairs by examining the micro and blind_buried vias.
std::vector< DRILL_TOOL > m_toolListBuffer
const std::string layerPairName(DRILL_LAYER_PAIR aPair) const
bool CreateMapFilesSet(const wxString &aPlotDirectory, REPORTER *aReporter=nullptr)
Create the full set of map files for the board, in PS, PDF ... format (use SetMapFileFormat() to sele...
const std::string layerName(PCB_LAYER_ID aLayer) const
unsigned printToolSummary(FILE *out, bool aSummaryNPTH) const
Print m_toolListBuffer[] tools to aOut and returns total hole count.
int getHolesCount() const
virtual const wxString getDrillFileName(const DRILL_SPAN &aSpan, bool aNPTH, bool aMerge_PTH_NPTH) const
bool plotDrillMarks(PLOTTER *aPlotter)
Write the drill marks in PDF, POSTSCRIPT or other supported formats/.
const wxString BuildFileFunctionAttributeString(const DRILL_SPAN &aSpan, TYPE_FILE aHoleType, bool aCompatNCdrill=false) const
bool GenDrillReportFile(const wxString &aFullFileName, REPORTER *aReporter=nullptr)
Create a plain text report file giving a list of drill values and drill count for through holes,...
void UseX2format(bool aEnable)
void UseX2NetAttributes(bool aEnable)
void DisableApertMacros(bool aDisable)
Disable Aperture Macro (AM) command, only for broken Gerber Readers.
Handle hole which must be drilled (diameter, position and layers).
int m_FrontPostMachiningDepth
PAD_DRILL_POST_MACHINING_MODE m_FrontPostMachining
PCB_LAYER_ID m_Hole_Bottom_Layer
std::optional< int > m_StubLength
PCB_LAYER_ID m_Hole_Top_Layer
HOLE_ATTRIBUTE m_HoleAttribute
int m_FrontPostMachiningAngle
PCB_LAYER_ID m_DrillStart
BOARD_ITEM * m_ItemParent
int m_BackPostMachiningDepth
int m_BackPostMachiningSize
PAD_DRILL_POST_MACHINING_MODE m_BackPostMachining
int m_FrontPostMachiningSize
int m_BackPostMachiningAngle
static const METRICS & Default()
PCB specific render settings.
void SetDefaultPenWidth(int aWidth)
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.
Describe the page size and margins of a paper page on which to eventually print or plot.
const VECTOR2D GetSizeIU(double aIUScale) const
Gets the page size in internal units.
Parameters and options when plotting/printing a board.
void SetLayer(PCB_LAYER_ID aLayer) override
Set the layer this item is on.
Collect all BOARD_ITEM objects of a given set of KICAD_T type(s).
void Collect(BOARD_ITEM *aBoard, const std::vector< KICAD_T > &aTypes)
Collect BOARD_ITEM objects using this class's Inspector method, which does the collection.
Base plotter engine class.
virtual bool OpenFile(const wxString &aFullFilename)
Open or create the plot file aFullFilename.
virtual void SetPageSettings(const PAGE_INFO &aPageSettings)
void SetRenderSettings(RENDER_SETTINGS *aSettings)
static const int USE_DEFAULT_LINE_WIDTH
virtual void ThickOval(const VECTOR2I &aPos, const VECTOR2I &aSize, const EDA_ANGLE &aOrient, int aWidth, void *aData)
virtual bool StartPlot(const wxString &aPageNumber)=0
virtual void SetGerberCoordinatesFormat(int aResolution, bool aUseInches=false)
virtual PLOT_FORMAT GetPlotterType() const =0
Return the effective plot engine in use.
void Marker(const VECTOR2I &position, int diametre, unsigned aShapeId)
Draw a pattern shape number aShapeId, to coord position.
virtual void SetCreator(const wxString &aCreator)
void ClearHeaderLinesList()
Remove all lines from the list of free lines to print at the beginning of the file.
virtual void SetViewport(const VECTOR2I &aOffset, double aIusPerDecimil, double aScale, bool aMirror)=0
Set the plot offset and scaling for the current plot.
void AddLineToHeader(const wxString &aExtraString)
Add a line to the list of free lines to print at the beginning of the file.
virtual void SetColorMode(bool aColorMode)
Plot in B/W or color.
virtual void SetCurrentLineWidth(int width, void *aData=nullptr)=0
Set the line width for the next drawing.
virtual void PlotText(const VECTOR2I &aPos, const COLOR4D &aColor, const wxString &aText, const TEXT_ATTRIBUTES &aAttributes, KIFONT::FONT *aFont=nullptr, const KIFONT::METRICS &aFontMetrics=KIFONT::METRICS::Default(), void *aData=nullptr)
A pure virtual class used to derive REPORTER objects from.
virtual REPORTER & Report(const wxString &aText, SEVERITY aSeverity=RPT_SEVERITY_UNDEFINED)
Report a string with a given severity.
GR_TEXT_H_ALIGN_T m_Halign
GR_TEXT_V_ALIGN_T m_Valign
wxString GetDefaultPlotExtension(PLOT_FORMAT aFormat)
Return the default plot extension for a format.
static constexpr EDA_ANGLE ANGLE_0
static constexpr EDA_ANGLE ANGLE_HORIZONTAL
double diameter_in_mm(double ius)
double diameter_in_inches(double ius)
static bool cmpHoleSorting(const HOLE_INFO &a, const HOLE_INFO &b)
static int getMarkerBestPenSize(int aMarkerDiameter)
int getSketchOvalBestPenSize()
helper classes to handle hole info for drill files generators.
#define USE_ATTRIB_FOR_HOLES
std::pair< PCB_LAYER_ID, PCB_LAYER_ID > DRILL_LAYER_PAIR
PCB_LAYER_ID
A quick note on layer IDs:
PCB_LAYER_ID ToLAYER_ID(int aLayer)
This file contains miscellaneous commonly used macros and functions.
#define KI_FALLTHROUGH
The KI_FALLTHROUGH macro is to be used when switch statement cases should purposely fallthrough from ...
@ 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
void AddGerberX2Header(PLOTTER *aPlotter, const BOARD *aBoard, bool aUseX1CompatibilityMode)
Calculate some X2 attributes as defined in the Gerber file format specification J4 (chapter 5) and ad...
PLOT_FORMAT
The set of supported output plot formats.
Plotting engines similar to ps (PostScript, Gerber, svg)
std::vector< FAB_LAYER_COLOR > dummy
wxString From_UTF8(const char *cstring)
wxString GetISO8601CurrentDateTime()
#define TO_UTF8(wxstring)
Convert a wxString to a UTF8 encoded C string for all wxWidgets build modes.
DRILL_LAYER_PAIR Pair() const
PCB_LAYER_ID DrillEndLayer() const
PCB_LAYER_ID TopLayer() const
PCB_LAYER_ID DrillStartLayer() const
PCB_LAYER_ID BottomLayer() const
! The properties of a padstack drill. Drill position is always the pad position (origin).
@ PCB_SHAPE_T
class PCB_SHAPE, a segment not on copper layers
@ PCB_VIA_T
class PCB_VIA, a via (like a track segment on a copper layer)
VECTOR2< int32_t > VECTOR2I