Yet another tranche of module -> footprint.
This commit is contained in:
parent
2cc9dad4ff
commit
9106cc19bf
|
@ -238,11 +238,11 @@ void BOARD_ADAPTER::SetFlag( DISPLAY3D_FLG aFlag, bool aState )
|
||||||
m_drawFlags[aFlag] = aState;
|
m_drawFlags[aFlag] = aState;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool BOARD_ADAPTER::ShouldModuleBeDisplayed( MODULE_ATTR_T aModuleAttributs ) const
|
bool BOARD_ADAPTER::ShouldFPBeDisplayed( FOOTPRINT_ATTR_T aFPAttributes ) const
|
||||||
{
|
{
|
||||||
if( aModuleAttributs & MOD_SMD )
|
if( aFPAttributes & FP_SMD )
|
||||||
return GetFlag( FL_FP_ATTRIBUTES_NORMAL_INSERT );
|
return GetFlag( FL_FP_ATTRIBUTES_NORMAL_INSERT );
|
||||||
else if( aModuleAttributs & MOD_THROUGH_HOLE )
|
else if( aFPAttributes & FP_THROUGH_HOLE )
|
||||||
return GetFlag( FL_FP_ATTRIBUTES_NORMAL );
|
return GetFlag( FL_FP_ATTRIBUTES_NORMAL );
|
||||||
else
|
else
|
||||||
return GetFlag( FL_FP_ATTRIBUTES_VIRTUAL );
|
return GetFlag( FL_FP_ATTRIBUTES_VIRTUAL );
|
||||||
|
|
|
@ -117,7 +117,7 @@ class BOARD_ADAPTER
|
||||||
* relation to attributs and the flags
|
* relation to attributs and the flags
|
||||||
* @return true if module should be displayed, false if not
|
* @return true if module should be displayed, false if not
|
||||||
*/
|
*/
|
||||||
bool ShouldModuleBeDisplayed( MODULE_ATTR_T aModuleAttributs ) const;
|
bool ShouldFPBeDisplayed( FOOTPRINT_ATTR_T aFPAttributes ) const;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief SetBoard - Set current board to be rendered
|
* @brief SetBoard - Set current board to be rendered
|
||||||
|
|
|
@ -1287,7 +1287,7 @@ void C3D_RENDER_OGL_LEGACY::render_3D_models_selected( bool aRenderTopOrBot,
|
||||||
|
|
||||||
if( !fp->Models().empty() )
|
if( !fp->Models().empty() )
|
||||||
{
|
{
|
||||||
if( m_boardAdapter.ShouldModuleBeDisplayed( (MODULE_ATTR_T) fp->GetAttributes() ) )
|
if( m_boardAdapter.ShouldFPBeDisplayed((FOOTPRINT_ATTR_T) fp->GetAttributes()) )
|
||||||
{
|
{
|
||||||
if( ( aRenderTopOrBot && !fp->IsFlipped() )
|
if( ( aRenderTopOrBot && !fp->IsFlipped() )
|
||||||
|| ( !aRenderTopOrBot && fp->IsFlipped() ) )
|
|| ( !aRenderTopOrBot && fp->IsFlipped() ) )
|
||||||
|
|
|
@ -1403,7 +1403,7 @@ void C3D_RENDER_RAYTRACING::load_3D_models( CCONTAINER &aDstContainer, bool aSki
|
||||||
for( MODULE* fp : m_boardAdapter.GetBoard()->Footprints() )
|
for( MODULE* fp : m_boardAdapter.GetBoard()->Footprints() )
|
||||||
{
|
{
|
||||||
if( !fp->Models().empty()
|
if( !fp->Models().empty()
|
||||||
&& m_boardAdapter.ShouldModuleBeDisplayed( (MODULE_ATTR_T)fp->GetAttributes() ) )
|
&& m_boardAdapter.ShouldFPBeDisplayed((FOOTPRINT_ATTR_T) fp->GetAttributes()) )
|
||||||
{
|
{
|
||||||
double zpos = m_boardAdapter.GetModulesZcoord3DIU( fp->IsFlipped() );
|
double zpos = m_boardAdapter.GetModulesZcoord3DIU( fp->IsFlipped() );
|
||||||
|
|
||||||
|
|
|
@ -134,8 +134,8 @@ void DIALOG_BOARD_STATISTICS::refreshItemsTypes()
|
||||||
|
|
||||||
// If you need some more types to be shown, simply add them to the
|
// If you need some more types to be shown, simply add them to the
|
||||||
// corresponding list
|
// corresponding list
|
||||||
m_componentsTypes.push_back( componentsType_t( MOD_THROUGH_HOLE, _( "THT:" ) ) );
|
m_componentsTypes.push_back( componentsType_t( FP_THROUGH_HOLE, _( "THT:" ) ) );
|
||||||
m_componentsTypes.push_back( componentsType_t( MOD_SMD, _( "SMD:" ) ) );
|
m_componentsTypes.push_back( componentsType_t( FP_SMD, _( "SMD:" ) ) );
|
||||||
|
|
||||||
m_padsTypes.clear();
|
m_padsTypes.clear();
|
||||||
m_padsTypes.push_back( padsType_t( PAD_ATTRIB_PTH, _( "Through hole:" ) ) );
|
m_padsTypes.push_back( padsType_t( PAD_ATTRIB_PTH, _( "Through hole:" ) ) );
|
||||||
|
|
|
@ -73,17 +73,17 @@ public:
|
||||||
*/
|
*/
|
||||||
struct componentsType_t
|
struct componentsType_t
|
||||||
{
|
{
|
||||||
componentsType_t( MODULE_ATTR_T aAttribute, wxString aTitle )
|
componentsType_t( FOOTPRINT_ATTR_T aAttribute, wxString aTitle )
|
||||||
: attribute( aAttribute ),
|
: attribute( aAttribute ),
|
||||||
title( aTitle ),
|
title( aTitle ),
|
||||||
frontSideQty( 0 ),
|
frontSideQty( 0 ),
|
||||||
backSideQty( 0 )
|
backSideQty( 0 )
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
MODULE_ATTR_T attribute;
|
FOOTPRINT_ATTR_T attribute;
|
||||||
wxString title;
|
wxString title;
|
||||||
int frontSideQty;
|
int frontSideQty;
|
||||||
int backSideQty;
|
int backSideQty;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct drillType_t
|
struct drillType_t
|
||||||
|
|
|
@ -235,16 +235,16 @@ bool DIALOG_FOOTPRINT_FP_EDITOR::TransferDataToWindow()
|
||||||
m_CostRot90Ctrl->SetValue( m_footprint->GetPlacementCost90() );
|
m_CostRot90Ctrl->SetValue( m_footprint->GetPlacementCost90() );
|
||||||
m_CostRot180Ctrl->SetValue( m_footprint->GetPlacementCost180() );
|
m_CostRot180Ctrl->SetValue( m_footprint->GetPlacementCost180() );
|
||||||
|
|
||||||
if( m_footprint->GetAttributes() & MOD_THROUGH_HOLE )
|
if( m_footprint->GetAttributes() & FP_THROUGH_HOLE )
|
||||||
m_componentType->SetSelection( 0 );
|
m_componentType->SetSelection( 0 );
|
||||||
else if( m_footprint->GetAttributes() & MOD_SMD )
|
else if( m_footprint->GetAttributes() & FP_SMD )
|
||||||
m_componentType->SetSelection( 1 );
|
m_componentType->SetSelection( 1 );
|
||||||
else
|
else
|
||||||
m_componentType->SetSelection( 2 );
|
m_componentType->SetSelection( 2 );
|
||||||
|
|
||||||
m_boardOnly->SetValue( m_footprint->GetAttributes() & MOD_BOARD_ONLY );
|
m_boardOnly->SetValue( m_footprint->GetAttributes() & FP_BOARD_ONLY );
|
||||||
m_excludeFromPosFiles->SetValue( m_footprint->GetAttributes() & MOD_EXCLUDE_FROM_POS_FILES );
|
m_excludeFromPosFiles->SetValue( m_footprint->GetAttributes() & FP_EXCLUDE_FROM_POS_FILES );
|
||||||
m_excludeFromBOM->SetValue( m_footprint->GetAttributes() & MOD_EXCLUDE_FROM_BOM );
|
m_excludeFromBOM->SetValue( m_footprint->GetAttributes() & FP_EXCLUDE_FROM_BOM );
|
||||||
|
|
||||||
// Local Clearances
|
// Local Clearances
|
||||||
|
|
||||||
|
@ -650,19 +650,19 @@ bool DIALOG_FOOTPRINT_FP_EDITOR::TransferDataFromWindow()
|
||||||
|
|
||||||
switch( m_componentType->GetSelection() )
|
switch( m_componentType->GetSelection() )
|
||||||
{
|
{
|
||||||
case 0: attributes |= MOD_THROUGH_HOLE; break;
|
case 0: attributes |= FP_THROUGH_HOLE; break;
|
||||||
case 1: attributes |= MOD_SMD; break;
|
case 1: attributes |= FP_SMD; break;
|
||||||
default: break;
|
default: break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if( m_boardOnly->GetValue() )
|
if( m_boardOnly->GetValue() )
|
||||||
attributes |= MOD_BOARD_ONLY;
|
attributes |= FP_BOARD_ONLY;
|
||||||
|
|
||||||
if( m_excludeFromPosFiles->GetValue() )
|
if( m_excludeFromPosFiles->GetValue() )
|
||||||
attributes |= MOD_EXCLUDE_FROM_POS_FILES;
|
attributes |= FP_EXCLUDE_FROM_POS_FILES;
|
||||||
|
|
||||||
if( m_excludeFromBOM->GetValue() )
|
if( m_excludeFromBOM->GetValue() )
|
||||||
attributes |= MOD_EXCLUDE_FROM_BOM;
|
attributes |= FP_EXCLUDE_FROM_BOM;
|
||||||
|
|
||||||
m_footprint->SetAttributes( attributes );
|
m_footprint->SetAttributes( attributes );
|
||||||
|
|
||||||
|
|
|
@ -316,16 +316,16 @@ bool DIALOG_FOOTPRINT_PROPERTIES::TransferDataToWindow()
|
||||||
m_CostRot90Ctrl->SetValue( m_footprint->GetPlacementCost90() );
|
m_CostRot90Ctrl->SetValue( m_footprint->GetPlacementCost90() );
|
||||||
m_CostRot180Ctrl->SetValue( m_footprint->GetPlacementCost180() );
|
m_CostRot180Ctrl->SetValue( m_footprint->GetPlacementCost180() );
|
||||||
|
|
||||||
if( m_footprint->GetAttributes() & MOD_THROUGH_HOLE )
|
if( m_footprint->GetAttributes() & FP_THROUGH_HOLE )
|
||||||
m_componentType->SetSelection( 0 );
|
m_componentType->SetSelection( 0 );
|
||||||
else if( m_footprint->GetAttributes() & MOD_SMD )
|
else if( m_footprint->GetAttributes() & FP_SMD )
|
||||||
m_componentType->SetSelection( 1 );
|
m_componentType->SetSelection( 1 );
|
||||||
else
|
else
|
||||||
m_componentType->SetSelection( 2 );
|
m_componentType->SetSelection( 2 );
|
||||||
|
|
||||||
m_boardOnly->SetValue( m_footprint->GetAttributes() & MOD_BOARD_ONLY );
|
m_boardOnly->SetValue( m_footprint->GetAttributes() & FP_BOARD_ONLY );
|
||||||
m_excludeFromPosFiles->SetValue( m_footprint->GetAttributes() & MOD_EXCLUDE_FROM_POS_FILES );
|
m_excludeFromPosFiles->SetValue( m_footprint->GetAttributes() & FP_EXCLUDE_FROM_POS_FILES );
|
||||||
m_excludeFromBOM->SetValue( m_footprint->GetAttributes() & MOD_EXCLUDE_FROM_BOM );
|
m_excludeFromBOM->SetValue( m_footprint->GetAttributes() & FP_EXCLUDE_FROM_BOM );
|
||||||
|
|
||||||
// Local Clearances
|
// Local Clearances
|
||||||
|
|
||||||
|
@ -706,19 +706,19 @@ bool DIALOG_FOOTPRINT_PROPERTIES::TransferDataFromWindow()
|
||||||
|
|
||||||
switch( m_componentType->GetSelection() )
|
switch( m_componentType->GetSelection() )
|
||||||
{
|
{
|
||||||
case 0: attributes |= MOD_THROUGH_HOLE; break;
|
case 0: attributes |= FP_THROUGH_HOLE; break;
|
||||||
case 1: attributes |= MOD_SMD; break;
|
case 1: attributes |= FP_SMD; break;
|
||||||
default: break;
|
default: break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if( m_boardOnly->GetValue() )
|
if( m_boardOnly->GetValue() )
|
||||||
attributes |= MOD_BOARD_ONLY;
|
attributes |= FP_BOARD_ONLY;
|
||||||
|
|
||||||
if( m_excludeFromPosFiles->GetValue() )
|
if( m_excludeFromPosFiles->GetValue() )
|
||||||
attributes |= MOD_EXCLUDE_FROM_POS_FILES;
|
attributes |= FP_EXCLUDE_FROM_POS_FILES;
|
||||||
|
|
||||||
if( m_excludeFromBOM->GetValue() )
|
if( m_excludeFromBOM->GetValue() )
|
||||||
attributes |= MOD_EXCLUDE_FROM_BOM;
|
attributes |= FP_EXCLUDE_FROM_BOM;
|
||||||
|
|
||||||
m_footprint->SetAttributes( attributes );
|
m_footprint->SetAttributes( attributes );
|
||||||
|
|
||||||
|
|
|
@ -193,7 +193,7 @@ void DRC_TEST_PROVIDER_LVS::testFootprints( NETLIST& aNetlist )
|
||||||
if( m_drcEngine->IsErrorLimitExceeded( DRCE_EXTRA_FOOTPRINT ) )
|
if( m_drcEngine->IsErrorLimitExceeded( DRCE_EXTRA_FOOTPRINT ) )
|
||||||
break;
|
break;
|
||||||
|
|
||||||
if( footprint->GetAttributes() & MOD_BOARD_ONLY )
|
if( footprint->GetAttributes() & FP_BOARD_ONLY )
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
if( !aNetlist.GetComponentByReference( footprint->GetReference() ) )
|
if( !aNetlist.GetComponentByReference( footprint->GetReference() ) )
|
||||||
|
|
|
@ -123,7 +123,7 @@ std::string PLACE_FILE_EXPORTER::GenPositionData()
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
if( footprint->GetAttributes() & MOD_EXCLUDE_FROM_POS_FILES )
|
if( footprint->GetAttributes() & FP_EXCLUDE_FROM_POS_FILES )
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
if( m_excludeAllTH && footprint->HasThroughHolePads() )
|
if( m_excludeAllTH && footprint->HasThroughHolePads() )
|
||||||
|
@ -328,13 +328,13 @@ std::string PLACE_FILE_EXPORTER::GenReportData()
|
||||||
|
|
||||||
buffer += "attribut";
|
buffer += "attribut";
|
||||||
|
|
||||||
if(( footprint->GetAttributes() & ( MOD_THROUGH_HOLE | MOD_SMD ) ) == 0 )
|
if(( footprint->GetAttributes() & ( FP_THROUGH_HOLE | FP_SMD ) ) == 0 )
|
||||||
buffer += " virtual";
|
buffer += " virtual";
|
||||||
|
|
||||||
if( footprint->GetAttributes() & MOD_SMD )
|
if( footprint->GetAttributes() & FP_SMD )
|
||||||
buffer += " smd";
|
buffer += " smd";
|
||||||
|
|
||||||
if( footprint->GetAttributes() & MOD_THROUGH_HOLE )
|
if( footprint->GetAttributes() & FP_THROUGH_HOLE )
|
||||||
buffer += " none";
|
buffer += " none";
|
||||||
|
|
||||||
buffer += "\n";
|
buffer += "\n";
|
||||||
|
|
|
@ -1144,7 +1144,7 @@ static void FootprintWriteShape( FILE* aFile, MODULE* module, const wxString& aS
|
||||||
/* creates header: */
|
/* creates header: */
|
||||||
fprintf( aFile, "\nSHAPE \"%s\"\n", TO_UTF8( escapeString( aShapeName ) ) );
|
fprintf( aFile, "\nSHAPE \"%s\"\n", TO_UTF8( escapeString( aShapeName ) ) );
|
||||||
|
|
||||||
if( module->GetAttributes() & MOD_THROUGH_HOLE )
|
if( module->GetAttributes() & FP_THROUGH_HOLE )
|
||||||
fprintf( aFile, "INSERT TH\n" );
|
fprintf( aFile, "INSERT TH\n" );
|
||||||
else
|
else
|
||||||
fprintf( aFile, "INSERT SMD\n" );
|
fprintf( aFile, "INSERT SMD\n" );
|
||||||
|
|
|
@ -69,7 +69,7 @@ int PLACEFILE_GERBER_WRITER::CreatePlaceFile( wxString& aFullFilename, PCB_LAYER
|
||||||
|
|
||||||
for( MODULE* footprint : m_pcb->Footprints() )
|
for( MODULE* footprint : m_pcb->Footprints() )
|
||||||
{
|
{
|
||||||
if( footprint->GetAttributes() & MOD_EXCLUDE_FROM_POS_FILES )
|
if( footprint->GetAttributes() & FP_EXCLUDE_FROM_POS_FILES )
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
if( footprint->GetLayer() == aLayer )
|
if( footprint->GetLayer() == aLayer )
|
||||||
|
@ -146,9 +146,9 @@ int PLACEFILE_GERBER_WRITER::CreatePlaceFile( wxString& aFullFilename, PCB_LAYER
|
||||||
|
|
||||||
pnpAttrib.m_MountType = GBR_CMP_PNP_METADATA::MOUNT_TYPE_UNSPECIFIED;
|
pnpAttrib.m_MountType = GBR_CMP_PNP_METADATA::MOUNT_TYPE_UNSPECIFIED;
|
||||||
|
|
||||||
if( footprint->GetAttributes() & MOD_THROUGH_HOLE )
|
if( footprint->GetAttributes() & FP_THROUGH_HOLE )
|
||||||
pnpAttrib.m_MountType = GBR_CMP_PNP_METADATA::MOUNT_TYPE_TH;
|
pnpAttrib.m_MountType = GBR_CMP_PNP_METADATA::MOUNT_TYPE_TH;
|
||||||
else if( footprint->GetAttributes() & MOD_SMD )
|
else if( footprint->GetAttributes() & FP_SMD )
|
||||||
pnpAttrib.m_MountType = GBR_CMP_PNP_METADATA::MOUNT_TYPE_SMD;
|
pnpAttrib.m_MountType = GBR_CMP_PNP_METADATA::MOUNT_TYPE_SMD;
|
||||||
|
|
||||||
// Add component value info:
|
// Add component value info:
|
||||||
|
|
|
@ -765,13 +765,13 @@ void MODULE::GetMsgPanelInfo( EDA_DRAW_FRAME* aFrame, std::vector<MSG_PANEL_ITEM
|
||||||
if( m_ModuleStatus & MODULE_is_PLACED )
|
if( m_ModuleStatus & MODULE_is_PLACED )
|
||||||
addToken( &status, _( "autoplaced" ) );
|
addToken( &status, _( "autoplaced" ) );
|
||||||
|
|
||||||
if( m_Attributs & MOD_BOARD_ONLY )
|
if( m_Attributs & FP_BOARD_ONLY )
|
||||||
addToken( &attrs, _( "not in schematic" ) );
|
addToken( &attrs, _( "not in schematic" ) );
|
||||||
|
|
||||||
if( m_Attributs & MOD_EXCLUDE_FROM_POS_FILES )
|
if( m_Attributs & FP_EXCLUDE_FROM_POS_FILES )
|
||||||
addToken( &attrs, _( "exclude from pos files" ) );
|
addToken( &attrs, _( "exclude from pos files" ) );
|
||||||
|
|
||||||
if( m_Attributs & MOD_EXCLUDE_FROM_BOM )
|
if( m_Attributs & FP_EXCLUDE_FROM_BOM )
|
||||||
addToken( &attrs, _( "exclude from BOM" ) );
|
addToken( &attrs, _( "exclude from BOM" ) );
|
||||||
|
|
||||||
aList.emplace_back( _( "Status: " ) + status, _( "Attributes:" ) + wxS( " " ) + attrs, BROWN );
|
aList.emplace_back( _( "Status: " ) + status, _( "Attributes:" ) + wxS( " " ) + attrs, BROWN );
|
||||||
|
|
|
@ -58,18 +58,18 @@ enum INCLUDE_NPTH_T
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Enum MODULE_ATTR_T
|
* Enum FOOTPRINT_ATTR_T
|
||||||
* is the set of attributes allowed within a MODULE, using MODULE::SetAttributes()
|
* is the set of attributes allowed within a FOOTPRINT, using FOOTPRINT::SetAttributes()
|
||||||
* and MODULE::GetAttributes(). These are to be ORed together when calling
|
* and FOOTPRINT::GetAttributes(). These are to be ORed together when calling
|
||||||
* MODULE::SetAttributes()
|
* FOOTPRINT::SetAttributes()
|
||||||
*/
|
*/
|
||||||
enum MODULE_ATTR_T
|
enum FOOTPRINT_ATTR_T
|
||||||
{
|
{
|
||||||
MOD_THROUGH_HOLE = 0x0001,
|
FP_THROUGH_HOLE = 0x0001,
|
||||||
MOD_SMD = 0x0002,
|
FP_SMD = 0x0002,
|
||||||
MOD_EXCLUDE_FROM_POS_FILES = 0x0004,
|
FP_EXCLUDE_FROM_POS_FILES = 0x0004,
|
||||||
MOD_EXCLUDE_FROM_BOM = 0x0008,
|
FP_EXCLUDE_FROM_BOM = 0x0008,
|
||||||
MOD_BOARD_ONLY = 0x0010 // Footprint has no corresponding symbol
|
FP_BOARD_ONLY = 0x0010 // Footprint has no corresponding symbol
|
||||||
};
|
};
|
||||||
|
|
||||||
class FP_3DMODEL
|
class FP_3DMODEL
|
||||||
|
|
|
@ -122,28 +122,28 @@ void FOOTPRINT_EDIT_FRAME::SaveFootprintToBoard( wxCommandEvent& event )
|
||||||
class BASIC_FOOTPRINT_INFO : public FOOTPRINT_INFO
|
class BASIC_FOOTPRINT_INFO : public FOOTPRINT_INFO
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
BASIC_FOOTPRINT_INFO( MODULE* aModule )
|
BASIC_FOOTPRINT_INFO( MODULE* aFootprint )
|
||||||
{
|
{
|
||||||
m_nickname = aModule->GetFPID().GetLibNickname().wx_str();
|
m_nickname = aFootprint->GetFPID().GetLibNickname().wx_str();
|
||||||
m_fpname = aModule->GetFPID().GetLibItemName().wx_str();
|
m_fpname = aFootprint->GetFPID().GetLibItemName().wx_str();
|
||||||
m_pad_count = aModule->GetPadCount( DO_NOT_INCLUDE_NPTH );
|
m_pad_count = aFootprint->GetPadCount( DO_NOT_INCLUDE_NPTH );
|
||||||
m_unique_pad_count = aModule->GetUniquePadCount( DO_NOT_INCLUDE_NPTH );
|
m_unique_pad_count = aFootprint->GetUniquePadCount( DO_NOT_INCLUDE_NPTH );
|
||||||
m_keywords = aModule->GetKeywords();
|
m_keywords = aFootprint->GetKeywords();
|
||||||
m_doc = aModule->GetDescription();
|
m_doc = aFootprint->GetDescription();
|
||||||
m_loaded = true;
|
m_loaded = true;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
void FOOTPRINT_EDIT_FRAME::editFootprintProperties( MODULE* aModule )
|
void FOOTPRINT_EDIT_FRAME::editFootprintProperties( MODULE* aFootprint )
|
||||||
{
|
{
|
||||||
LIB_ID oldFPID = aModule->GetFPID();
|
LIB_ID oldFPID = aFootprint->GetFPID();
|
||||||
|
|
||||||
DIALOG_FOOTPRINT_FP_EDITOR dialog( this, aModule );
|
DIALOG_FOOTPRINT_FP_EDITOR dialog( this, aFootprint );
|
||||||
dialog.ShowModal();
|
dialog.ShowModal();
|
||||||
|
|
||||||
// Update library tree
|
// Update library tree
|
||||||
BASIC_FOOTPRINT_INFO footprintInfo( aModule );
|
BASIC_FOOTPRINT_INFO footprintInfo( aFootprint );
|
||||||
wxDataViewItem treeItem = m_adapter->FindItem( oldFPID );
|
wxDataViewItem treeItem = m_adapter->FindItem( oldFPID );
|
||||||
|
|
||||||
if( treeItem.IsOk() ) // Can be not found in tree if the current footprint is imported
|
if( treeItem.IsOk() ) // Can be not found in tree if the current footprint is imported
|
||||||
|
|
|
@ -416,7 +416,7 @@ MODULE* MICROWAVE_TOOL::createMicrowaveInductor( MICROWAVE_INDUCTOR_PATTERN& aIn
|
||||||
MODULE* footprint = editFrame.CreateNewFootprint( msg );
|
MODULE* footprint = editFrame.CreateNewFootprint( msg );
|
||||||
|
|
||||||
footprint->SetFPID( LIB_ID( wxEmptyString, wxT( "mw_inductor" ) ) );
|
footprint->SetFPID( LIB_ID( wxEmptyString, wxT( "mw_inductor" ) ) );
|
||||||
footprint->SetAttributes( MOD_EXCLUDE_FROM_POS_FILES | MOD_EXCLUDE_FROM_BOM );
|
footprint->SetAttributes( FP_EXCLUDE_FROM_POS_FILES | FP_EXCLUDE_FROM_BOM );
|
||||||
footprint->ClearFlags();
|
footprint->ClearFlags();
|
||||||
footprint->SetPosition( aInductorPattern.m_End );
|
footprint->SetPosition( aInductorPattern.m_End );
|
||||||
|
|
||||||
|
|
|
@ -310,19 +310,19 @@ bool BOARD_NETLIST_UPDATER::updateComponentParameters( MODULE* aPcbComponent,
|
||||||
}
|
}
|
||||||
|
|
||||||
if( ( aNewComponent->GetProperties().count( "exclude_from_bom" ) > 0 )
|
if( ( aNewComponent->GetProperties().count( "exclude_from_bom" ) > 0 )
|
||||||
!= ( ( aPcbComponent->GetAttributes() & MOD_EXCLUDE_FROM_BOM ) > 0 ) )
|
!= ( ( aPcbComponent->GetAttributes() & FP_EXCLUDE_FROM_BOM ) > 0 ) )
|
||||||
{
|
{
|
||||||
int attributes = aPcbComponent->GetAttributes();
|
int attributes = aPcbComponent->GetAttributes();
|
||||||
|
|
||||||
if( aNewComponent->GetProperties().count( "exclude_from_bom" ) )
|
if( aNewComponent->GetProperties().count( "exclude_from_bom" ) )
|
||||||
{
|
{
|
||||||
attributes |= MOD_EXCLUDE_FROM_BOM;
|
attributes |= FP_EXCLUDE_FROM_BOM;
|
||||||
msg.Printf( _( "Setting %s 'exclude from BOM' fabrication attribute." ),
|
msg.Printf( _( "Setting %s 'exclude from BOM' fabrication attribute." ),
|
||||||
aPcbComponent->GetReference() );
|
aPcbComponent->GetReference() );
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
attributes &= ~MOD_EXCLUDE_FROM_BOM;
|
attributes &= ~FP_EXCLUDE_FROM_BOM;
|
||||||
msg.Printf( _( "Removing %s 'exclude from BOM' fabrication attribute." ),
|
msg.Printf( _( "Removing %s 'exclude from BOM' fabrication attribute." ),
|
||||||
aPcbComponent->GetReference() );
|
aPcbComponent->GetReference() );
|
||||||
}
|
}
|
||||||
|
@ -626,7 +626,7 @@ bool BOARD_NETLIST_UPDATER::deleteUnusedComponents( NETLIST& aNetlist )
|
||||||
|
|
||||||
for( MODULE* footprint : m_board->Footprints() )
|
for( MODULE* footprint : m_board->Footprints() )
|
||||||
{
|
{
|
||||||
if(( footprint->GetAttributes() & MOD_BOARD_ONLY ) > 0 )
|
if(( footprint->GetAttributes() & FP_BOARD_ONLY ) > 0 )
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
if( m_lookupByTimestamp )
|
if( m_lookupByTimestamp )
|
||||||
|
|
|
@ -1568,10 +1568,10 @@ void PCB_EDIT_FRAME::ShowFootprintPropertiesDialog( MODULE* aFootprint )
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int PCB_EDIT_FRAME::ShowExchangeFootprintsDialog( MODULE* aModule, bool updateMode,
|
int PCB_EDIT_FRAME::ShowExchangeFootprintsDialog( MODULE* aFootprint, bool updateMode,
|
||||||
bool selectedMode )
|
bool selectedMode )
|
||||||
{
|
{
|
||||||
DIALOG_EXCHANGE_FOOTPRINTS dialog( this, aModule, updateMode, selectedMode );
|
DIALOG_EXCHANGE_FOOTPRINTS dialog( this, aFootprint, updateMode, selectedMode );
|
||||||
|
|
||||||
return dialog.ShowQuasiModal();
|
return dialog.ShowQuasiModal();
|
||||||
}
|
}
|
||||||
|
|
|
@ -736,7 +736,7 @@ public:
|
||||||
// Footprint editing (see also PCB_BASE_FRAME)
|
// Footprint editing (see also PCB_BASE_FRAME)
|
||||||
void ShowFootprintPropertiesDialog( MODULE* aFootprint );
|
void ShowFootprintPropertiesDialog( MODULE* aFootprint );
|
||||||
|
|
||||||
int ShowExchangeFootprintsDialog( MODULE* aModule, bool updateMode, bool selectedMode );
|
int ShowExchangeFootprintsDialog( MODULE* aFootprint, bool updateMode, bool selectedMode );
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Function Exchange_Module
|
* Function Exchange_Module
|
||||||
|
|
|
@ -1299,11 +1299,11 @@ void PCB_PAINTER::draw( const FP_TEXT* aText, int aLayer )
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void PCB_PAINTER::draw( const MODULE* aModule, int aLayer )
|
void PCB_PAINTER::draw( const MODULE* aFootprint, int aLayer )
|
||||||
{
|
{
|
||||||
if( aLayer == LAYER_ANCHOR )
|
if( aLayer == LAYER_ANCHOR )
|
||||||
{
|
{
|
||||||
const COLOR4D color = m_pcbSettings.GetColor( aModule, aLayer );
|
const COLOR4D color = m_pcbSettings.GetColor( aFootprint, aLayer );
|
||||||
|
|
||||||
// Keep the size and width constant, not related to the scale because the anchor
|
// Keep the size and width constant, not related to the scale because the anchor
|
||||||
// is just a marker on screen
|
// is just a marker on screen
|
||||||
|
@ -1316,14 +1316,14 @@ void PCB_PAINTER::draw( const MODULE* aModule, int aLayer )
|
||||||
m_gal->SetStrokeColor( color );
|
m_gal->SetStrokeColor( color );
|
||||||
m_gal->SetLineWidth( anchorThickness );
|
m_gal->SetLineWidth( anchorThickness );
|
||||||
|
|
||||||
VECTOR2D center = aModule->GetPosition();
|
VECTOR2D center = aFootprint->GetPosition();
|
||||||
m_gal->DrawLine( center - VECTOR2D( anchorSize, 0 ), center + VECTOR2D( anchorSize, 0 ) );
|
m_gal->DrawLine( center - VECTOR2D( anchorSize, 0 ), center + VECTOR2D( anchorSize, 0 ) );
|
||||||
m_gal->DrawLine( center - VECTOR2D( 0, anchorSize ), center + VECTOR2D( 0, anchorSize ) );
|
m_gal->DrawLine( center - VECTOR2D( 0, anchorSize ), center + VECTOR2D( 0, anchorSize ) );
|
||||||
|
|
||||||
#if 0 // For debug purpose only: draw the footing bounding box
|
#if 0 // For debug purpose only: draw the footing bounding box
|
||||||
double bboxThickness = 1.0 / m_gal->GetWorldScale();
|
double bboxThickness = 1.0 / m_gal->GetWorldScale();
|
||||||
m_gal->SetLineWidth( bboxThickness );
|
m_gal->SetLineWidth( bboxThickness );
|
||||||
EDA_RECT rect = aModule->GetBoundingBoxBase();
|
EDA_RECT rect = aFootprint->GetBoundingBoxBase();
|
||||||
m_gal->DrawRectangle( VECTOR2D( rect.GetOrigin() ), VECTOR2D( rect.GetEnd() ) );
|
m_gal->DrawRectangle( VECTOR2D( rect.GetOrigin() ), VECTOR2D( rect.GetEnd() ) );
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
|
@ -288,7 +288,7 @@ protected:
|
||||||
void draw( const PCB_SHAPE* aSegment, int aLayer );
|
void draw( const PCB_SHAPE* aSegment, int aLayer );
|
||||||
void draw( const PCB_TEXT* aText, int aLayer );
|
void draw( const PCB_TEXT* aText, int aLayer );
|
||||||
void draw( const FP_TEXT* aText, int aLayer );
|
void draw( const FP_TEXT* aText, int aLayer );
|
||||||
void draw( const MODULE* aModule, int aLayer );
|
void draw( const MODULE* aFootprint, int aLayer );
|
||||||
void draw( const PCB_GROUP* aGroup, int aLayer );
|
void draw( const PCB_GROUP* aGroup, int aLayer );
|
||||||
void draw( const ZONE* aZone, int aLayer );
|
void draw( const ZONE* aZone, int aLayer );
|
||||||
void draw( const DIMENSION_BASE* aDimension, int aLayer );
|
void draw( const DIMENSION_BASE* aDimension, int aLayer );
|
||||||
|
|
|
@ -61,19 +61,19 @@ using namespace PCB_KEYS_T;
|
||||||
class FP_CACHE_ITEM
|
class FP_CACHE_ITEM
|
||||||
{
|
{
|
||||||
WX_FILENAME m_filename;
|
WX_FILENAME m_filename;
|
||||||
std::unique_ptr<MODULE> m_module;
|
std::unique_ptr<MODULE> m_footprint;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
FP_CACHE_ITEM( MODULE* aModule, const WX_FILENAME& aFileName );
|
FP_CACHE_ITEM( MODULE* aFootprint, const WX_FILENAME& aFileName );
|
||||||
|
|
||||||
const WX_FILENAME& GetFileName() const { return m_filename; }
|
const WX_FILENAME& GetFileName() const { return m_filename; }
|
||||||
const MODULE* GetModule() const { return m_module.get(); }
|
const MODULE* GetModule() const { return m_footprint.get(); }
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
FP_CACHE_ITEM::FP_CACHE_ITEM( MODULE* aModule, const WX_FILENAME& aFileName ) :
|
FP_CACHE_ITEM::FP_CACHE_ITEM( MODULE* aFootprint, const WX_FILENAME& aFileName ) :
|
||||||
m_filename( aFileName ),
|
m_filename( aFileName ),
|
||||||
m_module( aModule )
|
m_footprint( aFootprint )
|
||||||
{ }
|
{ }
|
||||||
|
|
||||||
|
|
||||||
|
@ -109,9 +109,9 @@ public:
|
||||||
/**
|
/**
|
||||||
* Save the footprint cache or a single module from it to disk
|
* Save the footprint cache or a single module from it to disk
|
||||||
*
|
*
|
||||||
* @param aModule if set, save only this module, otherwise, save the full library
|
* @param aFootprint if set, save only this module, otherwise, save the full library
|
||||||
*/
|
*/
|
||||||
void Save( MODULE* aModule = NULL );
|
void Save( MODULE* aFootprint = NULL );
|
||||||
|
|
||||||
void Load();
|
void Load();
|
||||||
|
|
||||||
|
@ -154,7 +154,7 @@ FP_CACHE::FP_CACHE( PCB_IO* aOwner, const wxString& aLibraryPath )
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void FP_CACHE::Save( MODULE* aModule )
|
void FP_CACHE::Save( MODULE* aFootprint )
|
||||||
{
|
{
|
||||||
m_cache_timestamp = 0;
|
m_cache_timestamp = 0;
|
||||||
|
|
||||||
|
@ -172,7 +172,7 @@ void FP_CACHE::Save( MODULE* aModule )
|
||||||
|
|
||||||
for( MODULE_ITER it = m_modules.begin(); it != m_modules.end(); ++it )
|
for( MODULE_ITER it = m_modules.begin(); it != m_modules.end(); ++it )
|
||||||
{
|
{
|
||||||
if( aModule && aModule != it->second->GetModule() )
|
if( aFootprint && aFootprint != it->second->GetModule() )
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
WX_FILENAME fn = it->second->GetFileName();
|
WX_FILENAME fn = it->second->GetFileName();
|
||||||
|
@ -216,7 +216,7 @@ void FP_CACHE::Save( MODULE* aModule )
|
||||||
m_cache_timestamp += m_lib_path.GetModificationTime().GetValue().GetValue();
|
m_cache_timestamp += m_lib_path.GetModificationTime().GetValue().GetValue();
|
||||||
|
|
||||||
// If we've saved the full cache, we clear the dirty flag.
|
// If we've saved the full cache, we clear the dirty flag.
|
||||||
if( !aModule )
|
if( !aFootprint )
|
||||||
m_cache_dirty = false;
|
m_cache_dirty = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -846,39 +846,39 @@ void PCB_IO::format( PCB_SHAPE* aShape, int aNestLevel ) const
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void PCB_IO::format( FP_SHAPE* aModuleDrawing, int aNestLevel ) const
|
void PCB_IO::format( FP_SHAPE* aFPShape, int aNestLevel ) const
|
||||||
{
|
{
|
||||||
switch( aModuleDrawing->GetShape() )
|
switch( aFPShape->GetShape() )
|
||||||
{
|
{
|
||||||
case S_SEGMENT: // Line
|
case S_SEGMENT: // Line
|
||||||
m_out->Print( aNestLevel, "(fp_line (start %s) (end %s)",
|
m_out->Print( aNestLevel, "(fp_line (start %s) (end %s)",
|
||||||
FormatInternalUnits( aModuleDrawing->GetStart0() ).c_str(),
|
FormatInternalUnits( aFPShape->GetStart0() ).c_str(),
|
||||||
FormatInternalUnits( aModuleDrawing->GetEnd0() ).c_str() );
|
FormatInternalUnits( aFPShape->GetEnd0() ).c_str() );
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case S_RECT: // Rectangle
|
case S_RECT: // Rectangle
|
||||||
m_out->Print( aNestLevel, "(fp_rect (start %s) (end %s)",
|
m_out->Print( aNestLevel, "(fp_rect (start %s) (end %s)",
|
||||||
FormatInternalUnits( aModuleDrawing->GetStart0() ).c_str(),
|
FormatInternalUnits( aFPShape->GetStart0() ).c_str(),
|
||||||
FormatInternalUnits( aModuleDrawing->GetEnd0() ).c_str() );
|
FormatInternalUnits( aFPShape->GetEnd0() ).c_str() );
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case S_CIRCLE: // Circle
|
case S_CIRCLE: // Circle
|
||||||
m_out->Print( aNestLevel, "(fp_circle (center %s) (end %s)",
|
m_out->Print( aNestLevel, "(fp_circle (center %s) (end %s)",
|
||||||
FormatInternalUnits( aModuleDrawing->GetStart0() ).c_str(),
|
FormatInternalUnits( aFPShape->GetStart0() ).c_str(),
|
||||||
FormatInternalUnits( aModuleDrawing->GetEnd0() ).c_str() );
|
FormatInternalUnits( aFPShape->GetEnd0() ).c_str() );
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case S_ARC: // Arc
|
case S_ARC: // Arc
|
||||||
m_out->Print( aNestLevel, "(fp_arc (start %s) (end %s) (angle %s)",
|
m_out->Print( aNestLevel, "(fp_arc (start %s) (end %s) (angle %s)",
|
||||||
FormatInternalUnits( aModuleDrawing->GetStart0() ).c_str(),
|
FormatInternalUnits( aFPShape->GetStart0() ).c_str(),
|
||||||
FormatInternalUnits( aModuleDrawing->GetEnd0() ).c_str(),
|
FormatInternalUnits( aFPShape->GetEnd0() ).c_str(),
|
||||||
FormatAngle( aModuleDrawing->GetAngle() ).c_str() );
|
FormatAngle( aFPShape->GetAngle() ).c_str() );
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case S_POLYGON: // Polygonal segment
|
case S_POLYGON: // Polygonal segment
|
||||||
if( aModuleDrawing->IsPolyShapeValid() )
|
if( aFPShape->IsPolyShapeValid() )
|
||||||
{
|
{
|
||||||
SHAPE_POLY_SET& poly = aModuleDrawing->GetPolyShape();
|
SHAPE_POLY_SET& poly = aFPShape->GetPolyShape();
|
||||||
SHAPE_LINE_CHAIN& outline = poly.Outline( 0 );
|
SHAPE_LINE_CHAIN& outline = poly.Outline( 0 );
|
||||||
int pointsCount = outline.PointCount();
|
int pointsCount = outline.PointCount();
|
||||||
|
|
||||||
|
@ -909,23 +909,23 @@ void PCB_IO::format( FP_SHAPE* aModuleDrawing, int aNestLevel ) const
|
||||||
|
|
||||||
case S_CURVE: // Bezier curve
|
case S_CURVE: // Bezier curve
|
||||||
m_out->Print( aNestLevel, "(fp_curve (pts (xy %s) (xy %s) (xy %s) (xy %s))",
|
m_out->Print( aNestLevel, "(fp_curve (pts (xy %s) (xy %s) (xy %s) (xy %s))",
|
||||||
FormatInternalUnits( aModuleDrawing->GetStart0() ).c_str(),
|
FormatInternalUnits( aFPShape->GetStart0() ).c_str(),
|
||||||
FormatInternalUnits( aModuleDrawing->GetBezier0_C1() ).c_str(),
|
FormatInternalUnits( aFPShape->GetBezier0_C1() ).c_str(),
|
||||||
FormatInternalUnits( aModuleDrawing->GetBezier0_C2() ).c_str(),
|
FormatInternalUnits( aFPShape->GetBezier0_C2() ).c_str(),
|
||||||
FormatInternalUnits( aModuleDrawing->GetEnd0() ).c_str() );
|
FormatInternalUnits( aFPShape->GetEnd0() ).c_str() );
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
wxFAIL_MSG( "PCB_IO::format cannot format unknown FP_SHAPE shape:"
|
wxFAIL_MSG( "PCB_IO::format cannot format unknown FP_SHAPE shape:"
|
||||||
+ PCB_SHAPE_TYPE_T_asString( aModuleDrawing->GetShape() ) );
|
+ PCB_SHAPE_TYPE_T_asString( aFPShape->GetShape() ) );
|
||||||
return;
|
return;
|
||||||
};
|
};
|
||||||
|
|
||||||
formatLayer( aModuleDrawing );
|
formatLayer( aFPShape );
|
||||||
|
|
||||||
m_out->Print( 0, " (width %s)", FormatInternalUnits( aModuleDrawing->GetWidth() ).c_str() );
|
m_out->Print( 0, " (width %s)", FormatInternalUnits( aFPShape->GetWidth() ).c_str() );
|
||||||
|
|
||||||
m_out->Print( 0, " (tstamp %s)", TO_UTF8( aModuleDrawing->m_Uuid.AsString() ) );
|
m_out->Print( 0, " (tstamp %s)", TO_UTF8( aFPShape->m_Uuid.AsString() ) );
|
||||||
|
|
||||||
m_out->Print( 0, ")\n" );
|
m_out->Print( 0, ")\n" );
|
||||||
}
|
}
|
||||||
|
@ -949,11 +949,11 @@ void PCB_IO::format( PCB_TARGET* aTarget, int aNestLevel ) const
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void PCB_IO::format( MODULE* aModule, int aNestLevel ) const
|
void PCB_IO::format( MODULE* aFootprint, int aNestLevel ) const
|
||||||
{
|
{
|
||||||
if( !( m_ctl & CTL_OMIT_INITIAL_COMMENTS ) )
|
if( !( m_ctl & CTL_OMIT_INITIAL_COMMENTS ) )
|
||||||
{
|
{
|
||||||
const wxArrayString* initial_comments = aModule->GetInitialComments();
|
const wxArrayString* initial_comments = aFootprint->GetInitialComments();
|
||||||
|
|
||||||
if( initial_comments )
|
if( initial_comments )
|
||||||
{
|
{
|
||||||
|
@ -966,45 +966,45 @@ void PCB_IO::format( MODULE* aModule, int aNestLevel ) const
|
||||||
|
|
||||||
if( m_ctl & CTL_OMIT_LIBNAME )
|
if( m_ctl & CTL_OMIT_LIBNAME )
|
||||||
m_out->Print( aNestLevel, "(module %s",
|
m_out->Print( aNestLevel, "(module %s",
|
||||||
m_out->Quotes( aModule->GetFPID().GetLibItemNameAndRev() ).c_str() );
|
m_out->Quotes( aFootprint->GetFPID().GetLibItemNameAndRev() ).c_str() );
|
||||||
else
|
else
|
||||||
m_out->Print( aNestLevel, "(module %s",
|
m_out->Print( aNestLevel, "(module %s",
|
||||||
m_out->Quotes( aModule->GetFPID().Format() ).c_str() );
|
m_out->Quotes( aFootprint->GetFPID().Format() ).c_str() );
|
||||||
|
|
||||||
if( aModule->IsLocked() )
|
if( aFootprint->IsLocked() )
|
||||||
m_out->Print( 0, " locked" );
|
m_out->Print( 0, " locked" );
|
||||||
|
|
||||||
if( aModule->IsPlaced() )
|
if( aFootprint->IsPlaced() )
|
||||||
m_out->Print( 0, " placed" );
|
m_out->Print( 0, " placed" );
|
||||||
|
|
||||||
formatLayer( aModule );
|
formatLayer( aFootprint );
|
||||||
|
|
||||||
m_out->Print( 0, " (tedit %lX)", (unsigned long)aModule->GetLastEditTime() );
|
m_out->Print( 0, " (tedit %lX)", (unsigned long)aFootprint->GetLastEditTime() );
|
||||||
|
|
||||||
if( !( m_ctl & CTL_OMIT_TSTAMPS ) )
|
if( !( m_ctl & CTL_OMIT_TSTAMPS ) )
|
||||||
m_out->Print( 0, " (tstamp %s)", TO_UTF8( aModule->m_Uuid.AsString() ) );
|
m_out->Print( 0, " (tstamp %s)", TO_UTF8( aFootprint->m_Uuid.AsString() ) );
|
||||||
|
|
||||||
m_out->Print( 0, "\n" );
|
m_out->Print( 0, "\n" );
|
||||||
|
|
||||||
if( !( m_ctl & CTL_OMIT_AT ) )
|
if( !( m_ctl & CTL_OMIT_AT ) )
|
||||||
{
|
{
|
||||||
m_out->Print( aNestLevel+1, "(at %s", FormatInternalUnits( aModule->GetPosition() ).c_str() );
|
m_out->Print( aNestLevel+1, "(at %s", FormatInternalUnits( aFootprint->GetPosition() ).c_str() );
|
||||||
|
|
||||||
if( aModule->GetOrientation() != 0.0 )
|
if( aFootprint->GetOrientation() != 0.0 )
|
||||||
m_out->Print( 0, " %s", FormatAngle( aModule->GetOrientation() ).c_str() );
|
m_out->Print( 0, " %s", FormatAngle( aFootprint->GetOrientation() ).c_str() );
|
||||||
|
|
||||||
m_out->Print( 0, ")\n" );
|
m_out->Print( 0, ")\n" );
|
||||||
}
|
}
|
||||||
|
|
||||||
if( !aModule->GetDescription().IsEmpty() )
|
if( !aFootprint->GetDescription().IsEmpty() )
|
||||||
m_out->Print( aNestLevel+1, "(descr %s)\n",
|
m_out->Print( aNestLevel+1, "(descr %s)\n",
|
||||||
m_out->Quotew( aModule->GetDescription() ).c_str() );
|
m_out->Quotew( aFootprint->GetDescription() ).c_str() );
|
||||||
|
|
||||||
if( !aModule->GetKeywords().IsEmpty() )
|
if( !aFootprint->GetKeywords().IsEmpty() )
|
||||||
m_out->Print( aNestLevel+1, "(tags %s)\n",
|
m_out->Print( aNestLevel+1, "(tags %s)\n",
|
||||||
m_out->Quotew( aModule->GetKeywords() ).c_str() );
|
m_out->Quotew( aFootprint->GetKeywords() ).c_str() );
|
||||||
|
|
||||||
const std::map<wxString, wxString>& props = aModule->GetProperties();
|
const std::map<wxString, wxString>& props = aFootprint->GetProperties();
|
||||||
|
|
||||||
for( const std::pair<const wxString, wxString>& prop : props )
|
for( const std::pair<const wxString, wxString>& prop : props )
|
||||||
{
|
{
|
||||||
|
@ -1013,78 +1013,78 @@ void PCB_IO::format( MODULE* aModule, int aNestLevel ) const
|
||||||
m_out->Quotew( prop.second ).c_str() );
|
m_out->Quotew( prop.second ).c_str() );
|
||||||
}
|
}
|
||||||
|
|
||||||
if( !( m_ctl & CTL_OMIT_PATH ) && !aModule->GetPath().empty() )
|
if( !( m_ctl & CTL_OMIT_PATH ) && !aFootprint->GetPath().empty() )
|
||||||
m_out->Print( aNestLevel+1, "(path %s)\n",
|
m_out->Print( aNestLevel+1, "(path %s)\n",
|
||||||
m_out->Quotew( aModule->GetPath().AsString() ).c_str() );
|
m_out->Quotew( aFootprint->GetPath().AsString() ).c_str() );
|
||||||
|
|
||||||
if( aModule->GetPlacementCost90() != 0 )
|
if( aFootprint->GetPlacementCost90() != 0 )
|
||||||
m_out->Print( aNestLevel+1, "(autoplace_cost90 %d)\n", aModule->GetPlacementCost90() );
|
m_out->Print( aNestLevel+1, "(autoplace_cost90 %d)\n", aFootprint->GetPlacementCost90() );
|
||||||
|
|
||||||
if( aModule->GetPlacementCost180() != 0 )
|
if( aFootprint->GetPlacementCost180() != 0 )
|
||||||
m_out->Print( aNestLevel+1, "(autoplace_cost180 %d)\n", aModule->GetPlacementCost180() );
|
m_out->Print( aNestLevel+1, "(autoplace_cost180 %d)\n", aFootprint->GetPlacementCost180() );
|
||||||
|
|
||||||
if( aModule->GetLocalSolderMaskMargin() != 0 )
|
if( aFootprint->GetLocalSolderMaskMargin() != 0 )
|
||||||
m_out->Print( aNestLevel+1, "(solder_mask_margin %s)\n",
|
m_out->Print( aNestLevel+1, "(solder_mask_margin %s)\n",
|
||||||
FormatInternalUnits( aModule->GetLocalSolderMaskMargin() ).c_str() );
|
FormatInternalUnits( aFootprint->GetLocalSolderMaskMargin() ).c_str() );
|
||||||
|
|
||||||
if( aModule->GetLocalSolderPasteMargin() != 0 )
|
if( aFootprint->GetLocalSolderPasteMargin() != 0 )
|
||||||
m_out->Print( aNestLevel+1, "(solder_paste_margin %s)\n",
|
m_out->Print( aNestLevel+1, "(solder_paste_margin %s)\n",
|
||||||
FormatInternalUnits( aModule->GetLocalSolderPasteMargin() ).c_str() );
|
FormatInternalUnits( aFootprint->GetLocalSolderPasteMargin() ).c_str() );
|
||||||
|
|
||||||
if( aModule->GetLocalSolderPasteMarginRatio() != 0 )
|
if( aFootprint->GetLocalSolderPasteMarginRatio() != 0 )
|
||||||
m_out->Print( aNestLevel+1, "(solder_paste_ratio %s)\n",
|
m_out->Print( aNestLevel+1, "(solder_paste_ratio %s)\n",
|
||||||
Double2Str( aModule->GetLocalSolderPasteMarginRatio() ).c_str() );
|
Double2Str( aFootprint->GetLocalSolderPasteMarginRatio() ).c_str() );
|
||||||
|
|
||||||
if( aModule->GetLocalClearance() != 0 )
|
if( aFootprint->GetLocalClearance() != 0 )
|
||||||
m_out->Print( aNestLevel+1, "(clearance %s)\n",
|
m_out->Print( aNestLevel+1, "(clearance %s)\n",
|
||||||
FormatInternalUnits( aModule->GetLocalClearance() ).c_str() );
|
FormatInternalUnits( aFootprint->GetLocalClearance() ).c_str() );
|
||||||
|
|
||||||
if( aModule->GetZoneConnection() != ZONE_CONNECTION::INHERITED )
|
if( aFootprint->GetZoneConnection() != ZONE_CONNECTION::INHERITED )
|
||||||
m_out->Print( aNestLevel+1, "(zone_connect %d)\n",
|
m_out->Print( aNestLevel+1, "(zone_connect %d)\n",
|
||||||
static_cast<int>( aModule->GetZoneConnection() ) );
|
static_cast<int>( aFootprint->GetZoneConnection() ) );
|
||||||
|
|
||||||
if( aModule->GetThermalWidth() != 0 )
|
if( aFootprint->GetThermalWidth() != 0 )
|
||||||
m_out->Print( aNestLevel+1, "(thermal_width %s)\n",
|
m_out->Print( aNestLevel+1, "(thermal_width %s)\n",
|
||||||
FormatInternalUnits( aModule->GetThermalWidth() ).c_str() );
|
FormatInternalUnits( aFootprint->GetThermalWidth() ).c_str() );
|
||||||
|
|
||||||
if( aModule->GetThermalGap() != 0 )
|
if( aFootprint->GetThermalGap() != 0 )
|
||||||
m_out->Print( aNestLevel+1, "(thermal_gap %s)\n",
|
m_out->Print( aNestLevel+1, "(thermal_gap %s)\n",
|
||||||
FormatInternalUnits( aModule->GetThermalGap() ).c_str() );
|
FormatInternalUnits( aFootprint->GetThermalGap() ).c_str() );
|
||||||
|
|
||||||
// Attributes
|
// Attributes
|
||||||
if( aModule->GetAttributes() )
|
if( aFootprint->GetAttributes() )
|
||||||
{
|
{
|
||||||
m_out->Print( aNestLevel+1, "(attr" );
|
m_out->Print( aNestLevel+1, "(attr" );
|
||||||
|
|
||||||
if( aModule->GetAttributes() & MOD_SMD )
|
if( aFootprint->GetAttributes() & FP_SMD )
|
||||||
m_out->Print( 0, " smd" );
|
m_out->Print( 0, " smd" );
|
||||||
|
|
||||||
if( aModule->GetAttributes() & MOD_THROUGH_HOLE )
|
if( aFootprint->GetAttributes() & FP_THROUGH_HOLE )
|
||||||
m_out->Print( 0, " through_hole" );
|
m_out->Print( 0, " through_hole" );
|
||||||
|
|
||||||
if( aModule->GetAttributes() & MOD_BOARD_ONLY )
|
if( aFootprint->GetAttributes() & FP_BOARD_ONLY )
|
||||||
m_out->Print( 0, " board_only" );
|
m_out->Print( 0, " board_only" );
|
||||||
|
|
||||||
if( aModule->GetAttributes() & MOD_EXCLUDE_FROM_POS_FILES )
|
if( aFootprint->GetAttributes() & FP_EXCLUDE_FROM_POS_FILES )
|
||||||
m_out->Print( 0, " exclude_from_pos_files" );
|
m_out->Print( 0, " exclude_from_pos_files" );
|
||||||
|
|
||||||
if( aModule->GetAttributes() & MOD_EXCLUDE_FROM_BOM )
|
if( aFootprint->GetAttributes() & FP_EXCLUDE_FROM_BOM )
|
||||||
m_out->Print( 0, " exclude_from_bom" );
|
m_out->Print( 0, " exclude_from_bom" );
|
||||||
|
|
||||||
m_out->Print( 0, ")\n" );
|
m_out->Print( 0, ")\n" );
|
||||||
}
|
}
|
||||||
|
|
||||||
Format( (BOARD_ITEM*) &aModule->Reference(), aNestLevel+1 );
|
Format((BOARD_ITEM*) &aFootprint->Reference(), aNestLevel + 1 );
|
||||||
Format( (BOARD_ITEM*) &aModule->Value(), aNestLevel+1 );
|
Format((BOARD_ITEM*) &aFootprint->Value(), aNestLevel + 1 );
|
||||||
|
|
||||||
std::set<PAD*, MODULE::cmp_pads> sorted_pads( aModule->Pads().begin(),
|
std::set<PAD*, MODULE::cmp_pads> sorted_pads( aFootprint->Pads().begin(),
|
||||||
aModule->Pads().end() );
|
aFootprint->Pads().end() );
|
||||||
std::set<BOARD_ITEM*, MODULE::cmp_drawings> sorted_drawings( aModule->GraphicalItems().begin(),
|
std::set<BOARD_ITEM*, MODULE::cmp_drawings> sorted_drawings( aFootprint->GraphicalItems().begin(),
|
||||||
aModule->GraphicalItems().end() );
|
aFootprint->GraphicalItems().end() );
|
||||||
std::set<BOARD_ITEM*, BOARD_ITEM::ptr_cmp> sorted_zones( aModule->Zones().begin(),
|
std::set<BOARD_ITEM*, BOARD_ITEM::ptr_cmp> sorted_zones( aFootprint->Zones().begin(),
|
||||||
aModule->Zones().end() );
|
aFootprint->Zones().end() );
|
||||||
std::set<BOARD_ITEM*, PCB_GROUP::ptr_cmp> sorted_groups( aModule->Groups().begin(),
|
std::set<BOARD_ITEM*, PCB_GROUP::ptr_cmp> sorted_groups( aFootprint->Groups().begin(),
|
||||||
aModule->Groups().end() );
|
aFootprint->Groups().end() );
|
||||||
|
|
||||||
// Save drawing elements.
|
// Save drawing elements.
|
||||||
|
|
||||||
|
@ -1104,8 +1104,8 @@ void PCB_IO::format( MODULE* aModule, int aNestLevel ) const
|
||||||
Format( group, aNestLevel + 1 );
|
Format( group, aNestLevel + 1 );
|
||||||
|
|
||||||
// Save 3D info.
|
// Save 3D info.
|
||||||
auto bs3D = aModule->Models().begin();
|
auto bs3D = aFootprint->Models().begin();
|
||||||
auto es3D = aModule->Models().end();
|
auto es3D = aFootprint->Models().end();
|
||||||
|
|
||||||
while( bs3D != es3D )
|
while( bs3D != es3D )
|
||||||
{
|
{
|
||||||
|
|
|
@ -260,7 +260,7 @@ private:
|
||||||
|
|
||||||
void format( DIMENSION_BASE* aDimension, int aNestLevel = 0 ) const;
|
void format( DIMENSION_BASE* aDimension, int aNestLevel = 0 ) const;
|
||||||
|
|
||||||
void format( FP_SHAPE* aModuleDrawing, int aNestLevel = 0 ) const;
|
void format( FP_SHAPE* aFPShape, int aNestLevel = 0 ) const;
|
||||||
|
|
||||||
void format( PCB_GROUP* aGroup, int aNestLevel = 0 ) const;
|
void format( PCB_GROUP* aGroup, int aNestLevel = 0 ) const;
|
||||||
|
|
||||||
|
@ -268,7 +268,7 @@ private:
|
||||||
|
|
||||||
void format( PCB_TARGET* aTarget, int aNestLevel = 0 ) const;
|
void format( PCB_TARGET* aTarget, int aNestLevel = 0 ) const;
|
||||||
|
|
||||||
void format( MODULE* aModule, int aNestLevel = 0 ) const;
|
void format( MODULE* aFootprint, int aNestLevel = 0 ) const;
|
||||||
|
|
||||||
void format( PAD* aPad, int aNestLevel = 0 ) const;
|
void format( PAD* aPad, int aNestLevel = 0 ) const;
|
||||||
|
|
||||||
|
|
|
@ -2951,27 +2951,27 @@ MODULE* PCB_PARSER::parseMODULE_unchecked( wxArrayString* aInitialComments )
|
||||||
switch( token )
|
switch( token )
|
||||||
{
|
{
|
||||||
case T_virtual: // legacy token prior to version 20200826
|
case T_virtual: // legacy token prior to version 20200826
|
||||||
attributes |= MOD_EXCLUDE_FROM_POS_FILES | MOD_EXCLUDE_FROM_BOM;
|
attributes |= FP_EXCLUDE_FROM_POS_FILES | FP_EXCLUDE_FROM_BOM;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case T_through_hole:
|
case T_through_hole:
|
||||||
attributes |= MOD_THROUGH_HOLE;
|
attributes |= FP_THROUGH_HOLE;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case T_smd:
|
case T_smd:
|
||||||
attributes |= MOD_SMD;
|
attributes |= FP_SMD;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case T_board_only:
|
case T_board_only:
|
||||||
attributes |= MOD_BOARD_ONLY;
|
attributes |= FP_BOARD_ONLY;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case T_exclude_from_pos_files:
|
case T_exclude_from_pos_files:
|
||||||
attributes |= MOD_EXCLUDE_FROM_POS_FILES;
|
attributes |= FP_EXCLUDE_FROM_POS_FILES;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case T_exclude_from_bom:
|
case T_exclude_from_bom:
|
||||||
attributes |= MOD_EXCLUDE_FROM_BOM;
|
attributes |= FP_EXCLUDE_FROM_BOM;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
|
@ -3082,7 +3082,7 @@ MODULE* PCB_PARSER::parseMODULE_unchecked( wxArrayString* aInitialComments )
|
||||||
// files. We probably don't want to get into that game so we'll just include them by
|
// files. We probably don't want to get into that game so we'll just include them by
|
||||||
// default and let the user change it if required.
|
// default and let the user change it if required.
|
||||||
if( m_requiredVersion < 20200826 && attributes == 0 )
|
if( m_requiredVersion < 20200826 && attributes == 0 )
|
||||||
attributes |= MOD_THROUGH_HOLE;
|
attributes |= FP_THROUGH_HOLE;
|
||||||
|
|
||||||
module->SetAttributes( attributes );
|
module->SetAttributes( attributes );
|
||||||
|
|
||||||
|
|
|
@ -1297,11 +1297,11 @@ void LEGACY_PLUGIN::loadFOOTPRINT( MODULE* aFootprint )
|
||||||
data = line + SZ( "At" );
|
data = line + SZ( "At" );
|
||||||
|
|
||||||
if( strstr( data, "SMD" ) )
|
if( strstr( data, "SMD" ) )
|
||||||
attrs |= MOD_SMD;
|
attrs |= FP_SMD;
|
||||||
else if( strstr( data, "VIRTUAL" ) )
|
else if( strstr( data, "VIRTUAL" ) )
|
||||||
attrs |= MOD_EXCLUDE_FROM_POS_FILES | MOD_EXCLUDE_FROM_BOM;
|
attrs |= FP_EXCLUDE_FROM_POS_FILES | FP_EXCLUDE_FROM_BOM;
|
||||||
else
|
else
|
||||||
attrs |= MOD_THROUGH_HOLE | MOD_EXCLUDE_FROM_POS_FILES;
|
attrs |= FP_THROUGH_HOLE | FP_EXCLUDE_FROM_POS_FILES;
|
||||||
|
|
||||||
aFootprint->SetAttributes( attrs );
|
aFootprint->SetAttributes( attrs );
|
||||||
}
|
}
|
||||||
|
@ -3017,10 +3017,10 @@ void LEGACY_PLUGIN::init( const PROPERTIES* aProperties )
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void LEGACY_PLUGIN::SaveModule3D( const MODULE* me ) const
|
void LEGACY_PLUGIN::SaveFP3DModels( const MODULE* aFootprint ) const
|
||||||
{
|
{
|
||||||
auto sM = me->Models().begin();
|
auto sM = aFootprint->Models().begin();
|
||||||
auto eM = me->Models().end();
|
auto eM = aFootprint->Models().end();
|
||||||
|
|
||||||
while( sM != eM )
|
while( sM != eM )
|
||||||
{
|
{
|
||||||
|
|
|
@ -102,7 +102,7 @@ public:
|
||||||
void SetReader( LINE_READER* aReader ) { m_reader = aReader; }
|
void SetReader( LINE_READER* aReader ) { m_reader = aReader; }
|
||||||
void SetFilePtr( FILE* aFile ) { m_fp = aFile; }
|
void SetFilePtr( FILE* aFile ) { m_fp = aFile; }
|
||||||
|
|
||||||
void SaveModule3D( const MODULE* aModule ) const;
|
void SaveFP3DModels( const MODULE* aFootprint ) const;
|
||||||
|
|
||||||
// return the new .kicad_pcb layer id from the old (legacy) layer id
|
// return the new .kicad_pcb layer id from the old (legacy) layer id
|
||||||
static PCB_LAYER_ID leg_layer2new( int cu_count, LAYER_NUM aLayerNum );
|
static PCB_LAYER_ID leg_layer2new( int cu_count, LAYER_NUM aLayerNum );
|
||||||
|
|
Loading…
Reference in New Issue