added wxStandardPaths::GetAppDocumentsDir() and use it by default for loading/saving documents in wxDocManager

git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@58259 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Vadim Zeitlin
2009-01-21 14:01:30 +00:00
parent 0cdbed4cfa
commit d8efd2198f
6 changed files with 62 additions and 7 deletions

View File

@@ -328,6 +328,7 @@ All:
- Added wxSHUTDOWN_LOGOFF and wxSHUTDOWN_FORCE wxShutdown() flags (troelsk).
- Added wxSocket::ShutdownOutput().
- Handle exceptions thrown from overridden wxView::OnCreate() gracefully.
- Added wxStandardPaths::GetAppDocumentsDir().
All (Unix):

View File

@@ -436,7 +436,7 @@ public:
virtual void FileHistoryAddFilesToMenu();
virtual void FileHistoryAddFilesToMenu(wxMenu* menu);
wxString GetLastDirectory() const { return m_lastDirectory; }
wxString GetLastDirectory() const;
void SetLastDirectory(const wxString& dir) { m_lastDirectory = dir; }
// Get the current document manager

View File

@@ -131,6 +131,11 @@ public:
// $HOME under Unix and ~/Documents under Mac
virtual wxString GetDocumentsDir() const;
// return the directory for the documents files used by this application:
// it's a subdirectory of GetDocumentsDir() constructed using the
// application name/vendor if it exists or just GetDocumentsDir() otherwise
virtual wxString GetAppDocumentsDir() const;
// return the temporary directory for the current user
virtual wxString GetTempDir() const;
@@ -151,8 +156,8 @@ public:
protected:
// append the path component, with a leading path seperator if a
// path seperator or dot (.) is not already at the end of dir
// append the path component, with a leading path separator if a
// path separator or dot (.) is not already at the end of dir
static wxString AppendPathComponent(const wxString& dir, const wxString& component);
// append application information determined by m_usedAppInfo to dir

View File

@@ -53,6 +53,23 @@ public:
*/
static wxStandardPathsBase& Get();
/**
Return the directory for the document files used by this application.
If the application-specific directory doesn't exist, this function
returns GetDocumentsDir().
Example return values:
- Unix: @c ~/appname
- Windows: @c "C:\Documents and Settings\username\My Documents\appname"
- Mac: @c ~/Documents/appname
@since 2.9.0
@see GetAppDocumentsDir()
*/
virtual wxString GetAppDocumentsDir() const;
/**
Return the directory containing the system config files.
Example return values:
@@ -78,12 +95,15 @@ public:
/**
Return the directory containing the current user's documents.
Example return values:
- Unix: @c ~ (the home directory)
- Windows: @c "C:\Documents and Settings\username\My Documents"
- Mac: @c ~/Documents
@since 2.7.0
@see GetAppDocumentsDir()
*/
virtual wxString GetDocumentsDir() const;

View File

@@ -56,6 +56,7 @@
#include "wx/cmdproc.h"
#include "wx/tokenzr.h"
#include "wx/filename.h"
#include "wx/stdpaths.h"
#include "wx/vector.h"
#include "wx/ptr_scpd.h"
@@ -307,8 +308,12 @@ bool wxDocument::SaveAs()
wxString filter = docTemplate->GetFileFilter() ;
#endif
wxString defaultDir = docTemplate->GetDirectory();
if (defaultDir.IsEmpty())
if ( defaultDir.empty() )
{
defaultDir = wxPathOnly(GetFilename());
if ( defaultDir.empty() )
defaultDir = GetDocumentManager()->GetLastDirectory();
}
wxString fileName = wxFileSelector(_("Save As"),
defaultDir,
@@ -938,6 +943,19 @@ bool wxDocManager::Initialize()
return true;
}
wxString wxDocManager::GetLastDirectory() const
{
// use the system-dependent default location for the document files if
// we're being opened for the first time
if ( m_lastDirectory.empty() )
{
wxDocManager * const self = const_cast<wxDocManager *>(this);
self->m_lastDirectory = wxStandardPaths::Get().GetAppDocumentsDir();
}
return m_lastDirectory;
}
wxFileHistory *wxDocManager::OnCreateFileHistory()
{
return new wxFileHistory;
@@ -1490,7 +1508,7 @@ wxDocTemplate *wxDocManager::SelectDocumentPath(wxDocTemplate **templates,
wxWindow* parent = wxFindSuitableParent();
wxString pathTmp = wxFileSelectorEx(_("Open File"),
m_lastDirectory,
GetLastDirectory(),
wxEmptyString,
&FilterIndex,
descrBuf,
@@ -1514,7 +1532,8 @@ wxDocTemplate *wxDocManager::SelectDocumentPath(wxDocTemplate **templates,
path = wxEmptyString;
return NULL;
}
m_lastDirectory = wxPathOnly(pathTmp);
SetLastDirectory(wxPathOnly(pathTmp));
path = pathTmp;

View File

@@ -106,6 +106,14 @@ wxString wxStandardPathsBase::GetDocumentsDir() const
return wxFileName::GetHomeDir();
}
wxString wxStandardPathsBase::GetAppDocumentsDir() const
{
const wxString docsDir = GetDocumentsDir();
wxString appDocsDir = AppendAppInfo(docsDir);
return wxDirExists(appDocsDir) ? appDocsDir : docsDir;
}
// return the temporary directory for the current user
wxString wxStandardPathsBase::GetTempDir() const
{
@@ -113,7 +121,9 @@ wxString wxStandardPathsBase::GetTempDir() const
}
/* static */
wxString wxStandardPathsBase::AppendPathComponent(const wxString& dir, const wxString& component)
wxString
wxStandardPathsBase::AppendPathComponent(const wxString& dir,
const wxString& component)
{
wxString subdir(dir);