added mode parameter to wxFFileStream ctors taking wxFFile

git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@31383 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Vadim Zeitlin
2005-01-15 23:06:09 +00:00
parent c67b4daf47
commit 5fec5bb620
3 changed files with 91 additions and 105 deletions

View File

@@ -38,9 +38,9 @@ can seek beyond the end of the stream (file) and will thus not return
\membersection{wxFFileInputStream::wxFFileInputStream}\label{wxffileinputstreamctor} \membersection{wxFFileInputStream::wxFFileInputStream}\label{wxffileinputstreamctor}
\func{}{wxFFileInputStream}{\param{const wxString\&}{ ifileName}} \func{}{wxFFileInputStream}{\param{const wxString\&}{ filename}, \param{const wxChar *}{ mode = "rb"}}
Opens the specified file using its {\it ifilename} name in read-only mode. Opens the specified file using its {\it filename} name using the specified mode.
\func{}{wxFFileInputStream}{\param{wxFFile\&}{ file}} \func{}{wxFFileInputStream}{\param{wxFFile\&}{ file}}
@@ -102,10 +102,9 @@ can seek beyond the end of the stream (file) and will thus not return
\membersection{wxFFileOutputStream::wxFFileOutputStream}\label{wxffileoutputstreamctor} \membersection{wxFFileOutputStream::wxFFileOutputStream}\label{wxffileoutputstreamctor}
\func{}{wxFFileOutputStream}{\param{const wxString\&}{ ofileName}} \func{}{wxFFileOutputStream}{\param{const wxString\&}{ filename}, \param{const wxChar *}{ mode="w+b"}}
Creates a new file with {\it ofilename} name and initializes the stream in Opens the file with the given {\it filename} name in the specified mode.
write-only mode.
\func{}{wxFFileOutputStream}{\param{wxFFile\&}{ file}} \func{}{wxFFileOutputStream}{\param{wxFFile\&}{ file}}

View File

