KiCad PCB EDA Suite
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Modules Pages Concepts
env_vars.h
Go to the documentation of this file.
1/*
2 * This program source code file is part of KiCad, a free EDA CAD application.
3 *
4 * Copyright The KiCad Developers, see AUTHORS.txt for contributors.
5 *
6 * This program is free software: you can redistribute it and/or modify it
7 * under the terms of the GNU General Public License as published by the
8 * Free Software Foundation, either version 3 of the License, or (at your
9 * option) any later version.
10 *
11 * This program is distributed in the hope that it will be useful, but
12 * WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 * General Public License for more details.
15 *
16 * You should have received a copy of the GNU General Public License along
17 * with this program. If not, see <http://www.gnu.org/licenses/>.
18 */
19
26#ifndef ENV_VARS_H
27#define ENV_VARS_H
28
29#include <kicommon.h>
30#include <wx/string.h>
31#include <wx/arrstr.h>
32#include <map>
33#include <vector>
34#include <optional>
35
36class ENV_VAR_ITEM;
37
38namespace ENV_VAR
39{
48 KICOMMON_API bool IsEnvVarImmutable( const wxString& aEnvVar );
49
53 KICOMMON_API const std::vector<wxString>& GetPredefinedEnvVars();
54
58 KICOMMON_API void GetEnvVarAutocompleteTokens( wxArrayString* aVars );
59
66 KICOMMON_API wxString GetVersionedEnvVarName( const wxString& aBaseName );
67
79 KICOMMON_API std::optional<wxString>
80 GetVersionedEnvVarValue( const std::map<wxString, ENV_VAR_ITEM>& aMap,
81 const wxString& aBaseName );
82
92 KICOMMON_API wxString LookUpEnvVarHelp( const wxString& aEnvVar );
93
100 template <typename VAL_TYPE>
101 KICOMMON_API std::optional<VAL_TYPE> GetEnvVar( const wxString& aEnvVarName );
102
109 template<>
110 KICOMMON_API std::optional<wxString> GetEnvVar( const wxString& aEnvVarName );
111
119 template <>
120 KICOMMON_API std::optional<double> GetEnvVar( const wxString& aEnvVarName );
121};
122
123#endif /* ENV_VARS_H */
KiCad uses environment variables internally for determining the base paths for libraries,...
#define KICOMMON_API
Definition: kicommon.h:28
KICOMMON_API wxString LookUpEnvVarHelp(const wxString &aEnvVar)
Look up long-form help text for a given environment variable.
Definition: env_vars.cpp:158
KICOMMON_API void GetEnvVarAutocompleteTokens(wxArrayString *aVars)
Return autocomplete tokens for environment variables for Scintilla.
Definition: env_vars.cpp:73
KICOMMON_API std::optional< VAL_TYPE > GetEnvVar(const wxString &aEnvVarName)
Get an environment variable as a specific type, if set correctly.
KICOMMON_API std::optional< wxString > GetVersionedEnvVarValue(const std::map< wxString, ENV_VAR_ITEM > &aMap, const wxString &aBaseName)
Attempt to retrieve the value of a versioned environment variable, such as KICAD8_TEMPLATE_DIR.
Definition: env_vars.cpp:92
KICOMMON_API const std::vector< wxString > & GetPredefinedEnvVars()
Get the list of pre-defined environment variables.
Definition: env_vars.cpp:67
KICOMMON_API wxString GetVersionedEnvVarName(const wxString &aBaseName)
Construct a versioned environment variable based on this KiCad major version.
Definition: env_vars.cpp:83
KICOMMON_API bool IsEnvVarImmutable(const wxString &aEnvVar)
Determine if an environment variable is "predefined", i.e.
Definition: env_vars.cpp:52