Standardize pad type enums
This commit is contained in:
parent
84363c8e06
commit
bf3cb0b1d0
|
@ -493,7 +493,7 @@ void BOARD_ADAPTER::AddPadsShapesWithClearanceToContainer( const MODULE* aModule
|
||||||
|
|
||||||
// NPTH pads are not drawn on layers if the
|
// NPTH pads are not drawn on layers if the
|
||||||
// shape size and pos is the same as their hole:
|
// shape size and pos is the same as their hole:
|
||||||
if( aSkipNPTHPadsWihNoCopper && (pad->GetAttribute() == PAD_ATTRIB_HOLE_NOT_PLATED) )
|
if( aSkipNPTHPadsWihNoCopper && ( pad->GetAttribute() == PAD_ATTRIB_NPTH ) )
|
||||||
{
|
{
|
||||||
if( (pad->GetDrillSize() == pad->GetSize()) &&
|
if( (pad->GetDrillSize() == pad->GetSize()) &&
|
||||||
(pad->GetOffset() == wxPoint( 0, 0 )) )
|
(pad->GetOffset() == wxPoint( 0, 0 )) )
|
||||||
|
|
|
@ -471,7 +471,7 @@ void BOARD_ADAPTER::createLayers( REPORTER* aStatusReporter )
|
||||||
|
|
||||||
// The hole in the body is inflated by copper thickness,
|
// The hole in the body is inflated by copper thickness,
|
||||||
// if not plated, no copper
|
// if not plated, no copper
|
||||||
const int inflate = (pad->GetAttribute () != PAD_ATTRIB_HOLE_NOT_PLATED) ?
|
const int inflate = ( pad->GetAttribute () != PAD_ATTRIB_NPTH ) ?
|
||||||
GetCopperThicknessBIU() : 0;
|
GetCopperThicknessBIU() : 0;
|
||||||
|
|
||||||
m_stats_nr_holes++;
|
m_stats_nr_holes++;
|
||||||
|
@ -506,7 +506,7 @@ void BOARD_ADAPTER::createLayers( REPORTER* aStatusReporter )
|
||||||
// The hole in the body is inflated by copper thickness.
|
// The hole in the body is inflated by copper thickness.
|
||||||
const int inflate = GetCopperThicknessBIU();
|
const int inflate = GetCopperThicknessBIU();
|
||||||
|
|
||||||
if( pad->GetAttribute () != PAD_ATTRIB_HOLE_NOT_PLATED )
|
if( pad->GetAttribute () != PAD_ATTRIB_NPTH )
|
||||||
{
|
{
|
||||||
pad->TransformHoleWithClearanceToPolygon( m_through_outer_holes_poly, inflate );
|
pad->TransformHoleWithClearanceToPolygon( m_through_outer_holes_poly, inflate );
|
||||||
}
|
}
|
||||||
|
|
|
@ -794,7 +794,7 @@ void C3D_RENDER_OGL_LEGACY::generate_3D_Vias_and_Pads()
|
||||||
{
|
{
|
||||||
for( auto pad : module->Pads() )
|
for( auto pad : module->Pads() )
|
||||||
{
|
{
|
||||||
if( pad->GetAttribute() != PAD_ATTRIB_HOLE_NOT_PLATED )
|
if( pad->GetAttribute() != PAD_ATTRIB_NPTH )
|
||||||
{
|
{
|
||||||
const wxSize drillsize = pad->GetDrillSize();
|
const wxSize drillsize = pad->GetDrillSize();
|
||||||
const bool hasHole = drillsize.x && drillsize.y;
|
const bool hasHole = drillsize.x && drillsize.y;
|
||||||
|
|
|
@ -1258,7 +1258,7 @@ void C3D_RENDER_RAYTRACING::add_3D_vias_and_pads_to_container()
|
||||||
for( auto module : m_boardAdapter.GetBoard()->Modules() )
|
for( auto module : m_boardAdapter.GetBoard()->Modules() )
|
||||||
{
|
{
|
||||||
for( auto pad : module->Pads() )
|
for( auto pad : module->Pads() )
|
||||||
if( pad->GetAttribute () != PAD_ATTRIB_HOLE_NOT_PLATED )
|
if( pad->GetAttribute () != PAD_ATTRIB_NPTH )
|
||||||
{
|
{
|
||||||
insert3DPadHole( pad );
|
insert3DPadHole( pad );
|
||||||
}
|
}
|
||||||
|
|
|
@ -77,13 +77,13 @@ enum PAD_DRILL_SHAPE_T
|
||||||
*/
|
*/
|
||||||
enum PAD_ATTR_T
|
enum PAD_ATTR_T
|
||||||
{
|
{
|
||||||
PAD_ATTRIB_STANDARD, ///< Usual pad
|
PAD_ATTRIB_PTH, ///< Plated through hole pad
|
||||||
PAD_ATTRIB_SMD, ///< Smd pad, appears on the solder paste layer (default)
|
PAD_ATTRIB_SMD, ///< Smd pad, appears on the solder paste layer (default)
|
||||||
PAD_ATTRIB_CONN, ///< Like smd, does not appear on the solder paste layer (default)
|
PAD_ATTRIB_CONN, ///< Like smd, does not appear on the solder paste layer (default)
|
||||||
///< note also has a special attribute in Gerber X files
|
///< note also has a special attribute in Gerber X files
|
||||||
///< Used for edgecard connectors for instance
|
///< Used for edgecard connectors for instance
|
||||||
PAD_ATTRIB_HOLE_NOT_PLATED, ///< like PAD_STANDARD, but not plated
|
PAD_ATTRIB_NPTH, ///< like PAD_PTH, but not plated
|
||||||
///< mechanical use only, no connection allowed
|
///< mechanical use only, no connection allowed
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -131,7 +131,7 @@ void MODULE::TransformPadsShapesWithClearanceToPolygon( PCB_LAYER_ID aLayer,
|
||||||
|
|
||||||
// NPTH pads are not drawn on layers if the shape size and pos is the same
|
// NPTH pads are not drawn on layers if the shape size and pos is the same
|
||||||
// as their hole:
|
// as their hole:
|
||||||
if( aSkipNPTHPadsWihNoCopper && pad->GetAttribute() == PAD_ATTRIB_HOLE_NOT_PLATED )
|
if( aSkipNPTHPadsWihNoCopper && pad->GetAttribute() == PAD_ATTRIB_NPTH )
|
||||||
{
|
{
|
||||||
if( pad->GetDrillSize() == pad->GetSize() && pad->GetOffset() == wxPoint( 0, 0 ) )
|
if( pad->GetDrillSize() == pad->GetSize() && pad->GetOffset() == wxPoint( 0, 0 ) )
|
||||||
{
|
{
|
||||||
|
|
|
@ -834,7 +834,7 @@ unsigned MODULE::GetPadCount( INCLUDE_NPTH_T aIncludeNPTH ) const
|
||||||
|
|
||||||
for( D_PAD* pad : m_pads )
|
for( D_PAD* pad : m_pads )
|
||||||
{
|
{
|
||||||
if( pad->GetAttribute() == PAD_ATTRIB_HOLE_NOT_PLATED )
|
if( pad->GetAttribute() == PAD_ATTRIB_NPTH )
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
cnt++;
|
cnt++;
|
||||||
|
@ -864,7 +864,7 @@ unsigned MODULE::GetUniquePadCount( INCLUDE_NPTH_T aIncludeNPTH ) const
|
||||||
if( !aIncludeNPTH )
|
if( !aIncludeNPTH )
|
||||||
{
|
{
|
||||||
// skip NPTH
|
// skip NPTH
|
||||||
if( pad->GetAttribute() == PAD_ATTRIB_HOLE_NOT_PLATED )
|
if( pad->GetAttribute() == PAD_ATTRIB_NPTH )
|
||||||
{
|
{
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
|
@ -70,16 +70,16 @@ D_PAD::D_PAD( MODULE* parent ) :
|
||||||
SetAnchorPadShape( PAD_SHAPE_CIRCLE ); // Default shape for custom shaped pads
|
SetAnchorPadShape( PAD_SHAPE_CIRCLE ); // Default shape for custom shaped pads
|
||||||
// is PAD_CIRCLE.
|
// is PAD_CIRCLE.
|
||||||
SetDrillShape( PAD_DRILL_SHAPE_CIRCLE ); // Default pad drill shape is a circle.
|
SetDrillShape( PAD_DRILL_SHAPE_CIRCLE ); // Default pad drill shape is a circle.
|
||||||
m_attribute = PAD_ATTRIB_STANDARD; // Default pad type is NORMAL (thru hole)
|
m_attribute = PAD_ATTRIB_PTH; // Default pad type is plated through hole
|
||||||
SetProperty( PAD_PROP_NONE ); // no special fabrication property
|
SetProperty( PAD_PROP_NONE ); // no special fabrication property
|
||||||
m_localClearance = 0;
|
m_localClearance = 0;
|
||||||
m_localSolderMaskMargin = 0;
|
m_localSolderMaskMargin = 0;
|
||||||
m_localSolderPasteMargin = 0;
|
m_localSolderPasteMargin = 0;
|
||||||
m_localSolderPasteMarginRatio = 0.0;
|
m_localSolderPasteMarginRatio = 0.0;
|
||||||
// Parameters for round rect only:
|
// Parameters for round rect only:
|
||||||
m_roundedCornerScale = 0.25; // from IPC-7351C standard
|
m_roundedCornerScale = 0.25; // from IPC-7351C standard
|
||||||
// Parameters for chamfered rect only:
|
// Parameters for chamfered rect only:
|
||||||
m_chamferScale = 0.2; // Size of chamfer: ratio of smallest of X,Y size
|
m_chamferScale = 0.2; // Size of chamfer: ratio of smallest of X,Y size
|
||||||
m_chamferPositions = RECT_NO_CHAMFER; // No chamfered corner
|
m_chamferPositions = RECT_NO_CHAMFER; // No chamfered corner
|
||||||
|
|
||||||
m_zoneConnection = ZONE_CONNECTION::INHERITED; // Use parent setting by default
|
m_zoneConnection = ZONE_CONNECTION::INHERITED; // Use parent setting by default
|
||||||
|
@ -89,7 +89,7 @@ D_PAD::D_PAD( MODULE* parent ) :
|
||||||
m_customShapeClearanceArea = CUST_PAD_SHAPE_IN_ZONE_OUTLINE;
|
m_customShapeClearanceArea = CUST_PAD_SHAPE_IN_ZONE_OUTLINE;
|
||||||
|
|
||||||
// Set layers mask to default for a standard thru hole pad.
|
// Set layers mask to default for a standard thru hole pad.
|
||||||
m_layerMask = StandardMask();
|
m_layerMask = PTHMask();
|
||||||
|
|
||||||
SetSubRatsnest( 0 ); // used in ratsnest calculations
|
SetSubRatsnest( 0 ); // used in ratsnest calculations
|
||||||
|
|
||||||
|
@ -138,7 +138,7 @@ D_PAD& D_PAD::operator=( const D_PAD &aOther )
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
LSET D_PAD::StandardMask()
|
LSET D_PAD::PTHMask()
|
||||||
{
|
{
|
||||||
static LSET saved = LSET::AllCuMask() | LSET( 2, F_Mask, B_Mask );
|
static LSET saved = LSET::AllCuMask() | LSET( 2, F_Mask, B_Mask );
|
||||||
return saved;
|
return saved;
|
||||||
|
@ -201,7 +201,7 @@ bool D_PAD::FlashLayer( int aLayer ) const
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
/// We don't remove the copper from non-PTH pads
|
/// We don't remove the copper from non-PTH pads
|
||||||
if( GetAttribute() != PAD_ATTRIB_STANDARD )
|
if( GetAttribute() != PAD_ATTRIB_PTH )
|
||||||
return IsOnLayer( static_cast<PCB_LAYER_ID>( aLayer ) );
|
return IsOnLayer( static_cast<PCB_LAYER_ID>( aLayer ) );
|
||||||
|
|
||||||
/// Heatsink pads always get copper
|
/// Heatsink pads always get copper
|
||||||
|
@ -1044,11 +1044,11 @@ wxString D_PAD::ShowPadAttr() const
|
||||||
{
|
{
|
||||||
switch( GetAttribute() )
|
switch( GetAttribute() )
|
||||||
{
|
{
|
||||||
case PAD_ATTRIB_STANDARD: return _( "Std" );
|
case PAD_ATTRIB_PTH: return _( "PTH" );
|
||||||
case PAD_ATTRIB_SMD: return _( "SMD" );
|
case PAD_ATTRIB_SMD: return _( "SMD" );
|
||||||
case PAD_ATTRIB_CONN: return _( "Conn" );
|
case PAD_ATTRIB_CONN: return _( "Conn" );
|
||||||
case PAD_ATTRIB_HOLE_NOT_PLATED: return _( "Not Plated" );
|
case PAD_ATTRIB_NPTH: return _( "NPTH" );
|
||||||
default: return wxT( "???" );
|
default: return wxT( "???" );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1085,7 +1085,7 @@ EDA_ITEM* D_PAD::Clone() const
|
||||||
|
|
||||||
bool D_PAD::PadShouldBeNPTH() const
|
bool D_PAD::PadShouldBeNPTH() const
|
||||||
{
|
{
|
||||||
return( m_attribute == PAD_ATTRIB_STANDARD
|
return( m_attribute == PAD_ATTRIB_PTH
|
||||||
&& m_drill.x >= m_size.x && m_drill.y >= m_size.y );
|
&& m_drill.x >= m_size.x && m_drill.y >= m_size.y );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1095,10 +1095,10 @@ void D_PAD::ViewGetLayers( int aLayers[], int& aCount ) const
|
||||||
aCount = 0;
|
aCount = 0;
|
||||||
|
|
||||||
// These 2 types of pads contain a hole
|
// These 2 types of pads contain a hole
|
||||||
if( m_attribute == PAD_ATTRIB_STANDARD )
|
if( m_attribute == PAD_ATTRIB_PTH )
|
||||||
aLayers[aCount++] = LAYER_PADS_PLATEDHOLES;
|
aLayers[aCount++] = LAYER_PADS_PLATEDHOLES;
|
||||||
|
|
||||||
if( m_attribute == PAD_ATTRIB_HOLE_NOT_PLATED )
|
if( m_attribute == PAD_ATTRIB_NPTH )
|
||||||
aLayers[aCount++] = LAYER_NON_PLATEDHOLES;
|
aLayers[aCount++] = LAYER_NON_PLATEDHOLES;
|
||||||
|
|
||||||
if( IsOnLayer( F_Cu ) && IsOnLayer( B_Cu ) )
|
if( IsOnLayer( F_Cu ) && IsOnLayer( B_Cu ) )
|
||||||
|
@ -1113,7 +1113,7 @@ void D_PAD::ViewGetLayers( int aLayers[], int& aCount ) const
|
||||||
|
|
||||||
// Is this a PTH pad that has only front copper? If so, we need to also display the
|
// Is this a PTH pad that has only front copper? If so, we need to also display the
|
||||||
// net name on the PTH netname layer so that it isn't blocked by the drill hole.
|
// net name on the PTH netname layer so that it isn't blocked by the drill hole.
|
||||||
if( m_attribute == PAD_ATTRIB_STANDARD )
|
if( m_attribute == PAD_ATTRIB_PTH )
|
||||||
aLayers[aCount++] = LAYER_PADS_NETNAMES;
|
aLayers[aCount++] = LAYER_PADS_NETNAMES;
|
||||||
else
|
else
|
||||||
aLayers[aCount++] = LAYER_PAD_FR_NETNAMES;
|
aLayers[aCount++] = LAYER_PAD_FR_NETNAMES;
|
||||||
|
@ -1124,7 +1124,7 @@ void D_PAD::ViewGetLayers( int aLayers[], int& aCount ) const
|
||||||
|
|
||||||
// Is this a PTH pad that has only back copper? If so, we need to also display the
|
// Is this a PTH pad that has only back copper? If so, we need to also display the
|
||||||
// net name on the PTH netname layer so that it isn't blocked by the drill hole.
|
// net name on the PTH netname layer so that it isn't blocked by the drill hole.
|
||||||
if( m_attribute == PAD_ATTRIB_STANDARD )
|
if( m_attribute == PAD_ATTRIB_PTH )
|
||||||
aLayers[aCount++] = LAYER_PADS_NETNAMES;
|
aLayers[aCount++] = LAYER_PADS_NETNAMES;
|
||||||
else
|
else
|
||||||
aLayers[aCount++] = LAYER_PAD_BK_NETNAMES;
|
aLayers[aCount++] = LAYER_PAD_BK_NETNAMES;
|
||||||
|
@ -1177,7 +1177,7 @@ double D_PAD::ViewGetLOD( int aLayer, KIGFX::VIEW* aView ) const
|
||||||
return HIDE;
|
return HIDE;
|
||||||
|
|
||||||
// Handle Render tab switches
|
// Handle Render tab switches
|
||||||
if( ( GetAttribute() == PAD_ATTRIB_STANDARD || GetAttribute() == PAD_ATTRIB_HOLE_NOT_PLATED )
|
if( ( GetAttribute() == PAD_ATTRIB_PTH || GetAttribute() == PAD_ATTRIB_NPTH )
|
||||||
&& !aView->IsLayerVisible( LAYER_PADS_TH ) )
|
&& !aView->IsLayerVisible( LAYER_PADS_TH ) )
|
||||||
return HIDE;
|
return HIDE;
|
||||||
|
|
||||||
|
@ -1329,10 +1329,10 @@ static struct PAD_DESC
|
||||||
PAD_DESC()
|
PAD_DESC()
|
||||||
{
|
{
|
||||||
ENUM_MAP<PAD_ATTR_T>::Instance()
|
ENUM_MAP<PAD_ATTR_T>::Instance()
|
||||||
.Map( PAD_ATTRIB_STANDARD, _( "Through-hole" ) )
|
.Map( PAD_ATTRIB_PTH, _( "Through-hole" ) )
|
||||||
.Map( PAD_ATTRIB_SMD, _( "SMD" ) )
|
.Map( PAD_ATTRIB_SMD, _( "SMD" ) )
|
||||||
.Map( PAD_ATTRIB_CONN, _( "Edge connector" ) )
|
.Map( PAD_ATTRIB_CONN, _( "Edge connector" ) )
|
||||||
.Map( PAD_ATTRIB_HOLE_NOT_PLATED, _( "NPTH, mechanical" ) );
|
.Map( PAD_ATTRIB_NPTH, _( "NPTH, mechanical" ) );
|
||||||
|
|
||||||
ENUM_MAP<PAD_SHAPE_T>::Instance()
|
ENUM_MAP<PAD_SHAPE_T>::Instance()
|
||||||
.Map( PAD_SHAPE_CIRCLE, _( "Circle" ) )
|
.Map( PAD_SHAPE_CIRCLE, _( "Circle" ) )
|
||||||
|
|
|
@ -75,7 +75,7 @@ public:
|
||||||
* Default layers used for pads, according to the pad type.
|
* Default layers used for pads, according to the pad type.
|
||||||
* this is default values only, they can be changed for a given pad
|
* this is default values only, they can be changed for a given pad
|
||||||
*/
|
*/
|
||||||
static LSET StandardMask(); ///< layer set for a through hole pad
|
static LSET PTHMask(); ///< layer set for a through hole pad
|
||||||
static LSET SMDMask(); ///< layer set for a SMD pad on Front layer
|
static LSET SMDMask(); ///< layer set for a SMD pad on Front layer
|
||||||
static LSET ConnSMDMask(); ///< layer set for a SMD pad on Front layer
|
static LSET ConnSMDMask(); ///< layer set for a SMD pad on Front layer
|
||||||
///< used for edge board connectors
|
///< used for edge board connectors
|
||||||
|
@ -98,9 +98,9 @@ public:
|
||||||
{
|
{
|
||||||
if( *p == PCB_LOCATE_HOLE_T )
|
if( *p == PCB_LOCATE_HOLE_T )
|
||||||
return true;
|
return true;
|
||||||
else if( *p == PCB_LOCATE_PTH_T && m_attribute != PAD_ATTRIB_HOLE_NOT_PLATED )
|
else if( *p == PCB_LOCATE_PTH_T && m_attribute != PAD_ATTRIB_NPTH )
|
||||||
return true;
|
return true;
|
||||||
else if( *p == PCB_LOCATE_NPTH_T && m_attribute == PAD_ATTRIB_HOLE_NOT_PLATED )
|
else if( *p == PCB_LOCATE_NPTH_T && m_attribute == PAD_ATTRIB_NPTH )
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -701,7 +701,7 @@ private:
|
||||||
// module anchor, orientation 0)
|
// module anchor, orientation 0)
|
||||||
|
|
||||||
PAD_ATTR_T m_attribute; // PAD_ATTRIB_NORMAL, PAD_ATTRIB_SMD, PAD_ATTRIB_CONN,
|
PAD_ATTR_T m_attribute; // PAD_ATTRIB_NORMAL, PAD_ATTRIB_SMD, PAD_ATTRIB_CONN,
|
||||||
// PAD_ATTRIB_HOLE_NOT_PLATED
|
// PAD_ATTRIB_NPTH
|
||||||
PAD_PROP_T m_property; // Property in fab files (BGA, FIDUCIAL, TESTPOINT, etc.)
|
PAD_PROP_T m_property; // Property in fab files (BGA, FIDUCIAL, TESTPOINT, etc.)
|
||||||
|
|
||||||
double m_orient; // in 1/10 degrees
|
double m_orient; // in 1/10 degrees
|
||||||
|
|
|
@ -208,7 +208,7 @@ CN_ITEM* CN_LIST::Add( D_PAD* pad )
|
||||||
switch( pad->GetAttribute() )
|
switch( pad->GetAttribute() )
|
||||||
{
|
{
|
||||||
case PAD_ATTRIB_SMD:
|
case PAD_ATTRIB_SMD:
|
||||||
case PAD_ATTRIB_HOLE_NOT_PLATED:
|
case PAD_ATTRIB_NPTH:
|
||||||
case PAD_ATTRIB_CONN:
|
case PAD_ATTRIB_CONN:
|
||||||
{
|
{
|
||||||
LSET lmsk = pad->GetLayerSet();
|
LSET lmsk = pad->GetLayerSet();
|
||||||
|
|
|
@ -136,10 +136,10 @@ void DIALOG_BOARD_STATISTICS::refreshItemsTypes()
|
||||||
m_componentsTypes.push_back( componentsType_t( MOD_SMD, _( "SMD:" ) ) );
|
m_componentsTypes.push_back( componentsType_t( MOD_SMD, _( "SMD:" ) ) );
|
||||||
|
|
||||||
m_padsTypes.clear();
|
m_padsTypes.clear();
|
||||||
m_padsTypes.push_back( padsType_t( PAD_ATTRIB_STANDARD, _( "Through hole:" ) ) );
|
m_padsTypes.push_back( padsType_t( PAD_ATTRIB_PTH, _( "Through hole:" ) ) );
|
||||||
m_padsTypes.push_back( padsType_t( PAD_ATTRIB_SMD, _( "SMD:" ) ) );
|
m_padsTypes.push_back( padsType_t( PAD_ATTRIB_SMD, _( "SMD:" ) ) );
|
||||||
m_padsTypes.push_back( padsType_t( PAD_ATTRIB_CONN, _( "Connector:" ) ) );
|
m_padsTypes.push_back( padsType_t( PAD_ATTRIB_CONN, _( "Connector:" ) ) );
|
||||||
m_padsTypes.push_back( padsType_t( PAD_ATTRIB_HOLE_NOT_PLATED, _( "NPTH:" ) ) );
|
m_padsTypes.push_back( padsType_t( PAD_ATTRIB_NPTH, _( "NPTH:" ) ) );
|
||||||
|
|
||||||
m_viasTypes.clear();
|
m_viasTypes.clear();
|
||||||
m_viasTypes.push_back( viasType_t( VIATYPE::THROUGH, _( "Through vias:" ) ) );
|
m_viasTypes.push_back( viasType_t( VIATYPE::THROUGH, _( "Through vias:" ) ) );
|
||||||
|
@ -227,7 +227,7 @@ void DIALOG_BOARD_STATISTICS::getDataFromPCB()
|
||||||
}
|
}
|
||||||
|
|
||||||
drillType_t drill( pad->GetDrillSize().x, pad->GetDrillSize().y,
|
drillType_t drill( pad->GetDrillSize().x, pad->GetDrillSize().y,
|
||||||
pad->GetDrillShape(), pad->GetAttribute() != PAD_ATTRIB_HOLE_NOT_PLATED,
|
pad->GetDrillShape(), pad->GetAttribute() != PAD_ATTRIB_NPTH,
|
||||||
true, top, bottom );
|
true, top, bottom );
|
||||||
|
|
||||||
auto it = m_drillTypes.begin();
|
auto it = m_drillTypes.begin();
|
||||||
|
|
|
@ -148,7 +148,7 @@ void DIALOG_GENDRILL::InitDisplayParams()
|
||||||
{
|
{
|
||||||
if( pad->GetDrillSize().x != 0 )
|
if( pad->GetDrillSize().x != 0 )
|
||||||
{
|
{
|
||||||
if( pad->GetAttribute() == PAD_ATTRIB_HOLE_NOT_PLATED )
|
if( pad->GetAttribute() == PAD_ATTRIB_NPTH )
|
||||||
m_notplatedPadsHoleCount++;
|
m_notplatedPadsHoleCount++;
|
||||||
else
|
else
|
||||||
m_platedPadsHoleCount++;
|
m_platedPadsHoleCount++;
|
||||||
|
@ -158,7 +158,7 @@ void DIALOG_GENDRILL::InitDisplayParams()
|
||||||
{
|
{
|
||||||
if( pad->GetDrillSize().x != 0 && pad->GetDrillSize().y != 0 )
|
if( pad->GetDrillSize().x != 0 && pad->GetDrillSize().y != 0 )
|
||||||
{
|
{
|
||||||
if( pad->GetAttribute() == PAD_ATTRIB_HOLE_NOT_PLATED )
|
if( pad->GetAttribute() == PAD_ATTRIB_NPTH )
|
||||||
m_notplatedPadsHoleCount++;
|
m_notplatedPadsHoleCount++;
|
||||||
else
|
else
|
||||||
m_platedPadsHoleCount++;
|
m_platedPadsHoleCount++;
|
||||||
|
|
|
@ -77,10 +77,10 @@ enum CODE_CHOICE
|
||||||
|
|
||||||
static PAD_ATTR_T code_type[] =
|
static PAD_ATTR_T code_type[] =
|
||||||
{
|
{
|
||||||
PAD_ATTRIB_STANDARD,
|
PAD_ATTRIB_PTH,
|
||||||
PAD_ATTRIB_SMD,
|
PAD_ATTRIB_SMD,
|
||||||
PAD_ATTRIB_CONN,
|
PAD_ATTRIB_CONN,
|
||||||
PAD_ATTRIB_HOLE_NOT_PLATED,
|
PAD_ATTRIB_NPTH,
|
||||||
PAD_ATTRIB_SMD // Aperture pad :type SMD with no copper layers,
|
PAD_ATTRIB_SMD // Aperture pad :type SMD with no copper layers,
|
||||||
// only on tech layers (usually only on paste layer
|
// only on tech layers (usually only on paste layer
|
||||||
};
|
};
|
||||||
|
@ -88,10 +88,10 @@ static PAD_ATTR_T code_type[] =
|
||||||
// Default mask layers setup for pads according to the pad type
|
// Default mask layers setup for pads according to the pad type
|
||||||
static const LSET std_pad_layers[] =
|
static const LSET std_pad_layers[] =
|
||||||
{
|
{
|
||||||
D_PAD::StandardMask(), // PAD_ATTRIB_STANDARD:
|
D_PAD::StandardMask(), // PAD_ATTRIB_PTH:
|
||||||
D_PAD::SMDMask(), // PAD_ATTRIB_SMD:
|
D_PAD::SMDMask(), // PAD_ATTRIB_SMD:
|
||||||
D_PAD::ConnSMDMask(), // PAD_ATTRIB_CONN:
|
D_PAD::ConnSMDMask(), // PAD_ATTRIB_CONN:
|
||||||
D_PAD::UnplatedHoleMask(), // PAD_ATTRIB_HOLE_NOT_PLATED:
|
D_PAD::UnplatedHoleMask(), // PAD_ATTRIB_NPTH:
|
||||||
D_PAD::ApertureMask()
|
D_PAD::ApertureMask()
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -630,10 +630,10 @@ void DIALOG_PAD_PROPERTIES::initValues()
|
||||||
{
|
{
|
||||||
switch( m_dummyPad->GetAttribute() )
|
switch( m_dummyPad->GetAttribute() )
|
||||||
{
|
{
|
||||||
case PAD_ATTRIB_STANDARD: m_PadType->SetSelection( 0 ); break;
|
case PAD_ATTRIB_PTH: m_PadType->SetSelection( 0 ); break;
|
||||||
case PAD_ATTRIB_SMD: m_PadType->SetSelection( 1 ); break;
|
case PAD_ATTRIB_SMD: m_PadType->SetSelection( 1 ); break;
|
||||||
case PAD_ATTRIB_CONN: m_PadType->SetSelection( 2 ); break;
|
case PAD_ATTRIB_CONN: m_PadType->SetSelection( 2 ); break;
|
||||||
case PAD_ATTRIB_HOLE_NOT_PLATED: m_PadType->SetSelection( 3 ); break;
|
case PAD_ATTRIB_NPTH: m_PadType->SetSelection( 3 ); break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -649,7 +649,7 @@ void DIALOG_PAD_PROPERTIES::initValues()
|
||||||
}
|
}
|
||||||
|
|
||||||
// Ensure the pad property is compatible with the pad type
|
// Ensure the pad property is compatible with the pad type
|
||||||
if( m_dummyPad->GetAttribute() == PAD_ATTRIB_HOLE_NOT_PLATED )
|
if( m_dummyPad->GetAttribute() == PAD_ATTRIB_NPTH )
|
||||||
{
|
{
|
||||||
m_choiceFabProperty->SetSelection( 0 );
|
m_choiceFabProperty->SetSelection( 0 );
|
||||||
m_choiceFabProperty->Enable( false );
|
m_choiceFabProperty->Enable( false );
|
||||||
|
@ -1219,7 +1219,7 @@ bool DIALOG_PAD_PROPERTIES::padValuesOK()
|
||||||
if( !padlayers_mask[F_Cu] && !padlayers_mask[B_Cu] )
|
if( !padlayers_mask[F_Cu] && !padlayers_mask[B_Cu] )
|
||||||
{
|
{
|
||||||
if( ( m_dummyPad->GetDrillSize().x || m_dummyPad->GetDrillSize().y )
|
if( ( m_dummyPad->GetDrillSize().x || m_dummyPad->GetDrillSize().y )
|
||||||
&& m_dummyPad->GetAttribute() != PAD_ATTRIB_HOLE_NOT_PLATED )
|
&& m_dummyPad->GetAttribute() != PAD_ATTRIB_NPTH )
|
||||||
{
|
{
|
||||||
// Note: he message is shown in an HTML window
|
// Note: he message is shown in an HTML window
|
||||||
msg = _( "Error: plated through holes must have a copper pad on at least one layer" );
|
msg = _( "Error: plated through holes must have a copper pad on at least one layer" );
|
||||||
|
@ -1247,8 +1247,8 @@ bool DIALOG_PAD_PROPERTIES::padValuesOK()
|
||||||
|
|
||||||
switch( m_dummyPad->GetAttribute() )
|
switch( m_dummyPad->GetAttribute() )
|
||||||
{
|
{
|
||||||
case PAD_ATTRIB_HOLE_NOT_PLATED: // Not plated, but through hole, a hole is expected
|
case PAD_ATTRIB_NPTH: // Not plated, but through hole, a hole is expected
|
||||||
case PAD_ATTRIB_STANDARD : // Pad through hole, a hole is also expected
|
case PAD_ATTRIB_PTH: // Pad through hole, a hole is also expected
|
||||||
if( m_dummyPad->GetDrillSize().x <= 0 ||
|
if( m_dummyPad->GetDrillSize().x <= 0 ||
|
||||||
( m_dummyPad->GetDrillSize().y <= 0 && m_dummyPad->GetDrillShape() == PAD_DRILL_SHAPE_OBLONG ) )
|
( m_dummyPad->GetDrillSize().y <= 0 && m_dummyPad->GetDrillShape() == PAD_DRILL_SHAPE_OBLONG ) )
|
||||||
error_msgs.Add( _( "Error: Through hole pad: drill diameter set to 0" ) );
|
error_msgs.Add( _( "Error: Through hole pad: drill diameter set to 0" ) );
|
||||||
|
@ -1272,11 +1272,11 @@ bool DIALOG_PAD_PROPERTIES::padValuesOK()
|
||||||
}
|
}
|
||||||
|
|
||||||
if( m_dummyPad->GetProperty() != PAD_PROP_NONE &&
|
if( m_dummyPad->GetProperty() != PAD_PROP_NONE &&
|
||||||
m_dummyPad->GetAttribute() == PAD_ATTRIB_HOLE_NOT_PLATED )
|
m_dummyPad->GetAttribute() == PAD_ATTRIB_NPTH )
|
||||||
error_msgs.Add( _( "Property cannot be set for NPTH" ) );
|
error_msgs.Add( _( "Property cannot be set for NPTH" ) );
|
||||||
|
|
||||||
if( m_dummyPad->GetProperty() == PAD_PROP_CASTELLATED &&
|
if( m_dummyPad->GetProperty() == PAD_PROP_CASTELLATED &&
|
||||||
m_dummyPad->GetAttribute() != PAD_ATTRIB_STANDARD )
|
m_dummyPad->GetAttribute() != PAD_ATTRIB_PTH )
|
||||||
error_msgs.Add( _( "Castellated property can be set only for PTH" ) );
|
error_msgs.Add( _( "Castellated property can be set only for PTH" ) );
|
||||||
|
|
||||||
if( m_dummyPad->GetProperty() == PAD_PROP_BGA &&
|
if( m_dummyPad->GetProperty() == PAD_PROP_BGA &&
|
||||||
|
@ -1506,8 +1506,8 @@ bool DIALOG_PAD_PROPERTIES::TransferDataFromWindow()
|
||||||
|
|
||||||
int padNetcode = NETINFO_LIST::UNCONNECTED;
|
int padNetcode = NETINFO_LIST::UNCONNECTED;
|
||||||
|
|
||||||
// For PAD_ATTRIB_HOLE_NOT_PLATED, ensure there is no net name selected
|
// For PAD_ATTRIB_NPTH, ensure there is no net name selected
|
||||||
if( m_padMaster->GetAttribute() != PAD_ATTRIB_HOLE_NOT_PLATED )
|
if( m_padMaster->GetAttribute() != PAD_ATTRIB_NPTH )
|
||||||
padNetcode = m_PadNetSelector->GetSelectedNetcode();
|
padNetcode = m_PadNetSelector->GetSelectedNetcode();
|
||||||
|
|
||||||
m_currentPad->SetNetCode( padNetcode );
|
m_currentPad->SetNetCode( padNetcode );
|
||||||
|
@ -1744,7 +1744,7 @@ bool DIALOG_PAD_PROPERTIES::transferDataToPad( D_PAD* aPad )
|
||||||
|
|
||||||
switch( aPad->GetAttribute() )
|
switch( aPad->GetAttribute() )
|
||||||
{
|
{
|
||||||
case PAD_ATTRIB_STANDARD:
|
case PAD_ATTRIB_PTH:
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case PAD_ATTRIB_CONN:
|
case PAD_ATTRIB_CONN:
|
||||||
|
@ -1758,7 +1758,7 @@ bool DIALOG_PAD_PROPERTIES::transferDataToPad( D_PAD* aPad )
|
||||||
aPad->SetDrillSize( wxSize( 0, 0 ) );
|
aPad->SetDrillSize( wxSize( 0, 0 ) );
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case PAD_ATTRIB_HOLE_NOT_PLATED:
|
case PAD_ATTRIB_NPTH:
|
||||||
// Mechanical purpose only:
|
// Mechanical purpose only:
|
||||||
// no net name, no pad name allowed
|
// no net name, no pad name allowed
|
||||||
aPad->SetName( wxEmptyString );
|
aPad->SetName( wxEmptyString );
|
||||||
|
|
|
@ -279,7 +279,7 @@ void DRC_TEST_PROVIDER_COPPER_CLEARANCE::testCopperDrawItem( BOARD_ITEM* aItem )
|
||||||
{
|
{
|
||||||
padShape = pad->GetEffectiveShape().get();
|
padShape = pad->GetEffectiveShape().get();
|
||||||
}
|
}
|
||||||
else if( pad->GetAttribute() == PAD_ATTRIB_STANDARD )
|
else if( pad->GetAttribute() == PAD_ATTRIB_PTH )
|
||||||
{
|
{
|
||||||
// Note: drill size represents finish size, which means the actual holes size is the
|
// Note: drill size represents finish size, which means the actual holes size is the
|
||||||
// plating thickness larger.
|
// plating thickness larger.
|
||||||
|
@ -381,7 +381,7 @@ void DRC_TEST_PROVIDER_COPPER_CLEARANCE::doTrackDrc( TRACK* aRefSeg, PCB_LAYER_I
|
||||||
{
|
{
|
||||||
padShape = pad->GetEffectiveShape().get();
|
padShape = pad->GetEffectiveShape().get();
|
||||||
}
|
}
|
||||||
else if( pad->GetAttribute() == PAD_ATTRIB_STANDARD )
|
else if( pad->GetAttribute() == PAD_ATTRIB_PTH )
|
||||||
{
|
{
|
||||||
// Note: drill size represents finish size, which means the actual holes size is the
|
// Note: drill size represents finish size, which means the actual holes size is the
|
||||||
// plating thickness larger.
|
// plating thickness larger.
|
||||||
|
@ -688,7 +688,7 @@ void DRC_TEST_PROVIDER_COPPER_CLEARANCE::doPadToPadsDrc( int aRefPadIdx,
|
||||||
{
|
{
|
||||||
refPadShape = refPad->GetEffectiveShape().get();
|
refPadShape = refPad->GetEffectiveShape().get();
|
||||||
}
|
}
|
||||||
else if( refPad->GetAttribute() == PAD_ATTRIB_STANDARD )
|
else if( refPad->GetAttribute() == PAD_ATTRIB_PTH )
|
||||||
{
|
{
|
||||||
// Note: drill size represents finish size, which means the actual holes size is the
|
// Note: drill size represents finish size, which means the actual holes size is the
|
||||||
// plating thickness larger.
|
// plating thickness larger.
|
||||||
|
@ -708,7 +708,7 @@ void DRC_TEST_PROVIDER_COPPER_CLEARANCE::doPadToPadsDrc( int aRefPadIdx,
|
||||||
{
|
{
|
||||||
padShape = pad->GetEffectiveShape().get();
|
padShape = pad->GetEffectiveShape().get();
|
||||||
}
|
}
|
||||||
else if( pad->GetAttribute() == PAD_ATTRIB_STANDARD )
|
else if( pad->GetAttribute() == PAD_ATTRIB_PTH )
|
||||||
{
|
{
|
||||||
// Note: drill size represents finish size, which means the actual holes size is the
|
// Note: drill size represents finish size, which means the actual holes size is the
|
||||||
// plating thickness larger.
|
// plating thickness larger.
|
||||||
|
|
|
@ -829,7 +829,7 @@ void EAGLE_PLUGIN::loadPlain( wxXmlNode* aGraphics )
|
||||||
{
|
{
|
||||||
m_xpath->push( "hole" );
|
m_xpath->push( "hole" );
|
||||||
|
|
||||||
// Fabricate a MODULE with a single PAD_ATTRIB_HOLE_NOT_PLATED pad.
|
// Fabricate a MODULE with a single PAD_ATTRIB_NPTH pad.
|
||||||
// Use m_hole_count to gen up a unique name.
|
// Use m_hole_count to gen up a unique name.
|
||||||
|
|
||||||
MODULE* module = new MODULE( m_board );
|
MODULE* module = new MODULE( m_board );
|
||||||
|
@ -2076,12 +2076,12 @@ void EAGLE_PLUGIN::packageHole( MODULE* aModule, wxXmlNode* aTree, bool aCenter
|
||||||
{
|
{
|
||||||
EHOLE e( aTree );
|
EHOLE e( aTree );
|
||||||
|
|
||||||
// we add a PAD_ATTRIB_HOLE_NOT_PLATED pad to this module.
|
// we add a PAD_ATTRIB_NPTH pad to this module.
|
||||||
D_PAD* pad = new D_PAD( aModule );
|
D_PAD* pad = new D_PAD( aModule );
|
||||||
aModule->Add( pad );
|
aModule->Add( pad );
|
||||||
|
|
||||||
pad->SetShape( PAD_SHAPE_CIRCLE );
|
pad->SetShape( PAD_SHAPE_CIRCLE );
|
||||||
pad->SetAttribute( PAD_ATTRIB_HOLE_NOT_PLATED );
|
pad->SetAttribute( PAD_ATTRIB_NPTH );
|
||||||
|
|
||||||
// Mechanical purpose only:
|
// Mechanical purpose only:
|
||||||
// no offset, no net name, no pad name allowed
|
// no offset, no net name, no pad name allowed
|
||||||
|
|
|
@ -113,7 +113,7 @@ static void build_pad_testpoints( BOARD *aPcb, std::vector <D356_RECORD>& aRecor
|
||||||
rk.drill = std::min( drill.x, drill.y );
|
rk.drill = std::min( drill.x, drill.y );
|
||||||
rk.hole = (rk.drill != 0);
|
rk.hole = (rk.drill != 0);
|
||||||
rk.smd = pad->GetAttribute() == PAD_ATTRIB_SMD;
|
rk.smd = pad->GetAttribute() == PAD_ATTRIB_SMD;
|
||||||
rk.mechanical = (pad->GetAttribute() == PAD_ATTRIB_HOLE_NOT_PLATED);
|
rk.mechanical = ( pad->GetAttribute() == PAD_ATTRIB_NPTH );
|
||||||
rk.x_location = pad->GetPosition().x - origin.x;
|
rk.x_location = pad->GetPosition().x - origin.x;
|
||||||
rk.y_location = origin.y - pad->GetPosition().y;
|
rk.y_location = origin.y - pad->GetPosition().y;
|
||||||
rk.x_size = pad->GetSize().x;
|
rk.x_size = pad->GetSize().x;
|
||||||
|
|
|
@ -55,7 +55,7 @@ public:
|
||||||
|
|
||||||
bool isThrough() const
|
bool isThrough() const
|
||||||
{
|
{
|
||||||
return m_type == PAD_ATTRIB_HOLE_NOT_PLATED || m_type == PAD_ATTRIB_STANDARD;
|
return m_type == PAD_ATTRIB_NPTH || m_type == PAD_ATTRIB_PTH;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool operator==( const HYPERLYNX_PAD_STACK& other ) const
|
bool operator==( const HYPERLYNX_PAD_STACK& other ) const
|
||||||
|
@ -237,7 +237,7 @@ HYPERLYNX_PAD_STACK::HYPERLYNX_PAD_STACK( BOARD* aBoard, const D_PAD* aPad )
|
||||||
m_layers = aPad->GetLayerSet();
|
m_layers = aPad->GetLayerSet();
|
||||||
m_drill = aPad->GetDrillSize().x;
|
m_drill = aPad->GetDrillSize().x;
|
||||||
m_shape = aPad->GetShape();
|
m_shape = aPad->GetShape();
|
||||||
m_type = PAD_ATTRIB_STANDARD;
|
m_type = PAD_ATTRIB_PTH;
|
||||||
m_id = 0;
|
m_id = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -251,7 +251,7 @@ HYPERLYNX_PAD_STACK::HYPERLYNX_PAD_STACK( BOARD* aBoard, const VIA* aVia )
|
||||||
m_layers = LSET::AllCuMask();
|
m_layers = LSET::AllCuMask();
|
||||||
m_drill = aVia->GetDrillValue();
|
m_drill = aVia->GetDrillValue();
|
||||||
m_shape = PAD_SHAPE_CIRCLE;
|
m_shape = PAD_SHAPE_CIRCLE;
|
||||||
m_type = PAD_ATTRIB_STANDARD;
|
m_type = PAD_ATTRIB_PTH;
|
||||||
m_id = 0;
|
m_id = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -321,7 +321,7 @@ static void idf_export_module( BOARD* aPcb, MODULE* aModule,
|
||||||
if( drill > 0.0 )
|
if( drill > 0.0 )
|
||||||
{
|
{
|
||||||
// plating
|
// plating
|
||||||
if( pad->GetAttribute() == PAD_ATTRIB_HOLE_NOT_PLATED )
|
if( pad->GetAttribute() == PAD_ATTRIB_NPTH )
|
||||||
kplate = IDF3::NPTH;
|
kplate = IDF3::NPTH;
|
||||||
else
|
else
|
||||||
kplate = IDF3::PTH;
|
kplate = IDF3::PTH;
|
||||||
|
|
|
@ -1259,7 +1259,7 @@ static void export_vrml_pad( MODEL_VRML& aModel, BOARD* aPcb, D_PAD* aPad )
|
||||||
{
|
{
|
||||||
bool pth = false;
|
bool pth = false;
|
||||||
|
|
||||||
if( ( aPad->GetAttribute() != PAD_ATTRIB_HOLE_NOT_PLATED )
|
if( ( aPad->GetAttribute() != PAD_ATTRIB_NPTH )
|
||||||
&& !aModel.m_plainPCB )
|
&& !aModel.m_plainPCB )
|
||||||
pth = true;
|
pth = true;
|
||||||
|
|
||||||
|
|
|
@ -126,10 +126,10 @@ void GENDRILL_WRITER_BASE::buildHolesList( DRILL_LAYER_PAIR aLayerPair,
|
||||||
{
|
{
|
||||||
if( !m_merge_PTH_NPTH )
|
if( !m_merge_PTH_NPTH )
|
||||||
{
|
{
|
||||||
if( !aGenerateNPTH_list && pad->GetAttribute() == PAD_ATTRIB_HOLE_NOT_PLATED )
|
if( !aGenerateNPTH_list && pad->GetAttribute() == PAD_ATTRIB_NPTH )
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
if( aGenerateNPTH_list && pad->GetAttribute() != PAD_ATTRIB_HOLE_NOT_PLATED )
|
if( aGenerateNPTH_list && pad->GetAttribute() != PAD_ATTRIB_NPTH )
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -137,7 +137,7 @@ void GENDRILL_WRITER_BASE::buildHolesList( DRILL_LAYER_PAIR aLayerPair,
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
new_hole.m_ItemParent = pad;
|
new_hole.m_ItemParent = pad;
|
||||||
new_hole.m_Hole_NotPlated = (pad->GetAttribute() == PAD_ATTRIB_HOLE_NOT_PLATED);
|
new_hole.m_Hole_NotPlated = (pad->GetAttribute() == PAD_ATTRIB_NPTH);
|
||||||
new_hole.m_Tool_Reference = -1; // Flag is: Not initialized
|
new_hole.m_Tool_Reference = -1; // Flag is: Not initialized
|
||||||
new_hole.m_Hole_Orient = pad->GetOrientation();
|
new_hole.m_Hole_Orient = pad->GetOrientation();
|
||||||
new_hole.m_Hole_Shape = 0; // hole shape: round
|
new_hole.m_Hole_Shape = 0; // hole shape: round
|
||||||
|
|
|
@ -1246,10 +1246,10 @@ void PCB_IO::format( D_PAD* aPad, int aNestLevel ) const
|
||||||
|
|
||||||
switch( aPad->GetAttribute() )
|
switch( aPad->GetAttribute() )
|
||||||
{
|
{
|
||||||
case PAD_ATTRIB_STANDARD: type = "thru_hole"; break;
|
case PAD_ATTRIB_PTH: type = "thru_hole"; break;
|
||||||
case PAD_ATTRIB_SMD: type = "smd"; break;
|
case PAD_ATTRIB_SMD: type = "smd"; break;
|
||||||
case PAD_ATTRIB_CONN: type = "connect"; break;
|
case PAD_ATTRIB_CONN: type = "connect"; break;
|
||||||
case PAD_ATTRIB_HOLE_NOT_PLATED: type = "np_thru_hole"; break;
|
case PAD_ATTRIB_NPTH: type = "np_thru_hole"; break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
THROW_IO_ERROR( wxString::Format( "unknown pad attribute: %d", aPad->GetAttribute() ) );
|
THROW_IO_ERROR( wxString::Format( "unknown pad attribute: %d", aPad->GetAttribute() ) );
|
||||||
|
@ -1314,7 +1314,7 @@ void PCB_IO::format( D_PAD* aPad, int aNestLevel ) const
|
||||||
|
|
||||||
formatLayers( aPad->GetLayerSet() );
|
formatLayers( aPad->GetLayerSet() );
|
||||||
|
|
||||||
if( aPad->GetAttribute() == PAD_ATTRIB_STANDARD )
|
if( aPad->GetAttribute() == PAD_ATTRIB_PTH )
|
||||||
{
|
{
|
||||||
if( aPad->GetRemoveUnconnected() )
|
if( aPad->GetRemoveUnconnected() )
|
||||||
{
|
{
|
||||||
|
|
|
@ -1524,9 +1524,9 @@ void LEGACY_PLUGIN::loadPAD( MODULE* aModule )
|
||||||
else if( !strcmp( data, "CONN" ) )
|
else if( !strcmp( data, "CONN" ) )
|
||||||
attribute = PAD_ATTRIB_CONN;
|
attribute = PAD_ATTRIB_CONN;
|
||||||
else if( !strcmp( data, "HOLE" ) )
|
else if( !strcmp( data, "HOLE" ) )
|
||||||
attribute = PAD_ATTRIB_HOLE_NOT_PLATED;
|
attribute = PAD_ATTRIB_NPTH;
|
||||||
else
|
else
|
||||||
attribute = PAD_ATTRIB_STANDARD;
|
attribute = PAD_ATTRIB_PTH;
|
||||||
|
|
||||||
strtok_r( NULL, delims, &saveptr ); // skip unused prm
|
strtok_r( NULL, delims, &saveptr ); // skip unused prm
|
||||||
data = strtok_r( NULL, delims, &saveptr );
|
data = strtok_r( NULL, delims, &saveptr );
|
||||||
|
|
|
@ -30,7 +30,7 @@ bool PAD_NAMING::PadCanHaveName( const D_PAD& aPad )
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
// NPTH pads don't get numbers
|
// NPTH pads don't get numbers
|
||||||
if( aPad.GetAttribute() == PAD_ATTRIB_HOLE_NOT_PLATED )
|
if( aPad.GetAttribute() == PAD_ATTRIB_NPTH )
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
|
|
|
@ -199,7 +199,7 @@ void PCB_PAD::AddToModule( MODULE* aModule, int aRotation, bool aEncapsulatedPad
|
||||||
{
|
{
|
||||||
// mechanical hole
|
// mechanical hole
|
||||||
pad->SetShape( PAD_SHAPE_CIRCLE );
|
pad->SetShape( PAD_SHAPE_CIRCLE );
|
||||||
pad->SetAttribute( PAD_ATTRIB_HOLE_NOT_PLATED );
|
pad->SetAttribute( PAD_ATTRIB_NPTH );
|
||||||
|
|
||||||
pad->SetDrillShape( PAD_DRILL_SHAPE_CIRCLE );
|
pad->SetDrillShape( PAD_DRILL_SHAPE_CIRCLE );
|
||||||
pad->SetDrillSize( wxSize( m_hole, m_hole ) );
|
pad->SetDrillSize( wxSize( m_hole, m_hole ) );
|
||||||
|
@ -218,7 +218,7 @@ void PCB_PAD::AddToModule( MODULE* aModule, int aRotation, bool aEncapsulatedPad
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
( m_hole ) ? padType = PAD_ATTRIB_STANDARD : padType = PAD_ATTRIB_SMD;
|
( m_hole ) ? padType = PAD_ATTRIB_PTH : padType = PAD_ATTRIB_SMD;
|
||||||
|
|
||||||
// form layer mask
|
// form layer mask
|
||||||
for( i = 0; i < (int) m_shapes.GetCount(); i++ )
|
for( i = 0; i < (int) m_shapes.GetCount(); i++ )
|
||||||
|
@ -250,7 +250,7 @@ void PCB_PAD::AddToModule( MODULE* aModule, int aRotation, bool aEncapsulatedPad
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if( padType == PAD_ATTRIB_STANDARD )
|
if( padType == PAD_ATTRIB_PTH )
|
||||||
// actually this is a thru-hole pad
|
// actually this is a thru-hole pad
|
||||||
pad->SetLayerSet( LSET::AllCuMask() | LSET( 2, B_Mask, F_Mask ) );
|
pad->SetLayerSet( LSET::AllCuMask() | LSET( 2, B_Mask, F_Mask ) );
|
||||||
|
|
||||||
|
|
|
@ -134,7 +134,7 @@ static void isPlated( LIBEVAL::CONTEXT* aCtx, void* self )
|
||||||
BOARD_ITEM* item = vref ? vref->GetObject( aCtx ) : nullptr;
|
BOARD_ITEM* item = vref ? vref->GetObject( aCtx ) : nullptr;
|
||||||
D_PAD* pad = dynamic_cast<D_PAD*>( item );
|
D_PAD* pad = dynamic_cast<D_PAD*>( item );
|
||||||
|
|
||||||
if( pad && pad->GetAttribute() == PAD_ATTRIB_STANDARD )
|
if( pad && pad->GetAttribute() == PAD_ATTRIB_PTH )
|
||||||
result->Set( 1.0 );
|
result->Set( 1.0 );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -3424,7 +3424,7 @@ D_PAD* PCB_PARSER::parseD_PAD( MODULE* aParent )
|
||||||
switch( token )
|
switch( token )
|
||||||
{
|
{
|
||||||
case T_thru_hole:
|
case T_thru_hole:
|
||||||
pad->SetAttribute( PAD_ATTRIB_STANDARD );
|
pad->SetAttribute( PAD_ATTRIB_PTH );
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case T_smd:
|
case T_smd:
|
||||||
|
@ -3444,7 +3444,7 @@ D_PAD* PCB_PARSER::parseD_PAD( MODULE* aParent )
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case T_np_thru_hole:
|
case T_np_thru_hole:
|
||||||
pad->SetAttribute( PAD_ATTRIB_HOLE_NOT_PLATED );
|
pad->SetAttribute( PAD_ATTRIB_NPTH );
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
|
|
|
@ -300,7 +300,7 @@ void PlotStandardLayer( BOARD *aBoard, PLOTTER* aPlotter, LSET aLayerMask,
|
||||||
if( aPlotOpt.GetSkipPlotNPTH_Pads() &&
|
if( aPlotOpt.GetSkipPlotNPTH_Pads() &&
|
||||||
( aPlotOpt.GetDrillMarksType() == PCB_PLOT_PARAMS::NO_DRILL_SHAPE ) &&
|
( aPlotOpt.GetDrillMarksType() == PCB_PLOT_PARAMS::NO_DRILL_SHAPE ) &&
|
||||||
( pad->GetSize() == pad->GetDrillSize() ) &&
|
( pad->GetSize() == pad->GetDrillSize() ) &&
|
||||||
( pad->GetAttribute() == PAD_ATTRIB_HOLE_NOT_PLATED ) )
|
( pad->GetAttribute() == PAD_ATTRIB_NPTH ) )
|
||||||
break;
|
break;
|
||||||
|
|
||||||
itemplotter.PlotPad( pad, color, padPlotMode );
|
itemplotter.PlotPad( pad, color, padPlotMode );
|
||||||
|
|
|
@ -47,7 +47,7 @@
|
||||||
#include <gbr_metadata.h>
|
#include <gbr_metadata.h>
|
||||||
#include <gbr_netlist_metadata.h> // for GBR_NETLIST_METADATA
|
#include <gbr_netlist_metadata.h> // for GBR_NETLIST_METADATA
|
||||||
#include <layers_id_colors_and_visibility.h> // for LSET, IsCopperLayer
|
#include <layers_id_colors_and_visibility.h> // for LSET, IsCopperLayer
|
||||||
#include <pad_shapes.h> // for PAD_ATTRIB_HOLE_NOT_PLATED
|
#include <pad_shapes.h> // for PAD_ATTRIB_NPTH
|
||||||
#include <pcbplot.h>
|
#include <pcbplot.h>
|
||||||
#include <pcb_plot_params.h> // for PCB_PLOT_PARAMS, PCB_PL...
|
#include <pcb_plot_params.h> // for PCB_PLOT_PARAMS, PCB_PL...
|
||||||
|
|
||||||
|
@ -122,7 +122,7 @@ void BRDITEMS_PLOTTER::PlotPad( D_PAD* aPad, COLOR4D aColor, EDA_DRAW_MODE_T aPl
|
||||||
// Some pads are mechanical pads ( through hole or smd )
|
// Some pads are mechanical pads ( through hole or smd )
|
||||||
// when this is the case, they have no pad name and/or are not plated.
|
// when this is the case, they have no pad name and/or are not plated.
|
||||||
// In this case gerber files have slightly different attributes.
|
// In this case gerber files have slightly different attributes.
|
||||||
if( aPad->GetAttribute() == PAD_ATTRIB_HOLE_NOT_PLATED || aPad->GetName().IsEmpty() )
|
if( aPad->GetAttribute() == PAD_ATTRIB_NPTH || aPad->GetName().IsEmpty() )
|
||||||
gbr_metadata.m_NetlistMetadata.m_NotInNet = true;
|
gbr_metadata.m_NetlistMetadata.m_NotInNet = true;
|
||||||
|
|
||||||
if( !plotOnExternalCopperLayer )
|
if( !plotOnExternalCopperLayer )
|
||||||
|
@ -145,11 +145,11 @@ void BRDITEMS_PLOTTER::PlotPad( D_PAD* aPad, COLOR4D aColor, EDA_DRAW_MODE_T aPl
|
||||||
// has its aperture attribute set to GBR_APERTURE_ATTRIB_CONDUCTOR
|
// has its aperture attribute set to GBR_APERTURE_ATTRIB_CONDUCTOR
|
||||||
switch( aPad->GetAttribute() )
|
switch( aPad->GetAttribute() )
|
||||||
{
|
{
|
||||||
case PAD_ATTRIB_HOLE_NOT_PLATED: // Mechanical pad through hole
|
case PAD_ATTRIB_NPTH: // Mechanical pad through hole
|
||||||
gbr_metadata.SetApertureAttrib( GBR_APERTURE_METADATA::GBR_APERTURE_ATTRIB_WASHERPAD );
|
gbr_metadata.SetApertureAttrib( GBR_APERTURE_METADATA::GBR_APERTURE_ATTRIB_WASHERPAD );
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case PAD_ATTRIB_STANDARD : // Pad through hole, a hole is also expected
|
case PAD_ATTRIB_PTH : // Pad through hole, a hole is also expected
|
||||||
gbr_metadata.SetApertureAttrib( GBR_APERTURE_METADATA::GBR_APERTURE_ATTRIB_COMPONENTPAD );
|
gbr_metadata.SetApertureAttrib( GBR_APERTURE_METADATA::GBR_APERTURE_ATTRIB_COMPONENTPAD );
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
@ -200,7 +200,7 @@ void BRDITEMS_PLOTTER::PlotPad( D_PAD* aPad, COLOR4D aColor, EDA_DRAW_MODE_T aPl
|
||||||
}
|
}
|
||||||
|
|
||||||
// Ensure NPTH pads have *always* the GBR_APERTURE_ATTRIB_WASHERPAD attribute
|
// Ensure NPTH pads have *always* the GBR_APERTURE_ATTRIB_WASHERPAD attribute
|
||||||
if( aPad->GetAttribute() == PAD_ATTRIB_HOLE_NOT_PLATED )
|
if( aPad->GetAttribute() == PAD_ATTRIB_NPTH )
|
||||||
gbr_metadata.SetApertureAttrib( GBR_APERTURE_METADATA::GBR_APERTURE_ATTRIB_WASHERPAD );
|
gbr_metadata.SetApertureAttrib( GBR_APERTURE_METADATA::GBR_APERTURE_ATTRIB_WASHERPAD );
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
|
|
@ -1739,8 +1739,8 @@ void ALTIUM_PCB::ParsePads6Data(
|
||||||
"Pad '%s' of Footprint %s is not marked as multilayer, but it is an THT pad",
|
"Pad '%s' of Footprint %s is not marked as multilayer, but it is an THT pad",
|
||||||
elem.name, module->GetReference() ) );
|
elem.name, module->GetReference() ) );
|
||||||
}
|
}
|
||||||
pad->SetAttribute( elem.plated ? PAD_ATTR_T::PAD_ATTRIB_STANDARD :
|
pad->SetAttribute( elem.plated ? PAD_ATTR_T::PAD_ATTRIB_PTH :
|
||||||
PAD_ATTR_T::PAD_ATTRIB_HOLE_NOT_PLATED );
|
PAD_ATTR_T::PAD_ATTRIB_NPTH );
|
||||||
if( !elem.sizeAndShape || elem.sizeAndShape->holeshape == ALTIUM_PAD_HOLE_SHAPE::ROUND )
|
if( !elem.sizeAndShape || elem.sizeAndShape->holeshape == ALTIUM_PAD_HOLE_SHAPE::ROUND )
|
||||||
{
|
{
|
||||||
pad->SetDrillShape( PAD_DRILL_SHAPE_T::PAD_DRILL_SHAPE_CIRCLE );
|
pad->SetDrillShape( PAD_DRILL_SHAPE_T::PAD_DRILL_SHAPE_CIRCLE );
|
||||||
|
@ -1855,7 +1855,7 @@ void ALTIUM_PCB::ParsePads6Data(
|
||||||
pad->SetLayerSet( FlipLayerMask( D_PAD::SMDMask() ) );
|
pad->SetLayerSet( FlipLayerMask( D_PAD::SMDMask() ) );
|
||||||
break;
|
break;
|
||||||
case ALTIUM_LAYER::MULTI_LAYER:
|
case ALTIUM_LAYER::MULTI_LAYER:
|
||||||
pad->SetLayerSet( elem.plated ? D_PAD::StandardMask() : D_PAD::UnplatedHoleMask() );
|
pad->SetLayerSet( elem.plated ? D_PAD::PTHMask() : D_PAD::UnplatedHoleMask() );
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
PCB_LAYER_ID klayer = GetKicadLayer( elem.layer );
|
PCB_LAYER_ID klayer = GetKicadLayer( elem.layer );
|
||||||
|
|
|
@ -582,11 +582,11 @@ void CADSTAR_PCB_ARCHIVE_LOADER::loadLibraryPads( const SYMDEF_PCB& aComponent,
|
||||||
case PAD_SIDE::THROUGH_HOLE:
|
case PAD_SIDE::THROUGH_HOLE:
|
||||||
|
|
||||||
if( csPadcode.Plated )
|
if( csPadcode.Plated )
|
||||||
pad->SetAttribute( PAD_ATTR_T::PAD_ATTRIB_STANDARD );
|
pad->SetAttribute( PAD_ATTR_T::PAD_ATTRIB_PTH );
|
||||||
else
|
else
|
||||||
pad->SetAttribute( PAD_ATTR_T::PAD_ATTRIB_HOLE_NOT_PLATED );
|
pad->SetAttribute( PAD_ATTR_T::PAD_ATTRIB_NPTH );
|
||||||
|
|
||||||
pad->SetLayerSet( pad->StandardMask() ); // for now we will assume no paste layers
|
pad->SetLayerSet( pad->PTHMask() ); // for now we will assume no paste layers
|
||||||
//TODO: We need to read the csPad->Reassigns vector to make sure no paste
|
//TODO: We need to read the csPad->Reassigns vector to make sure no paste
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
|
|
@ -583,15 +583,15 @@ std::unique_ptr<PNS::SOLID> PNS_KICAD_IFACE_BASE::syncPad( D_PAD* aPad )
|
||||||
|
|
||||||
// ignore non-copper pads except for those with holes
|
// ignore non-copper pads except for those with holes
|
||||||
if( ( aPad->GetLayerSet() & LSET::AllCuMask()).none() &&
|
if( ( aPad->GetLayerSet() & LSET::AllCuMask()).none() &&
|
||||||
aPad->GetAttribute() != PAD_ATTRIB_HOLE_NOT_PLATED )
|
aPad->GetAttribute() != PAD_ATTRIB_NPTH )
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
switch( aPad->GetAttribute() )
|
switch( aPad->GetAttribute() )
|
||||||
{
|
{
|
||||||
case PAD_ATTRIB_STANDARD:
|
case PAD_ATTRIB_PTH:
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case PAD_ATTRIB_HOLE_NOT_PLATED:
|
case PAD_ATTRIB_NPTH:
|
||||||
case PAD_ATTRIB_CONN:
|
case PAD_ATTRIB_CONN:
|
||||||
case PAD_ATTRIB_SMD:
|
case PAD_ATTRIB_SMD:
|
||||||
{
|
{
|
||||||
|
@ -604,7 +604,7 @@ std::unique_ptr<PNS::SOLID> PNS_KICAD_IFACE_BASE::syncPad( D_PAD* aPad )
|
||||||
{
|
{
|
||||||
is_copper = true;
|
is_copper = true;
|
||||||
|
|
||||||
if( aPad->GetAttribute() != PAD_ATTRIB_HOLE_NOT_PLATED )
|
if( aPad->GetAttribute() != PAD_ATTRIB_NPTH )
|
||||||
layers = LAYER_RANGE( i );
|
layers = LAYER_RANGE( i );
|
||||||
|
|
||||||
break;
|
break;
|
||||||
|
@ -612,7 +612,7 @@ std::unique_ptr<PNS::SOLID> PNS_KICAD_IFACE_BASE::syncPad( D_PAD* aPad )
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Keep the NPTH pads because we will use the drill as alternate shape
|
/// Keep the NPTH pads because we will use the drill as alternate shape
|
||||||
if( !is_copper && aPad->GetAttribute() != PAD_ATTRIB_HOLE_NOT_PLATED )
|
if( !is_copper && aPad->GetAttribute() != PAD_ATTRIB_NPTH )
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
@ -624,11 +624,11 @@ std::unique_ptr<PNS::SOLID> PNS_KICAD_IFACE_BASE::syncPad( D_PAD* aPad )
|
||||||
|
|
||||||
std::unique_ptr< PNS::SOLID > solid( new PNS::SOLID );
|
std::unique_ptr< PNS::SOLID > solid( new PNS::SOLID );
|
||||||
|
|
||||||
if( aPad->GetAttribute() == PAD_ATTRIB_STANDARD ||
|
if( aPad->GetAttribute() == PAD_ATTRIB_PTH ||
|
||||||
aPad->GetAttribute() == PAD_ATTRIB_HOLE_NOT_PLATED )
|
aPad->GetAttribute() == PAD_ATTRIB_NPTH )
|
||||||
solid->SetAlternateShape( aPad->GetEffectiveHoleShape()->Clone() );
|
solid->SetAlternateShape( aPad->GetEffectiveHoleShape()->Clone() );
|
||||||
|
|
||||||
if( aPad->GetAttribute() == PAD_ATTRIB_HOLE_NOT_PLATED )
|
if( aPad->GetAttribute() == PAD_ATTRIB_NPTH )
|
||||||
solid->SetRoutable( false );
|
solid->SetRoutable( false );
|
||||||
|
|
||||||
solid->SetLayers( layers );
|
solid->SetLayers( layers );
|
||||||
|
|
|
@ -124,7 +124,7 @@ void PCB_INSPECTION_TOOL::reportZoneConnection( ZONE_CONTAINER* aZone, D_PAD* aP
|
||||||
// Resolve complex connection types into simple types
|
// Resolve complex connection types into simple types
|
||||||
if( connection == ZONE_CONNECTION::THT_THERMAL )
|
if( connection == ZONE_CONNECTION::THT_THERMAL )
|
||||||
{
|
{
|
||||||
if( aPad->GetAttribute() == PAD_ATTRIB_STANDARD )
|
if( aPad->GetAttribute() == PAD_ATTRIB_PTH )
|
||||||
{
|
{
|
||||||
connection = ZONE_CONNECTION::THERMAL;
|
connection = ZONE_CONNECTION::THERMAL;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1918,8 +1918,8 @@ bool SELECTION_TOOL::Selectable( const BOARD_ITEM* aItem, bool checkVisibilityOn
|
||||||
// Check render mode (from the Items tab) first
|
// Check render mode (from the Items tab) first
|
||||||
switch( pad->GetAttribute() )
|
switch( pad->GetAttribute() )
|
||||||
{
|
{
|
||||||
case PAD_ATTRIB_STANDARD:
|
case PAD_ATTRIB_PTH:
|
||||||
case PAD_ATTRIB_HOLE_NOT_PLATED:
|
case PAD_ATTRIB_NPTH:
|
||||||
if( !board()->IsElementVisible( LAYER_PADS_TH ) )
|
if( !board()->IsElementVisible( LAYER_PADS_TH ) )
|
||||||
return false;
|
return false;
|
||||||
break;
|
break;
|
||||||
|
|
|
@ -505,7 +505,7 @@ bool hasThermalConnection( D_PAD* pad, const ZONE_CONTAINER* aZone )
|
||||||
{
|
{
|
||||||
// Rejects non-standard pads with tht-only thermal reliefs
|
// Rejects non-standard pads with tht-only thermal reliefs
|
||||||
if( aZone->GetPadConnection( pad ) == ZONE_CONNECTION::THT_THERMAL
|
if( aZone->GetPadConnection( pad ) == ZONE_CONNECTION::THT_THERMAL
|
||||||
&& pad->GetAttribute() != PAD_ATTRIB_STANDARD )
|
&& pad->GetAttribute() != PAD_ATTRIB_PTH )
|
||||||
{
|
{
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -556,7 +556,7 @@ static void setupDummyPadForHole( const D_PAD* aPad, D_PAD& aDummyPad )
|
||||||
// plating thickness larger.
|
// plating thickness larger.
|
||||||
int platingThickness = 0;
|
int platingThickness = 0;
|
||||||
|
|
||||||
if( aPad->GetAttribute() == PAD_ATTRIB_STANDARD )
|
if( aPad->GetAttribute() == PAD_ATTRIB_PTH )
|
||||||
platingThickness = aPad->GetBoard()->GetDesignSettings().GetHolePlatingThickness();
|
platingThickness = aPad->GetBoard()->GetDesignSettings().GetHolePlatingThickness();
|
||||||
|
|
||||||
aDummyPad.SetOffset( wxPoint( 0, 0 ) );
|
aDummyPad.SetOffset( wxPoint( 0, 0 ) );
|
||||||
|
|
|
@ -37,7 +37,7 @@ struct PAD_FIXTURE
|
||||||
{
|
{
|
||||||
D_PAD pad( &m_module );
|
D_PAD pad( &m_module );
|
||||||
|
|
||||||
pad.SetAttribute( PAD_ATTRIB_HOLE_NOT_PLATED );
|
pad.SetAttribute( PAD_ATTRIB_NPTH );
|
||||||
pad.SetLayerSet( D_PAD::UnplatedHoleMask() );
|
pad.SetLayerSet( D_PAD::UnplatedHoleMask() );
|
||||||
|
|
||||||
return pad;
|
return pad;
|
||||||
|
@ -47,7 +47,7 @@ struct PAD_FIXTURE
|
||||||
{
|
{
|
||||||
D_PAD pad( &m_module );
|
D_PAD pad( &m_module );
|
||||||
|
|
||||||
pad.SetAttribute( PAD_ATTRIB_STANDARD );
|
pad.SetAttribute( PAD_ATTRIB_PTH );
|
||||||
pad.SetLayerSet( D_PAD::ApertureMask() );
|
pad.SetLayerSet( D_PAD::ApertureMask() );
|
||||||
|
|
||||||
return pad;
|
return pad;
|
||||||
|
|
Loading…
Reference in New Issue