KiCad PCB EDA Suite
Loading...
Searching...
No Matches
PATHS Class Reference

Helper class to centralize the paths used throughout kicad. More...

#include <paths.h>

Static Public Member Functions

static wxString GetUserScriptingPath ()
 Gets the user path for python scripts.
 
static wxString GetUserTemplatesPath ()
 Gets the user path for custom templates.
 
static wxString GetUserPluginsPath ()
 Gets the user path for plugins.
 
static wxString GetDefaultUserProjectsPath ()
 Gets the default path we point users to create projects.
 
static wxString GetDefaultUserSymbolsPath ()
 Gets the default path we point users to create projects.
 
static wxString GetDefaultUserFootprintsPath ()
 Gets the default path we point users to create projects.
 
static wxString GetDefaultUserDesignBlocksPath ()
 Gets the default path we point users to create projects.
 
static wxString GetDefaultUser3DModelsPath ()
 Gets the default path we point users to create projects.
 
static wxString GetStockDataPath (bool aRespectRunFromBuildDir=true)
 Gets the stock (install) data path, which is the base path for things like scripting, etc.
 
static wxString GetStockEDALibraryPath ()
 Gets the stock (install) EDA library data path, which is the base path for templates, schematic symbols, footprints, and 3D models.
 
static wxString GetDefault3rdPartyPath ()
 Gets the default path for PCM packages.
 
static wxString GetStockSymbolsPath ()
 Gets the stock (install) symbols path.
 
static wxString GetStockFootprintsPath ()
 Gets the stock (install) footprints path.
 
static wxString GetStockDesignBlocksPath ()
 Gets the stock (install) footprints path.
 
static wxString GetStock3dmodelsPath ()
 Gets the stock (install) 3dmodels path.
 
static wxString GetStockScriptingPath ()
 Gets the stock (install) scripting path.
 
static wxString GetStockPluginsPath ()
 Gets the stock (install) plugins path.
 
static wxString GetStockPlugins3DPath ()
 Gets the stock (install) 3d viewer plugins path.
 
static wxString GetStockDemosPath ()
 Gets the stock (install) demos path.
 
static wxString GetStockTemplatesPath ()
 Gets the stock (install) templates path.
 
static wxString GetLocaleDataPath ()
 Gets the locales translation data path.
 
static wxString GetUserCachePath ()
 Gets the stock (install) 3d viewer plugins path.
 
static wxString GetDocumentationPath ()
 Gets the documentation path, which is the base path for help files.
 
static wxString GetInstanceCheckerPath ()
 Gets the path used for wxSingleInstanceChecker lock files.
 
static wxString GetLogsPath ()
 Gets a path to use for user-visible log files.
 
static bool EnsurePathExists (const wxString &aPath)
 Attempts to create a given path if it does not exist.
 
static void EnsureUserPathsExist ()
 Ensures/creates user default paths.
 
static wxString GetUserSettingsPath ()
 Return the user configuration path used to store KiCad's configuration files.
 
static wxString CalculateUserSettingsPath (bool aIncludeVer=true, bool aUseEnv=true)
 Determines the base path for user settings files.
 
static const wxString & GetExecutablePath ()
 

Private Member Functions

 PATHS ()
 

Static Private Member Functions

static void getUserDocumentPath (wxFileName &aPath)
 Gets the user path for the current kicad version which acts as the root for other user paths.
 

Detailed Description

Helper class to centralize the paths used throughout kicad.

Definition at line 36 of file paths.h.

Constructor & Destructor Documentation

◆ PATHS()

PATHS::PATHS ( )
inlineprivate

Definition at line 238 of file paths.h.

Member Function Documentation

◆ CalculateUserSettingsPath()

wxString PATHS::CalculateUserSettingsPath ( bool  aIncludeVer = true,
bool  aUseEnv = true 
)
static

Determines the base path for user settings files.

The configuration path order of precedence is determined by the following criteria:

  • The value of the KICAD_CONFIG_HOME environment variable
  • The value of the XDG_CONFIG_HOME environment variable.
  • The result of the call to wxStandardPaths::GetUserConfigDir() with ".config" appended as required on Linux builds.
Parameters
aIncludeVerwill append the current KiCad version if true (default)
aUseEnvwill prefer the base path found in the KICAD_CONFIG_DIR if found (default)
Returns
A string containing the config path for Kicad

Definition at line 542 of file paths.cpp.

