X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/6cb5e50b0d2259de305f273d2be3d28d7e84dc6a..a353dc9852cc44fcffd339895ba3024d0eebbad7:/src/common/stdpbase.cpp diff --git a/src/common/stdpbase.cpp b/src/common/stdpbase.cpp index 4d477a2974..ab6b882ef6 100644 --- a/src/common/stdpbase.cpp +++ b/src/common/stdpbase.cpp @@ -24,6 +24,12 @@ #pragma hdrstop #endif +#ifndef WX_PRECOMP + #include "wx/app.h" +#endif //WX_PRECOMP +#include "wx/apptrait.h" + +#include "wx/filename.h" #include "wx/stdpaths.h" // ---------------------------------------------------------------------------- @@ -37,7 +43,12 @@ static wxStandardPaths gs_stdPaths; // ============================================================================ /* static */ -wxStandardPaths& wxStandardPathsBase::Get() +wxStandardPathsBase& wxStandardPathsBase::Get() +{ + return wxTheApp->GetTraits()->GetStandardPaths(); +} + +wxStandardPathsBase& wxAppTraitsBase::GetStandardPaths() { return gs_stdPaths; } @@ -57,3 +68,25 @@ wxString wxStandardPathsBase::GetUserLocalDataDir() const return GetUserDataDir(); } +/* static */ +wxString wxStandardPathsBase::AppendAppName(const wxString& dir) +{ + wxString subdir(dir); + + // empty string indicates that an error has occured, don't touch it then + if ( !subdir.empty() ) + { + const wxString appname = wxTheApp->GetAppName(); + if ( !appname.empty() ) + { + const wxChar ch = *(subdir.end() - 1); + if ( !wxFileName::IsPathSeparator(ch) && ch != _T('.') ) + subdir += wxFileName::GetPathSeparator(); + + subdir += appname; + } + } + + return subdir; +} +