X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/e0b3b9d044746a258f93ae7c66550788d08d028e..6d8978f030996c834fcd29d85d95ebe261b8defc:/src/unix/stdpaths.cpp diff --git a/src/unix/stdpaths.cpp b/src/unix/stdpaths.cpp index af3551bf06..3749968cc9 100644 --- a/src/unix/stdpaths.cpp +++ b/src/unix/stdpaths.cpp @@ -29,10 +29,13 @@ #include "wx/stdpaths.h" #ifndef WX_PRECOMP + #include "wx/wxcrt.h" #include "wx/utils.h" #endif //WX_PRECOMP #include "wx/filename.h" +#include "wx/log.h" +#include "wx/textfile.h" #if defined( __LINUX__ ) || defined( __VMS ) #include @@ -52,6 +55,7 @@ wxString wxStandardPaths::GetUserConfigDir() const return wxFileName::GetHomeDir(); } + // ============================================================================ // wxStandardPaths implementation for VMS // ============================================================================ @@ -62,7 +66,7 @@ wxString wxStandardPaths::GetInstallPrefix() const { if ( m_prefix.empty() ) { - wx_const_cast(wxStandardPaths *, this)->m_prefix = wxT("/sys$system"); + const_cast(this)->m_prefix = wxT("/sys$system"); } return m_prefix; @@ -75,12 +79,12 @@ wxString wxStandardPaths::GetConfigDir() const wxString wxStandardPaths::GetDataDir() const { - return AppendAppName(GetInstallPrefix() + _T("/sys$share")); + return AppendAppInfo(GetInstallPrefix() + _T("/sys$share")); } wxString wxStandardPaths::GetLocalDataDir() const { - return AppendAppName(_T("/sys$manager")); + return AppendAppInfo(_T("/sys$manager")); } wxString wxStandardPaths::GetUserDataDir() const @@ -169,7 +173,7 @@ wxString wxStandardPaths::GetInstallPrefix() const { if ( m_prefix.empty() ) { - wxStandardPaths *pathPtr = wx_const_cast(wxStandardPaths *, this); + wxStandardPaths *pathPtr = const_cast(this); pathPtr->DetectPrefix(); } @@ -187,22 +191,22 @@ wxString wxStandardPaths::GetConfigDir() const wxString wxStandardPaths::GetDataDir() const { - return AppendAppName(GetInstallPrefix() + _T("/share")); + return AppendAppInfo(GetInstallPrefix() + _T("/share")); } wxString wxStandardPaths::GetLocalDataDir() const { - return AppendAppName(_T("/etc")); + return AppendAppInfo(_T("/etc")); } wxString wxStandardPaths::GetUserDataDir() const { - return AppendAppName(wxFileName::GetHomeDir() + _T("/.")); + return AppendAppInfo(wxFileName::GetHomeDir() + _T("/.")); } wxString wxStandardPaths::GetPluginsDir() const { - return AppendAppName(GetInstallPrefix() + _T("/lib")); + return AppendAppInfo(GetInstallPrefix() + _T("/lib")); } wxString @@ -215,6 +219,46 @@ wxStandardPaths::GetLocalizedResourcesDir(const wxString& lang, return GetInstallPrefix() + _T("/share/locale/") + lang + _T("/LC_MESSAGES"); } +wxString wxStandardPaths::GetDocumentsDir() const +{ + { + wxLogNull logNull; + wxString homeDir = wxFileName::GetHomeDir(); + wxString configPath; + if (wxGetenv(wxT("XDG_CONFIG_HOME"))) + configPath = wxGetenv(wxT("XDG_CONFIG_HOME")); + else + configPath = homeDir + wxT("/.config"); + wxString dirsFile = configPath + wxT("/user-dirs.dirs"); + if (wxFileExists(dirsFile)) + { + wxTextFile textFile; + if (textFile.Open(dirsFile)) + { + size_t i; + for (i = 0; i < textFile.GetLineCount(); i++) + { + wxString line(textFile[i]); + int pos = line.Find(wxT("XDG_DOCUMENTS_DIR")); + if (pos != wxNOT_FOUND) + { + wxString value = line.AfterFirst(wxT('=')); + value.Replace(wxT("$HOME"), homeDir); + value.Trim(true); + value.Trim(false); + if (!value.IsEmpty() && wxDirExists(value)) + return value; + else + break; + } + } + } + } + } + + return wxStandardPathsBase::GetDocumentsDir(); +} + #endif // __VMS/!__VMS #endif // wxUSE_STDPATHS