/* * This program source code file is part of KiCad, a free EDA CAD application. * * Copyright (C) 2018-2021 KiCad Developers, see AUTHORS.txt for contributors. * * This program is free software: you can redistribute it and/or modify it * under the terms of the GNU General Public License as published by the * Free Software Foundation, either version 3 of the License, or (at your * option) any later version. * * This program is distributed in the hope that it will be useful, but * WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * General Public License for more details. * * You should have received a copy of the GNU General Public License along * with this program. If not, see . */ #include #include #include #include #include #include #include using STRING_MAP = std::map; /* * List of pre-defined environment variables * * TODO - Instead of defining these values here, * extract them from elsewhere in the program * (where they are originally defined) */ static const ENV_VAR::ENV_VAR_LIST predefinedEnvVars = { wxS( "KIPRJMOD" ), ENV_VAR::GetVersionedEnvVarName( wxS( "SYMBOL_DIR" ) ), ENV_VAR::GetVersionedEnvVarName( wxS( "3DMODEL_DIR" ) ), ENV_VAR::GetVersionedEnvVarName( wxS( "FOOTPRINT_DIR" ) ), ENV_VAR::GetVersionedEnvVarName( wxS( "TEMPLATE_DIR" ) ), wxS( "KICAD_USER_TEMPLATE_DIR" ), wxS( "KICAD_PTEMPLATES" ), ENV_VAR::GetVersionedEnvVarName( wxS( "3RD_PARTY" ) ), }; const wxRegEx versionedEnvVarRegex( wxS( "KICAD[0-9]+_[A-Z0-9_]+(_DIR)?" ) ); bool ENV_VAR::IsEnvVarImmutable( const wxString& aEnvVar ) { if( versionedEnvVarRegex.Matches( aEnvVar ) ) return true; for( const wxString& s : predefinedEnvVars ) { if( s == aEnvVar ) return true; } return false; } const ENV_VAR::ENV_VAR_LIST& ENV_VAR::GetPredefinedEnvVars() { return predefinedEnvVars; } wxString ENV_VAR::GetVersionedEnvVarName( const wxString& aBaseName ) { int version = 0; std::tie(version, std::ignore, std::ignore) = GetMajorMinorPatchTuple(); return wxString::Format( "KICAD%d_%s", version, aBaseName ); } std::optional ENV_VAR::GetVersionedEnvVarValue( const ENV_VAR_MAP& aMap, const wxString& aBaseName ) { wxString exactMatch = ENV_VAR::GetVersionedEnvVarName( aBaseName ); if( aMap.count( exactMatch ) ) return aMap.at( exactMatch ).GetValue(); wxString partialMatch = wxString::Format( "KICAD*_%s", aBaseName ); for( const auto& [k, v] : aMap ) { if( k.Matches( partialMatch ) ) return v.GetValue(); } return std::nullopt; } static void initialiseEnvVarHelp( STRING_MAP& aMap ) { // Set up dynamically, as we want to be able to use _() translations, // which can't be done statically aMap[ENV_VAR::GetVersionedEnvVarName( wxS( "FOOTPRINT_DIR" ) )] = _( "The base path of locally installed system " "footprint libraries (.pretty folders)."); aMap[ENV_VAR::GetVersionedEnvVarName( wxS( "3DMODEL_DIR" ) )] = _( "The base path of system footprint 3D shapes (.3Dshapes folders)."); aMap[ENV_VAR::GetVersionedEnvVarName( wxS( "SYMBOL_DIR" ) )] = _( "The base path of the locally installed symbol libraries."); aMap[ENV_VAR::GetVersionedEnvVarName( wxS( "TEMPLATE_DIR" ) )] = _( "A directory containing project templates installed with KiCad."); aMap[wxS( "KICAD_USER_TEMPLATE_DIR" )] = _( "Optional. Can be defined if you want to create your own project " "templates folder."); aMap[ENV_VAR::GetVersionedEnvVarName( wxS( "3RD_PARTY" ) )] = _( "A directory containing 3rd party plugins, libraries and other " "downloadable content."); aMap[wxS( "KIPRJMOD" )] = _("Internally defined by KiCad (cannot be edited) and is set " "to the absolute path of the currently loaded project file. This environment " "variable can be used to define files and paths relative to the currently loaded " "project. For instance, ${KIPRJMOD}/libs/footprints.pretty can be defined as a " "folder containing a project specific footprint library named footprints.pretty." ); aMap[ENV_VAR::GetVersionedEnvVarName( wxS( "SCRIPTING_DIR" ) )] = _( "A directory containing system-wide scripts installed with KiCad" ); aMap[ENV_VAR::GetVersionedEnvVarName( wxS( "USER_SCRIPTING_DIR" ) )] = _( "A directory containing user-specific scripts installed with KiCad" ); // Deprecated vars aMap[wxS( "KICAD_PTEMPLATES" )] = _( "Deprecated version of KICAD_TEMPLATE_DIR."); aMap[wxS( "KISYS3DMOD" )] = _( "Deprecated version of KICAD7_3DMODEL_DIR." ); aMap[wxS( "KISYSMOD" )] = _( "Deprecated version of KICAD7_FOOTPRINT_DIR." ); aMap[wxS( "KICAD_SYMBOL_DIR" )] = _( "Deprecated version of KICAD_SYMBOL_DIR."); } wxString ENV_VAR::LookUpEnvVarHelp( const wxString& aEnvVar ) { static STRING_MAP envVarHelpText; if( envVarHelpText.size() == 0 ) initialiseEnvVarHelp( envVarHelpText ); return envVarHelpText[ aEnvVar ]; } template<> std::optional ENV_VAR::GetEnvVar( const wxString& aEnvVarName ) { wxString env; if( wxGetEnv( aEnvVarName, &env ) ) { double value; if( env.ToDouble( &value ) ) return value; } return std::nullopt; } template<> std::optional ENV_VAR::GetEnvVar( const wxString& aEnvVarName ) { std::optional optValue; wxString env; if( wxGetEnv( aEnvVarName, &env ) ) { optValue = env; } return optValue; }