@@ -1,5 +1,5 @@
///////////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////////
// Name: wfstream.h // Name: wx/wfstream.h
// Purpose: File stream classes // Purpose: File stream classes
// Author: Guilhem Lavaux // Author: Guilhem Lavaux
// Modified by: // Modified by:
@@ -30,7 +30,8 @@
// wxFileStream using wxFile // wxFileStream using wxFile
// ---------------------------------------------------------------------------- // ----------------------------------------------------------------------------
class WXDLLIMPEXP_BASE wxFileInputStream: public wxInputStream { class WXDLLIMPEXP_BASE wxFileInputStream : public wxInputStream
{
public: public:
wxFileInputStream(const wxString& ifileName); wxFileInputStream(const wxString& ifileName);
wxFileInputStream(wxFile& file); wxFileInputStream(wxFile& file);
@@ -55,17 +56,14 @@ class WXDLLIMPEXP_BASE wxFileInputStream: public wxInputStream {
DECLARE_NO_COPY_CLASS(wxFileInputStream) DECLARE_NO_COPY_CLASS(wxFileInputStream)
}; };
class WXDLLIMPEXP_BASE wxFileOutputStream: public wxOutputStream { class WXDLLIMPEXP_BASE wxFileOutputStream : public wxOutputStream
{
public: public:
wxFileOutputStream(const wxString& fileName); wxFileOutputStream(const wxString& fileName);
wxFileOutputStream(wxFile& file); wxFileOutputStream(wxFile& file);
wxFileOutputStream(int fd); wxFileOutputStream(int fd);
virtual ~wxFileOutputStream(); virtual ~wxFileOutputStream();
// To solve an ambiguity on GCC
// inline wxOutputStream& Write(const void *buffer, size_t size)
// { return wxOutputStream::Write(buffer, size); }
void Sync(); void Sync();
bool Close() { return m_file_destroy ? m_file->Close() : true; } bool Close() { return m_file_destroy ? m_file->Close() : true; }
wxFileOffset GetLength() const; wxFileOffset GetLength() const;
@@ -100,9 +98,10 @@ private:
// wxFFileStream using wxFFile // wxFFileStream using wxFFile
// ---------------------------------------------------------------------------- // ----------------------------------------------------------------------------
class WXDLLIMPEXP_BASE wxFFileInputStream: public wxInputStream { class WXDLLIMPEXP_BASE wxFFileInputStream : public wxInputStream
{
public: public:
wxFFileInputStream(const wxString& ifileName); wxFFileInputStream(const wxString& fileName, const wxChar *mode = _T("rb"));
wxFFileInputStream(wxFFile& file); wxFFileInputStream(wxFFile& file);
wxFFileInputStream(FILE *file); wxFFileInputStream(FILE *file);
~wxFFileInputStream(); ~wxFFileInputStream();
@@ -125,17 +124,14 @@ class WXDLLIMPEXP_BASE wxFFileInputStream: public wxInputStream {
DECLARE_NO_COPY_CLASS(wxFFileInputStream) DECLARE_NO_COPY_CLASS(wxFFileInputStream)
}; };
class WXDLLIMPEXP_BASE wxFFileOutputStream: public wxOutputStream { class WXDLLIMPEXP_BASE wxFFileOutputStream : public wxOutputStream
{
public: public:
wxFFileOutputStream(const wxString& fileName); wxFFileOutputStream(const wxString& fileName, const wxChar *mode = _T("w+b"));
wxFFileOutputStream(wxFFile& file); wxFFileOutputStream(wxFFile& file);
wxFFileOutputStream(FILE *file); wxFFileOutputStream(FILE *file);
virtual ~wxFFileOutputStream(); virtual ~wxFFileOutputStream();
// To solve an ambiguity on GCC
// inline wxOutputStream& Write(const void *buffer, size_t size)
// { return wxOutputStream::Write(buffer, size); }
void Sync(); void Sync();
bool Close() { return m_file_destroy ? m_file->Close() : true; } bool Close() { return m_file_destroy ? m_file->Close() : true; }
wxFileOffset GetLength() const; wxFileOffset GetLength() const;
@@ -166,16 +162,6 @@ private:
DECLARE_NO_COPY_CLASS(wxFFileStream) DECLARE_NO_COPY_CLASS(wxFFileStream)
}; };
#endif #endif // wxUSE_STREAMS && wxUSE_FILE
// wxUSE_STREAMS && wxUSE_FILE
#endif
// _WX_WXFSTREAM_H__
#endif // _WX_WXFSTREAM_H__

View File

@@ -195,18 +195,19 @@ wxFileStream::wxFileStream(const wxString& fileName)
// wxFFileInputStream // wxFFileInputStream
// ---------------------------------------------------------------------------- // ----------------------------------------------------------------------------
wxFFileInputStream::wxFFileInputStream(const wxString& fileName) wxFFileInputStream::wxFFileInputStream(const wxString& fileName,
const wxChar *mode)
: wxInputStream() : wxInputStream()
{ {
m_file = new wxFFile(fileName, _T("rb")); m_file = new wxFFile(fileName, mode);
m_file_destroy = true; m_file_destroy = true;
} }
wxFFileInputStream::wxFFileInputStream() wxFFileInputStream::wxFFileInputStream()
: wxInputStream() : wxInputStream()
{ {
m_file_destroy = false;
m_file = NULL; m_file = NULL;
m_file_destroy = false;
} }
wxFFileInputStream::wxFFileInputStream(wxFFile& file) wxFFileInputStream::wxFFileInputStream(wxFFile& file)
@@ -262,9 +263,10 @@ wxFileOffset wxFFileInputStream::OnSysTell() const
// wxFFileOutputStream // wxFFileOutputStream
// ---------------------------------------------------------------------------- // ----------------------------------------------------------------------------
wxFFileOutputStream::wxFFileOutputStream(const wxString& fileName) wxFFileOutputStream::wxFFileOutputStream(const wxString& fileName,
const wxChar *mode)
{ {
m_file = new wxFFile(fileName, _T("w+b")); m_file = new wxFFile(fileName, mode);
m_file_destroy = true; m_file_destroy = true;
if (!m_file->IsOpened()) if (!m_file->IsOpened())
@@ -287,8 +289,8 @@ wxFFileOutputStream::wxFFileOutputStream(wxFFile& file)
wxFFileOutputStream::wxFFileOutputStream() wxFFileOutputStream::wxFFileOutputStream()
: wxOutputStream() : wxOutputStream()
{ {
m_file_destroy = false;
m_file = NULL; m_file = NULL;
m_file_destroy = false;
} }
wxFFileOutputStream::wxFFileOutputStream(FILE *file) wxFFileOutputStream::wxFFileOutputStream(FILE *file)
@@ -348,6 +350,5 @@ wxFFileStream::wxFFileStream(const wxString& fileName)
wxFFileOutputStream::m_file = wxFFileInputStream::m_file; wxFFileOutputStream::m_file = wxFFileInputStream::m_file;
} }
#endif #endif // wxUSE_STREAMS && wxUSE_FILE
// wxUSE_STREAMS && wxUSE_FILE