git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@9121
c3d73ce0-8a6f-49c7-b76d-
6d57e0e08775
msgTitle = wxTheApp->GetAppName();
else
msgTitle = wxString(_("File error"));
msgTitle = wxTheApp->GetAppName();
else
msgTitle = wxString(_("File error"));
(void)wxMessageBox(_("Sorry, could not open this file."), msgTitle, wxOK | wxICON_EXCLAMATION,
parent);
(void)wxMessageBox(_("Sorry, could not open this file."), msgTitle, wxOK | wxICON_EXCLAMATION,
parent);
void wxFileHistory::AddFileToHistory(const wxString& file)
{
int i;
void wxFileHistory::AddFileToHistory(const wxString& file)
{
int i;
// Check we don't already have this file
for (i = 0; i < m_fileHistoryN; i++)
{
// Check we don't already have this file
for (i = 0; i < m_fileHistoryN; i++)
{
- if (m_fileHistory[i] && wxString(m_fileHistory[i]) == file)
+ if ( m_fileHistory[i] && (file == m_fileHistory[i]) )
+ {
+ // we do have it, move it to the top of the history
+ RemoveFileFromHistory (i);
+ AddFileToHistory (file);
- // Add to the project file history:
- // Move existing files (if any) down so we can insert file at beginning.
-
- // First delete filename that has popped off the end of the array (if any)
- if (m_fileHistoryN == m_fileMaxFiles)
+ // if we already have a full history, delete the one at the end
+ if ( m_fileMaxFiles == m_fileHistoryN )
- delete[] m_fileHistory[m_fileMaxFiles-1];
- m_fileHistory[m_fileMaxFiles-1] = (wxChar *) NULL;
+ RemoveFileFromHistory (m_fileHistoryN - 1);
+ AddFileToHistory (file);
+ return;
+
+ // Add to the project file history:
+ // Move existing files (if any) down so we can insert file at beginning.
if (m_fileHistoryN < m_fileMaxFiles)
{
wxNode* node = m_fileMenus.First();
if (m_fileHistoryN < m_fileMaxFiles)
{
wxNode* node = m_fileMenus.First();
}
m_fileHistory[0] = copystring(file);
}
m_fileHistory[0] = copystring(file);
+ // this is the directory of the last opened file
+ wxString pathCurrent;
+ wxSplitPath( m_fileHistory[0], &pathCurrent, NULL, NULL );
for (i = 0; i < m_fileHistoryN; i++)
for (i = 0; i < m_fileHistoryN; i++)
+ {
+ if ( m_fileHistory[i] )
+ // if in same directory just show the filename; otherwise the full
+ // path
+ wxString pathInMenu, path, filename, ext;
+ wxSplitPath( m_fileHistory[i], &path, &filename, &ext );
+ if ( path == pathCurrent )
+ {
+ pathInMenu = filename;
+ if ( !ext.empty() )
+ pathInMenu = pathInMenu + wxFILE_SEP_EXT + ext;
+ }
+ else
+ {
+ // absolute path; could also set relative path
+ pathInMenu = m_fileHistory[i];
+ }
+
- buf.Printf(s_MRUEntryFormat, i+1, m_fileHistory[i]);
+ buf.Printf(s_MRUEntryFormat, i + 1, pathInMenu.c_str());
wxNode* node = m_fileMenus.First();
while (node)
{
wxMenu* menu = (wxMenu*) node->Data();
wxNode* node = m_fileMenus.First();
while (node)
{
wxMenu* menu = (wxMenu*) node->Data();
- menu->SetLabel(wxID_FILE1+i, buf);
+ menu->SetLabel(wxID_FILE1 + i, buf);
}
void wxFileHistory::RemoveFileFromHistory(int i)
}
void wxFileHistory::RemoveFileFromHistory(int i)
generic/msgdlgg.cpp \
generic/numdlgg.cpp \
generic/panelg.cpp \
generic/msgdlgg.cpp \
generic/numdlgg.cpp \
generic/panelg.cpp \
generic/printps.cpp \
generic/prntdlgg.cpp \
generic/progdlgg.cpp \
generic/printps.cpp \
generic/prntdlgg.cpp \
generic/progdlgg.cpp \
panel.h \
paper.h \
pen.h \
panel.h \
paper.h \
pen.h \
print.h \
printdlg.h \
prntbase.h \
print.h \
printdlg.h \
prntbase.h \
generic/msgdlgg.h \
generic/notebook.h \
generic/panelg.h \
generic/msgdlgg.h \
generic/notebook.h \
generic/panelg.h \
generic/printps.h \
generic/prntdlgg.h \
generic/progdlgg.h \
generic/printps.h \
generic/prntdlgg.h \
generic/progdlgg.h \
msgdlgg.o \
numdlgg.o \
panelg.o \
msgdlgg.o \
numdlgg.o \
panelg.o \
printps.o \
prntdlgg.o \
progdlgg.o \
printps.o \
prntdlgg.o \
progdlgg.o \
msgdlgg.d \
numdlgg.d \
panelg.d \
msgdlgg.d \
numdlgg.d \
panelg.d \
printps.d \
prntdlgg.d \
progdlgg.d \
printps.d \
prntdlgg.d \
progdlgg.d \
generic/msgdlgg.cpp \
generic/numdlgg.cpp \
generic/panelg.cpp \
generic/msgdlgg.cpp \
generic/numdlgg.cpp \
generic/panelg.cpp \
generic/printps.cpp \
generic/prntdlgg.cpp \
generic/progdlgg.cpp \
generic/printps.cpp \
generic/prntdlgg.cpp \
generic/progdlgg.cpp \
panel.h \
paper.h \
pen.h \
panel.h \
paper.h \
pen.h \
print.h \
printdlg.h \
prntbase.h \
print.h \
printdlg.h \
prntbase.h \
generic/msgdlgg.h \
generic/notebook.h \
generic/panelg.h \
generic/msgdlgg.h \
generic/notebook.h \
generic/panelg.h \
generic/printps.h \
generic/prntdlgg.h \
generic/progdlgg.h \
generic/printps.h \
generic/prntdlgg.h \
generic/progdlgg.h \
msgdlgg.o \
numdlgg.o \
panelg.o \
msgdlgg.o \
numdlgg.o \
panelg.o \
printps.o \
prntdlgg.o \
progdlgg.o \
printps.o \
prntdlgg.o \
progdlgg.o \
msgdlgg.d \
numdlgg.d \
panelg.d \
msgdlgg.d \
numdlgg.d \
panelg.d \
printps.d \
prntdlgg.d \
progdlgg.d \
printps.d \
prntdlgg.d \
progdlgg.d \