From 0d744a4e74f7db03fdaac8a4537485ea39a6bcb9 Mon Sep 17 00:00:00 2001 From: jean-pierre charras Date: Thu, 30 Mar 2023 13:17:24 +0200 Subject: [PATCH] kicad-cli, layer names: allows using both names used in GUI and in board files From master branch Fixes #14455 https://gitlab.com/kicad/code/kicad/issues/14455 --- kicad/cli/command_export_pcb_base.cpp | 20 ++++++++++++++++++++ kicad/cli/command_export_pcb_base.h | 5 +++++ 2 files changed, 25 insertions(+) diff --git a/kicad/cli/command_export_pcb_base.cpp b/kicad/cli/command_export_pcb_base.cpp index 733ae20667..a9df828011 100644 --- a/kicad/cli/command_export_pcb_base.cpp +++ b/kicad/cli/command_export_pcb_base.cpp @@ -51,14 +51,20 @@ CLI::EXPORT_PCB_BASE_COMMAND::EXPORT_PCB_BASE_COMMAND( const std::string& aName, m_argParser.add_argument( ARG_INPUT ).help( UTF8STDSTR( _( "Input file" ) ) ); + // Build list of layer names and their layer mask: for( int layer = 0; layer < PCB_LAYER_ID_COUNT; ++layer ) { std::string untranslated = TO_UTF8( wxString( LSET::Name( PCB_LAYER_ID( layer ) ) ) ); //m_layerIndices[untranslated] = PCB_LAYER_ID( layer ); + + // Add layer name used in pcb files m_layerMasks[untranslated] = LSET( PCB_LAYER_ID( layer ) ); + // Add layer name using GUI canonical layer name + m_layerGuiMasks[ TO_UTF8(LayerName( layer ) ) ] = LSET( PCB_LAYER_ID( layer ) ); } + // Add list of grouped layer names used in pcb files m_layerMasks["*"] = LSET::AllLayersMask(); m_layerMasks["*.Cu"] = LSET::AllCuMask(); m_layerMasks["*In.Cu"] = LSET::InternalCuMask(); @@ -69,6 +75,11 @@ CLI::EXPORT_PCB_BASE_COMMAND::EXPORT_PCB_BASE_COMMAND( const std::string& aName, m_layerMasks["*.SilkS"] = LSET( 2, B_SilkS, F_SilkS ); m_layerMasks["*.Fab"] = LSET( 2, B_Fab, F_Fab ); m_layerMasks["*.CrtYd"] = LSET( 2, B_CrtYd, F_CrtYd ); + + // Add list of grouped layer names using GUI canonical layer names + m_layerGuiMasks["*.Adhesive"] = LSET( 2, B_Adhes, F_Adhes ); + m_layerGuiMasks["*.Silkscreen"] = LSET( 2, B_SilkS, F_SilkS ); + m_layerGuiMasks["*.Courtyard"] = LSET( 2, B_CrtYd, F_CrtYd ); } @@ -80,14 +91,23 @@ LSET CLI::EXPORT_PCB_BASE_COMMAND::convertLayerStringList( wxString& aLayerStrin { layerMask.reset(); wxStringTokenizer layerTokens( aLayerString, "," ); + while( layerTokens.HasMoreTokens() ) { std::string token = TO_UTF8( layerTokens.GetNextToken() ); + + // Search for a layer name in canonical layer name used in .kicad_pcb files: if( m_layerMasks.count( token ) ) { layerMask |= m_layerMasks.at(token); aLayerArgSet = true; } + // Search for a layer name in canonical layer name used in GUI (not translated): + else if( m_layerGuiMasks.count( token ) ) + { + layerMask |= m_layerGuiMasks.at(token); + aLayerArgSet = true; + } else { wxFprintf( stderr, _( "Invalid layer name \"%s\"\n" ), token ); diff --git a/kicad/cli/command_export_pcb_base.h b/kicad/cli/command_export_pcb_base.h index e97f803675..0e82b856c1 100644 --- a/kicad/cli/command_export_pcb_base.h +++ b/kicad/cli/command_export_pcb_base.h @@ -47,7 +47,12 @@ protected: LSET convertLayerStringList( wxString& aLayerString, bool& aLayerArgSet ) const; void addLayerArg( bool aRequire ); + // The list of canonical layer names used in .kicad_pcb files: std::map m_layerMasks; + + // The list of canonical layer names used in GUI (not translated): + std::map m_layerGuiMasks; + LSET m_selectedLayers; bool m_selectedLayersSet;