// Created: 20/07/97
// RCS-ID: $Id$
// Copyright: (c) 1997, 1998 Guilhem Lavaux
-// Licence: wxWindows license
+// Licence: wxWindows licence
/////////////////////////////////////////////////////////////////////////////
-#ifdef __GNUG__
+#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA)
#pragma implementation "sckfile.h"
#endif
#include "wx/wxprec.h"
#ifdef __BORLANDC__
-#pragma hdrstop
+ #pragma hdrstop
#endif
#ifndef WX_PRECOMP
+ #include "wx/defs.h"
#endif
+#if wxUSE_STREAMS && wxUSE_PROTOCOL_FILE
+
#include <stdio.h>
-#include <stdlib.h>
-#include <wx/fstream.h>
+#include "wx/wfstream.h"
#include "wx/protocol/file.h"
-#if !USE_SHARED_LIBRARY
IMPLEMENT_DYNAMIC_CLASS(wxFileProto, wxProtocol)
-IMPLEMENT_PROTOCOL(wxFileProto, "file", NULL, FALSE)
-#endif
+IMPLEMENT_PROTOCOL(wxFileProto, wxT("file"), NULL, false)
wxFileProto::wxFileProto()
- : wxProtocol()
+ : wxProtocol()
{
+ m_error = wxPROTO_NOERR;
}
wxFileProto::~wxFileProto()
wxInputStream *wxFileProto::GetInputStream(const wxString& path)
{
- return new wxFileInputStream(path);
+ wxFileInputStream *retval = new wxFileInputStream(wxURI::Unescape(path));
+ if ( retval->Ok() )
+ {
+ m_error = wxPROTO_NOERR;
+
+ return retval;
+ }
+
+ m_error = wxPROTO_NOFILE;
+ delete retval;
+
+ return NULL;
}
+
+#endif // wxUSE_STREAMS && wxUSE_PROTOCOL_FILE
+