References GetMajorMinorVersion(), KIPLATFORM::ENV::GetUserConfigPath(), and TO_STR.

Referenced by SETTINGS_MANAGER::GetPreviousVersionPaths(), and GetUserSettingsPath().

◆ EnsurePathExists()

bool PATHS::EnsurePathExists ( const wxString &  aPath)
static

Attempts to create a given path if it does not exist.

Definition at line 423 of file paths.cpp.

References path.

Referenced by EnsureUserPathsExist(), EMBEDDED_FILES::GetTemporaryFileName(), PGM_BASE::InitPgm(), and KICAD_API_SERVER::Start().

◆ EnsureUserPathsExist()

◆ GetDefault3rdPartyPath()

wxString PATHS::GetDefault3rdPartyPath ( )
static

◆ GetDefaultUser3DModelsPath()

wxString PATHS::GetDefaultUser3DModelsPath ( )
static

Gets the default path we point users to create projects.

Definition at line 120 of file paths.cpp.

References getUserDocumentPath().

Referenced by EnsureUserPathsExist().

◆ GetDefaultUserDesignBlocksPath()

wxString PATHS::GetDefaultUserDesignBlocksPath ( )
static

Gets the default path we point users to create projects.

Definition at line 109 of file paths.cpp.

References getUserDocumentPath().

Referenced by SCH_EDIT_FRAME::AddDesignBlockLibrary(), SCH_EDIT_FRAME::createNewDesignBlockLibrary(), and PANEL_DESIGN_BLOCK_LIB_TABLE::PANEL_DESIGN_BLOCK_LIB_TABLE().

◆ GetDefaultUserFootprintsPath()

wxString PATHS::GetDefaultUserFootprintsPath ( )
static

Gets the default path we point users to create projects.

Definition at line 98 of file paths.cpp.

References getUserDocumentPath().

Referenced by PCB_BASE_EDIT_FRAME::AddLibrary(), PCB_BASE_EDIT_FRAME::createNewLibrary(), EnsureUserPathsExist(), and PANEL_FP_LIB_TABLE::PANEL_FP_LIB_TABLE().

◆ GetDefaultUserProjectsPath()

◆ GetDefaultUserSymbolsPath()

wxString PATHS::GetDefaultUserSymbolsPath ( )
static

Gets the default path we point users to create projects.

Definition at line 87 of file paths.cpp.

References getUserDocumentPath().

Referenced by SYMBOL_EDIT_FRAME::AddLibraryFile(), EnsureUserPathsExist(), SCH_EDITOR_CONTROL::ExportSymbolsToLibrary(), and PANEL_SYM_LIB_TABLE::PANEL_SYM_LIB_TABLE().

◆ GetDocumentationPath()

wxString PATHS::GetDocumentationPath ( )
static

Gets the documentation path, which is the base path for help files.

Definition at line 386 of file paths.cpp.

References path.

Referenced by SearchHelpFileFullPath().

◆ GetExecutablePath()

const wxString & PATHS::GetExecutablePath ( )
static

◆ GetInstanceCheckerPath()

wxString PATHS::GetInstanceCheckerPath ( )
static

Gets the path used for wxSingleInstanceChecker lock files.

Definition at line 402 of file paths.cpp.

References path.

Referenced by PGM_BASE::InitPgm().

◆ GetLocaleDataPath()

wxString PATHS::GetLocaleDataPath ( )
static

Gets the locales translation data path.

Definition at line 278 of file paths.cpp.

References GetStockDataPath(), and path.

Referenced by PGM_BASE::SetLanguagePath().

◆ GetLogsPath()

wxString PATHS::GetLogsPath ( )
static

Gets a path to use for user-visible log files.

Definition at line 412 of file paths.cpp.

References getUserDocumentPath().

Referenced by KICAD_API_SERVER::Start().

◆ GetStock3dmodelsPath()

wxString PATHS::GetStock3dmodelsPath ( )
static

Gets the stock (install) 3dmodels path.

Definition at line 248 of file paths.cpp.

References GetStockEDALibraryPath(), and path.

◆ GetStockDataPath()

wxString PATHS::GetStockDataPath ( bool  aRespectRunFromBuildDir = true)
static

◆ GetStockDemosPath()

wxString PATHS::GetStockDemosPath ( )
static

Gets the stock (install) demos path.

Definition at line 354 of file paths.cpp.

