92 return std::optional<int>();
95 return std::optional<int>( stackup.
GetLayerDistance( aStartLayer, aEndLayer ) );
98 if( !aGenerateNPTH_list )
115 std::max( secondary.
start, secondary.
end ) );
117 if( secondaryPair != aSpan.
Pair() )
126 if( secondary.
size.
x <= 0 && secondary.
size.
y <= 0 )
140 int diameter = secondary.
size.
x;
142 if( secondary.
size.
y > 0 )
143 diameter = ( diameter > 0 ) ? std::min( diameter, secondary.
size.
y )
186 int hole_sz =
via->GetDrillValue();
193 via->LayerPair( &top_layer, &bottom_layer );
243 for(
PAD*
pad : footprint->Pads() )
254 if(
pad->GetDrillSize().x == 0 )
280 &&
pad->GetDrillSizeX() !=
pad->GetDrillSizeY() )
300 bool last_notplated_opt =
false;
376 std::set<DRILL_SPAN> unique;
378 for(
int i = 0; i < vias.
GetCount(); ++i )
384 via->LayerPair( &top_layer, &bottom_layer );
387 unique.emplace( top_layer, bottom_layer,
false,
false );
394 if( secondary.
size.
x <= 0 && secondary.
size.
y <= 0 )
397 unique.emplace( secondary.
start, secondary.
end,
true,
false );
400 std::vector<DRILL_SPAN> ret;
402 ret.emplace_back(
F_Cu,
B_Cu,
false,
false );
407 ret.push_back( span );
426 int ly_id = ( aLayer -
B_Cu ) / 2;
427 return fmt::format(
"in{}", ly_id );
435 std::string ret =
layerName( aPair.first );
444 bool aMerge_PTH_NPTH )
const
452 int conventional_layer_num = 1;
456 if( layer == aLayer )
457 return conventional_layer_num;
459 conventional_layer_num++;
462 return conventional_layer_num;
467 extend.Printf( wxT(
"_Backdrills_Drill_%d_%d" ),
473 extend = wxT(
"-NPTH" );
477 if( !aMerge_PTH_NPTH )
478 extend = wxT(
"-PTH" );
487 wxFileName fn =
m_pcb->GetFileName();
489 fn.SetName( fn.GetName() + extend );
492 wxString ret = fn.GetFullName();
508 extend << wxT(
"-filling-" );
512 extend << wxT(
"-capping-" );
516 extend << wxT(
"-covering-" );
520 extend << wxT(
"-covering-" );
524 extend << wxT(
"-plugging-" );
528 extend << wxT(
"-plugging-" );
532 extend << wxT(
"-tenting-" );
536 extend << wxT(
"-tenting-" );
541 wxFileName fn =
m_pcb->GetFileName();
543 fn.SetName( fn.GetName() + extend );
546 wxString ret = fn.GetFullName();
560 hole_sets.emplace_back(
F_Cu,
B_Cu,
false,
true );
562 for( std::vector<DRILL_SPAN>::const_iterator it = hole_sets.begin(); it != hole_sets.end(); ++it )
572 fn.SetPath( aPlotDirectory );
574 fn.SetExt( wxEmptyString );
575 wxString fullfilename = fn.GetFullPath() + wxT(
"-drl_map" );
584 msg.Printf(
_(
"Failed to create file '%s'." ), fullfilename );
594 msg.Printf(
_(
"Created file '%s'." ), fullfilename );
607 bool aCompatNCdrill )
const
614 text = wxT(
"; #@! " );
618 text << wxT(
"TF.FileFunction," );
621 text << wxT(
"NonPlated," );
623 text << wxT(
"MixedPlating," );
625 text << wxT(
"Plated," );
627 int layer1 = aSpan.
Pair().first;
628 int layer2 = aSpan.
Pair().second;
638 layer1 = ( ( layer1 -
B_Cu ) / 2 ) + 1;
641 layer2 =
m_pcb->GetCopperLayerCount();
643 layer2 = ( ( layer2 -
B_Cu ) / 2) + 1;
645 text << layer1 << wxT(
"," ) << layer2;
649 int bottomlayer =
m_pcb->GetCopperLayerCount();
652 text << wxT(
",Blind" );
654 text << wxT(
",NPTH" );
657 else if( layer1 == toplayer && layer2 == bottomlayer )
658 text << wxT(
",PTH" );
659 else if( layer1 == toplayer || layer2 == bottomlayer )
660 text << wxT(
",Blind" );
662 text << wxT(
",Buried" );
673 bool hasOblong =
false;
674 bool hasDrill =
false;
686 if( hasOblong && hasDrill )
687 text << wxT(
",Mixed" );
689 text << wxT(
",Drill" );
691 text << wxT(
",Rout" );
719 int bestsize = aMarkerDiameter / 10;
721 const double MIN_SIZE_MM = 0.1;
722 bestsize = std::max( bestsize,
pcbIUScale.mmToIU( MIN_SIZE_MM ) );
731 const double SKETCH_LINE_WIDTH_MM = 0.1;
732 return pcbIUScale.mmToIU( SKETCH_LINE_WIDTH_MM );
739 const double DEFAULT_LINE_WIDTH_MM = 0.2;
740 return pcbIUScale.mmToIU( DEFAULT_LINE_WIDTH_MM );
754 int bottom_limit = 0;
762 LSET visibleLayers =
m_pcb->GetVisibleLayers();
764 BOX2I bbbox =
m_pcb->GetBoardEdgesBoundingBox();
765 m_pcb->SetVisibleLayers( visibleLayers );
795 double Xscale = double( pageSizeIU.
x - ( 2 * margin ) ) / bbbox.
GetWidth();
799 int ypagesize_for_board =
KiROUND( pageSizeIU.
y * 0.6 );
800 double Yscale = double( ypagesize_for_board - margin ) / bbbox.
GetHeight();
802 scale = std::min( Xscale, Yscale );
815 bottom_limit = ( pageSizeIU.
y - margin ) / std::min(
scale, 1.0 );
835 plotter = dxf_plotter;
850 if( !plotter->
OpenFile( aFullFileName ) )
873 text =
"%TF.FileFunction,Drillmap*%";
877 text = wxT(
"%TF.FilePolarity,Positive*%" );
895 switch( item->Type() )
913 for(
BOARD_ITEM* item : footprint->GraphicalItems() )
918 switch( item->Type() )
934 int plotX, plotY, TextWidth;
938 int textmarginaftersymbol =
pcbIUScale.mmToIU( 2 );
954 double charScale = std::min( 1.0, 1.0 /
scale );
956 TextWidth =
KiROUND( ( charSize * charScale ) / 10.0 );
957 intervalle =
KiROUND( charSize * charScale ) + TextWidth;
960 plotX =
KiROUND( bbbox.
GetX() + textmarginaftersymbol * charScale );
964 wxString Text = wxT(
"Drill Map:" );
969 attrs.
m_Size =
KiROUND( charSize * charScale, charSize * charScale );
980 int max_line_len = 0;
992 if( bottom_limit && ( plotY + intervalle > bottom_limit ) )
995 plotX += max_line_len +
pcbIUScale.mmToIU( 10 );
1002 plot_diam = std::min( plot_diam,
KiROUND( charSize * charScale ) );
1003 int x =
KiROUND( plotX - textmarginaftersymbol * charScale - plot_diam / 2.0 );
1004 int y =
KiROUND( plotY + charSize * charScale );
1018 extraInfo += wxT(
", castellated" );
1020 extraInfo += wxT(
", press-fit" );
1031 extraInfo += wxString::Format( wxT(
", backdrill stub %.3f-%.3fmm" ), minStub, maxStub );
1035 extraInfo += wxString::Format( wxT(
", backdrill stub %.3fmm" ), minStub );
1040 extraInfo += wxT(
", backdrill" );
1045 extraInfo += wxT(
", post-machined" );
1050 counts.Printf( wxT(
"(1 hole%s)" ), extraInfo );
1052 counts.Printf( wxT(
"(1 slot%s)" ), extraInfo );
1054 counts.Printf( wxT(
"(%d holes%s)" ), tool.
m_TotalCount, extraInfo );
1056 counts.Printf( wxT(
"(%d holes + 1 slot%s)" ), tool.
m_TotalCount - 1, extraInfo );
1064 msg += wxT(
" (not plated)" );
1069 intervalle =
KiROUND( ( ( charSize * charScale ) + TextWidth ) * 1.2 );
1071 if( intervalle < ( plot_diam + ( 1 *
pcbIUScale.IU_PER_MM /
scale ) + TextWidth ) )
1072 intervalle = plot_diam + ( 1 *
pcbIUScale.IU_PER_MM /
scale ) + TextWidth;
1076 int text_len = msg.Len() * ( ( charSize * charScale ) + TextWidth );
1077 max_line_len = std::max( max_line_len, text_len + plot_diam );
1089 wxFFile out( aFullFileName,
"wb" );
1090 if( !out.IsOpened() )
1092 wxString msg = wxString::Format(
_(
"Error creating drill report file '%s'" ), aFullFileName );
1097 FILE* outFp = out.fp();
1099 static const char separator[] =
1100 " =============================================================\n";
1104 unsigned totalHoleCount;
1105 wxFileName brdFilename(
m_pcb->GetFileName() );
1109 bool writeError =
false;
1113 fmt::print( outFp,
"Drill report for {}\n",
TO_UTF8( brdFilename.GetFullName() ) );
1117 fmt::print( outFp,
"Copper Layer Stackup:\n" );
1118 fmt::print( outFp,
"{}", separator );
1120 int conventional_layer_num = 1;
1124 fmt::print( outFp,
" L{:<2}: {:<25} {}\n", conventional_layer_num++,
1129 fmt::print( outFp,
"\n\n" );
1137 bool buildNPTHlist =
false;
1140 for(
unsigned pair_ndx = 0; pair_ndx < hole_sets.size(); ++pair_ndx )
1142 const DRILL_SPAN& span = hole_sets[pair_ndx];
1148 fmt::print( outFp,
"Drill file '{}' contains\n",
1151 fmt::print( outFp,
" plated through holes:\n" );
1152 fmt::print( outFp,
"{}", separator );
1154 fmt::print( outFp,
" Total plated holes count {}\n", totalHoleCount );
1158 fmt::print( outFp,
"Drill file '{}' contains\n",
1161 fmt::print( outFp,
" backdrill span: '{}' to '{}':\n",
1165 fmt::print( outFp,
"{}", separator );
1167 fmt::print( outFp,
" Total backdrilled holes count {}\n", totalHoleCount );
1171 fmt::print( outFp,
"Drill file '{}' contains\n",
1174 fmt::print( outFp,
" holes connecting layer pair: '{} and {}' ({} vias):\n",
1177 span.
Pair().first ==
F_Cu || span.
Pair().second ==
B_Cu ?
"blind" :
"buried" );
1179 fmt::print( outFp,
"{}", separator );
1181 fmt::print( outFp,
" Total plated holes count {}\n", totalHoleCount );
1184 fmt::print( outFp,
"\n\n" );
1190 buildNPTHlist =
true;
1198 fmt::print( outFp,
"Not plated through holes are merged with plated holes\n" );
1200 fmt::print( outFp,
"Drill file '{}' contains\n",
1203 fmt::print( outFp,
" unplated through holes:\n" );
1204 fmt::print( outFp,
"{}", separator );
1206 fmt::print( outFp,
" Total unplated holes count {}\n", totalHoleCount );
1208 catch(
const std::system_error& e )
1212 catch(
const fmt::format_error& )
1219 wxString msg = wxString::Format(
_(
"Created drill report file '%s'" ), aFullFileName );
1255 unsigned totalHoleCount = 0;
1268 int tool_number = ii+1;
1269 fmt::print( 0,
" T{} {:2.3f}mm {:2.4f}\" ", tool_number,
1275 fmt::print( out,
"(1 hole" );
1277 fmt::print( out,
"(1 hole) (with 1 slot" );
1281 fmt::print( out,
"({} holes) (with 1 slot", tool.
m_TotalCount );
1286 fmt::print( out,
", castellated" );
1289 fmt::print( out,
", press-fit" );
1291 fmt::print( out,
")\n" );
1296 fmt::print( out,
"\n" );
1298 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).
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.
@ 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