// Purpose: wxFileSystem class - interface for opening files
// Author: Vaclav Slavik
// Copyright: (c) 1999 Vaclav Slavik
+// CVS-ID: $Id$
// Licence: wxWindows Licence
/////////////////////////////////////////////////////////////////////////////
#pragma hdrstop
#endif
-#if !wxUSE_SOCKETS
- #undef wxUSE_FS_INET
- #define wxUSE_FS_INET 0
-#endif
-#if (wxUSE_HTML || wxUSE_FS_INET || wxUSE_FS_ZIP) && wxUSE_STREAMS
+#if wxUSE_FILESYSTEM
#include "wx/wfstream.h"
#include "wx/module.h"
wxList wxFileSystem::m_Handlers;
+static wxString MakeCorrectPath(const wxString& path)
+{
+ wxString p(path);
+ wxString r;
+ int i, j, cnt;
+
+ cnt = p.Length();
+ for (i = 0; i < cnt; i++)
+ if (p.GetChar(i) == wxT('\\')) p.GetWritableChar(i) = wxT('/'); // Want to be windows-safe
+
+ if (p.Left(2) == wxT("./")) { p = p.Mid(2); cnt -= 2; }
+
+ if (cnt < 3) return p;
+
+ r << p.GetChar(0) << p.GetChar(1);
+
+ // skip trailing ../.., if any
+ for (i = 2; i < cnt && (p.GetChar(i) == wxT('/') || p.GetChar(i) == wxT('.')); i++) r << p.GetChar(i);
+
+ // remove back references: translate dir1/../dir2 to dir2
+ for (; i < cnt; i++)
+ {
+ r << p.GetChar(i);
+ if (p.GetChar(i) == wxT('/') && p.GetChar(i-1) == wxT('.') && p.GetChar(i-2) == wxT('.'))
+ {
+ for (j = r.Length() - 2; j >= 0 && r.GetChar(j) != wxT('/') && r.GetChar(j) != wxT(':'); j--) {}
+ if (j >= 0 && r.GetChar(j) != wxT(':'))
+ {
+ for (j = j - 1; j >= 0 && r.GetChar(j) != wxT('/') && r.GetChar(j) != wxT(':'); j--) {}
+ r.Remove(j + 1);
+ }
+ }
+ }
+
+ for (; i < cnt; i++) r << p.GetChar(i);
+
+ return r;
+}
+
void wxFileSystem::ChangePathTo(const wxString& location, bool is_dir)
{
int i, pathpos = -1;
- m_Path = location;
- for (i = m_Path.Length()-1; i >= 0; i--)
- if (m_Path[(unsigned int) i] == wxT('\\')) m_Path.GetWritableChar(i) = wxT('/'); // wanna be windows-safe
+ m_Path = MakeCorrectPath(location);
if (is_dir)
{
wxFSFile* wxFileSystem::OpenFile(const wxString& location)
{
- wxString loc = location;
- int i, ln;
+ wxString loc = MakeCorrectPath(location);
+ unsigned i, ln;
char meta;
wxFSFile *s = NULL;
wxNode *node;
meta = 0;
for (i = 0; i < ln; i++)
{
- if (loc[(unsigned int) i] == wxT('\\')) loc.GetWritableChar(i) = wxT('/'); // wanna be windows-safe
if (!meta)
- switch (loc[(unsigned int) i])
+ switch (loc[i])
{
- case wxT('/') : case wxT(':') : case wxT('#') : meta = loc[(unsigned int) i];
+ case wxT('/') : case wxT(':') : case wxT('#') : meta = loc[i];
}
}
m_LastName = wxEmptyString;
m_FindFileHandler = NULL;
for (int i = spec2.Length()-1; i >= 0; i--)
- if (spec2[(unsigned int) i] == wxT('\\')) spec2.GetWritableChar(i) = wxT('/'); // wanna be windows-safe
+ if (spec2[(unsigned int) i] == wxT('\\')) spec2.GetWritableChar(i) = wxT('/'); // Want to be windows-safe
node = m_Handlers.GetFirst();
while (node)
IMPLEMENT_DYNAMIC_CLASS(wxFileSystemModule, wxModule)
#endif
- // (wxUSE_FS_INET || wxUSE_FS_ZIP) && wxUSE_STREAMS
+ // wxUSE_FILESYSTEM