References GetStockDataPath().

Referenced by KICAD_MANAGER_FRAME::doReCreateMenuBar(), and KICAD_MANAGER_CONTROL::OpenDemoProject().

◆ GetStockDesignBlocksPath()

wxString PATHS::GetStockDesignBlocksPath ( )
static

Gets the stock (install) footprints path.

Definition at line 238 of file paths.cpp.

References GetStockEDALibraryPath(), and path.

◆ GetStockEDALibraryPath()

wxString PATHS::GetStockEDALibraryPath ( )
static

Gets the stock (install) EDA library data path, which is the base path for templates, schematic symbols, footprints, and 3D models.

Definition at line 202 of file paths.cpp.

References GetStockDataPath(), and path.

Referenced by GetStock3dmodelsPath(), GetStockDesignBlocksPath(), GetStockFootprintsPath(), GetStockSymbolsPath(), GetStockTemplatesPath(), COMMON_SETTINGS::InitializeEnvironment(), and SystemDirsAppend().

◆ GetStockFootprintsPath()

wxString PATHS::GetStockFootprintsPath ( )
static

Gets the stock (install) footprints path.

Definition at line 228 of file paths.cpp.

References GetStockEDALibraryPath(), and path.

◆ GetStockPlugins3DPath()

wxString PATHS::GetStockPlugins3DPath ( )
static

Gets the stock (install) 3d viewer plugins path.

Definition at line 304 of file paths.cpp.

References GetExecutablePath().

Referenced by S3D_PLUGIN_MANAGER::loadPlugins().

◆ GetStockPluginsPath()

wxString PATHS::GetStockPluginsPath ( )
static

Gets the stock (install) plugins path.

Definition at line 288 of file paths.cpp.

References GetExecutablePath(), and GetStockDataPath().

Referenced by BOM_GENERATOR_HANDLER::FindFilePath(), DIALOG_BOM::pluginInit(), and API_PLUGIN_MANAGER::ReloadPlugins().

◆ GetStockScriptingPath()

wxString PATHS::GetStockScriptingPath ( )
static

Gets the stock (install) scripting path.

Definition at line 258 of file paths.cpp.

References GetStockDataPath(), and path.

◆ GetStockSymbolsPath()

wxString PATHS::GetStockSymbolsPath ( )
static

Gets the stock (install) symbols path.

Definition at line 218 of file paths.cpp.

References GetStockEDALibraryPath(), and path.

◆ GetStockTemplatesPath()

wxString PATHS::GetStockTemplatesPath ( )
static

Gets the stock (install) templates path.

Definition at line 268 of file paths.cpp.

References GetStockEDALibraryPath(), and path.

Referenced by COMMON_SETTINGS::InitializeEnvironment().

◆ GetUserCachePath()

◆ getUserDocumentPath()

void PATHS::getUserDocumentPath ( wxFileName &  aPath)
staticprivate

Gets the user path for the current kicad version which acts as the root for other user paths.

Parameters
aPathVariable to receive the path

Definition at line 40 of file paths.cpp.

References KIPLATFORM::ENV::GetDocumentsPath(), GetMajorMinorVersion(), and KICAD_PATH_STR.

Referenced by GetDefault3rdPartyPath(), GetDefaultUser3DModelsPath(), GetDefaultUserDesignBlocksPath(), GetDefaultUserFootprintsPath(), GetDefaultUserProjectsPath(), GetDefaultUserSymbolsPath(), GetLogsPath(), GetUserPluginsPath(), GetUserScriptingPath(), and GetUserTemplatesPath().

◆ GetUserPluginsPath()

wxString PATHS::GetUserPluginsPath ( )
static

◆ GetUserScriptingPath()

wxString PATHS::GetUserScriptingPath ( )
static

Gets the user path for python scripts.

Definition at line 65 of file paths.cpp.

References getUserDocumentPath().

Referenced by EnsureUserPathsExist().

◆ GetUserSettingsPath()

◆ GetUserTemplatesPath()

wxString PATHS::GetUserTemplatesPath ( )
static

Gets the user path for custom templates.

Definition at line 76 of file paths.cpp.

References getUserDocumentPath().

Referenced by EnsureUserPathsExist(), PL_EDITOR_FRAME::Files_io(), COMMON_SETTINGS::InitializeEnvironment(), and PGM_KICAD::OnPgmInit().


The documentation for this class was generated from the following files: