IPC-2581: Make sure non-physical layers aren't exported

This commit is contained in:
Jon Evans 2023-12-06 16:53:32 -05:00
parent 921291c28b
commit 2674a2a294
2 changed files with 12 additions and 1 deletions

View File

@ -1295,6 +1295,12 @@ void IPC2581_PLUGIN::addCadHeader( wxXmlNode* aEcadNode )
} }
bool IPC2581_PLUGIN::isValidLayerFor2581( PCB_LAYER_ID aLayer )
{
return ( aLayer >= F_Cu && aLayer <= User_9 ) || aLayer == UNDEFINED_LAYER;
}
void IPC2581_PLUGIN::addLayerAttributes( wxXmlNode* aNode, PCB_LAYER_ID aLayer ) void IPC2581_PLUGIN::addLayerAttributes( wxXmlNode* aNode, PCB_LAYER_ID aLayer )
{ {
switch( aLayer ) switch( aLayer )
@ -1389,6 +1395,9 @@ void IPC2581_PLUGIN::generateCadLayers( wxXmlNode* aCadLayerNode )
{ {
BOARD_STACKUP_ITEM* stackup_item = layers.at( i ); BOARD_STACKUP_ITEM* stackup_item = layers.at( i );
if( !isValidLayerFor2581( stackup_item->GetBrdLayerId() ) )
continue;
for( int sublayer_id = 0; sublayer_id < stackup_item->GetSublayersCount(); sublayer_id++ ) for( int sublayer_id = 0; sublayer_id < stackup_item->GetSublayersCount(); sublayer_id++ )
{ {
wxXmlNode* cadLayerNode = appendNode( aCadLayerNode, "Layer" ); wxXmlNode* cadLayerNode = appendNode( aCadLayerNode, "Layer" );
@ -1432,7 +1441,7 @@ void IPC2581_PLUGIN::generateCadLayers( wxXmlNode* aCadLayerNode )
for( PCB_LAYER_ID layer : layer_seq ) for( PCB_LAYER_ID layer : layer_seq )
{ {
if( added_layers.find( layer ) != added_layers.end() ) if( added_layers.find( layer ) != added_layers.end() || !isValidLayerFor2581( layer ) )
continue; continue;
wxString ly_name = genString( m_board->GetLayerName( layer ), "LAYER" ); wxString ly_name = genString( m_board->GetLayerName( layer ), "LAYER" );

View File

@ -276,6 +276,8 @@ private:
void insertNodeAfter( wxXmlNode* aPrev, wxXmlNode* aNode ); void insertNodeAfter( wxXmlNode* aPrev, wxXmlNode* aNode );
void addLayerAttributes( wxXmlNode* aNode, PCB_LAYER_ID aLayer ); void addLayerAttributes( wxXmlNode* aNode, PCB_LAYER_ID aLayer );
bool isValidLayerFor2581( PCB_LAYER_ID aLayer );
private: private:
LAYER_MAPPING_HANDLER m_layerMappingHandler; LAYER_MAPPING_HANDLER m_layerMappingHandler;
bool m_show_layer_mapping_warnings; bool m_show_layer_mapping_warnings;