mirror of
https://github.com/dolphin-emu/dolphin.git
synced 2025-07-26 15:49:50 -06:00
Import r67258 of the wxWidgets trunk, which I expect will before
long become wxWidgets 2.9.2, which in turn is expected to be the last 2.9 release before the 3.0 stable release. Since the full wxWidgets distribution is rather large, I have imported only the parts that we use, on a subdirectory basis: art include/wx/*.* include/wx/aui include/wx/cocoa include/wx/generic include/wx/gtk include/wx/meta include/wx/msw include/wx/osx include/wx/persist include/wx/private include/wx/protocol include/wx/unix src/aui src/common src/generic src/gtk src/msw src/osx src/unix git-svn-id: https://dolphin-emu.googlecode.com/svn/trunk@7380 8ced0084-cf51-0410-be5f-012b33b47a6e
This commit is contained in:
256
Externals/wxWidgets3/include/wx/wfstream.h
vendored
Normal file
256
Externals/wxWidgets3/include/wx/wfstream.h
vendored
Normal file
@ -0,0 +1,256 @@
|
||||
/////////////////////////////////////////////////////////////////////////////
|
||||
// Name: wx/wfstream.h
|
||||
// Purpose: File stream classes
|
||||
// Author: Guilhem Lavaux
|
||||
// Modified by:
|
||||
// Created: 11/07/98
|
||||
// RCS-ID: $Id: wfstream.h 62995 2009-12-27 19:39:55Z VZ $
|
||||
// Copyright: (c) Guilhem Lavaux
|
||||
// Licence: wxWindows licence
|
||||
/////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
#ifndef _WX_WXFSTREAM_H__
|
||||
#define _WX_WXFSTREAM_H__
|
||||
|
||||
#include "wx/defs.h"
|
||||
|
||||
#if wxUSE_STREAMS
|
||||
|
||||
#include "wx/object.h"
|
||||
#include "wx/string.h"
|
||||
#include "wx/stream.h"
|
||||
#include "wx/file.h"
|
||||
#include "wx/ffile.h"
|
||||
|
||||
#if wxUSE_FILE
|
||||
|
||||
// ----------------------------------------------------------------------------
|
||||
// wxFileStream using wxFile
|
||||
// ----------------------------------------------------------------------------
|
||||
|
||||
class WXDLLIMPEXP_BASE wxFileInputStream : public wxInputStream
|
||||
{
|
||||
public:
|
||||
wxFileInputStream(const wxString& ifileName);
|
||||
wxFileInputStream(wxFile& file);
|
||||
wxFileInputStream(int fd);
|
||||
virtual ~wxFileInputStream();
|
||||
|
||||
wxFileOffset GetLength() const;
|
||||
|
||||
bool Ok() const { return IsOk(); }
|
||||
virtual bool IsOk() const;
|
||||
bool IsSeekable() const { return m_file->GetKind() == wxFILE_KIND_DISK; }
|
||||
|
||||
protected:
|
||||
wxFileInputStream();
|
||||
|
||||
size_t OnSysRead(void *buffer, size_t size);
|
||||
wxFileOffset OnSysSeek(wxFileOffset pos, wxSeekMode mode);
|
||||
wxFileOffset OnSysTell() const;
|
||||
|
||||
protected:
|
||||
wxFile *m_file;
|
||||
bool m_file_destroy;
|
||||
|
||||
wxDECLARE_NO_COPY_CLASS(wxFileInputStream);
|
||||
};
|
||||
|
||||
class WXDLLIMPEXP_BASE wxFileOutputStream : public wxOutputStream
|
||||
{
|
||||
public:
|
||||
wxFileOutputStream(const wxString& fileName);
|
||||
wxFileOutputStream(wxFile& file);
|
||||
wxFileOutputStream(int fd);
|
||||
virtual ~wxFileOutputStream();
|
||||
|
||||
void Sync();
|
||||
bool Close() { return m_file_destroy ? m_file->Close() : true; }
|
||||
wxFileOffset GetLength() const;
|
||||
|
||||
bool Ok() const { return IsOk(); }
|
||||
virtual bool IsOk() const;
|
||||
bool IsSeekable() const { return m_file->GetKind() == wxFILE_KIND_DISK; }
|
||||
|
||||
protected:
|
||||
wxFileOutputStream();
|
||||
|
||||
size_t OnSysWrite(const void *buffer, size_t size);
|
||||
wxFileOffset OnSysSeek(wxFileOffset pos, wxSeekMode mode);
|
||||
wxFileOffset OnSysTell() const;
|
||||
|
||||
protected:
|
||||
wxFile *m_file;
|
||||
bool m_file_destroy;
|
||||
|
||||
wxDECLARE_NO_COPY_CLASS(wxFileOutputStream);
|
||||
};
|
||||
|
||||
class WXDLLIMPEXP_BASE wxTempFileOutputStream : public wxOutputStream
|
||||
{
|
||||
public:
|
||||
wxTempFileOutputStream(const wxString& fileName);
|
||||
virtual ~wxTempFileOutputStream();
|
||||
|
||||
bool Close() { return Commit(); }
|
||||
WXDLLIMPEXP_INLINE_BASE virtual bool Commit() { return m_file->Commit(); }
|
||||
WXDLLIMPEXP_INLINE_BASE virtual void Discard() { m_file->Discard(); }
|
||||
|
||||
wxFileOffset GetLength() const { return m_file->Length(); }
|
||||
bool IsSeekable() const { return true; }
|
||||
|
||||
protected:
|
||||
size_t OnSysWrite(const void *buffer, size_t size);
|
||||
wxFileOffset OnSysSeek(wxFileOffset pos, wxSeekMode mode)
|
||||
{ return m_file->Seek(pos, mode); }
|
||||
wxFileOffset OnSysTell() const { return m_file->Tell(); }
|
||||
|
||||
private:
|
||||
wxTempFile *m_file;
|
||||
|
||||
wxDECLARE_NO_COPY_CLASS(wxTempFileOutputStream);
|
||||
};
|
||||
|
||||
class WXDLLIMPEXP_BASE wxFileStream : public wxFileInputStream,
|
||||
public wxFileOutputStream
|
||||
{
|
||||
public:
|
||||
wxFileStream(const wxString& fileName);
|
||||
virtual bool IsOk() const;
|
||||
|
||||
// override (some) virtual functions inherited from both classes to resolve
|
||||
// ambiguities (this wouldn't be necessary if wxStreamBase were a virtual
|
||||
// base class but it isn't)
|
||||
|
||||
virtual bool IsSeekable() const
|
||||
{
|
||||
return wxFileInputStream::IsSeekable();
|
||||
}
|
||||
|
||||
virtual wxFileOffset GetLength() const
|
||||
{
|
||||
return wxFileInputStream::GetLength();
|
||||
}
|
||||
|
||||
protected:
|
||||
virtual wxFileOffset OnSysSeek(wxFileOffset pos, wxSeekMode mode)
|
||||
{
|
||||
return wxFileInputStream::OnSysSeek(pos, mode);
|
||||
}
|
||||
|
||||
virtual wxFileOffset OnSysTell() const
|
||||
{
|
||||
return wxFileInputStream::OnSysTell();
|
||||
}
|
||||
|
||||
private:
|
||||
wxDECLARE_NO_COPY_CLASS(wxFileStream);
|
||||
};
|
||||
|
||||
#endif //wxUSE_FILE
|
||||
|
||||
#if wxUSE_FFILE
|
||||
|
||||
// ----------------------------------------------------------------------------
|
||||
// wxFFileStream using wxFFile
|
||||
// ----------------------------------------------------------------------------
|
||||
|
||||
class WXDLLIMPEXP_BASE wxFFileInputStream : public wxInputStream
|
||||
{
|
||||
public:
|
||||
wxFFileInputStream(const wxString& fileName, const wxString& mode = "rb");
|
||||
wxFFileInputStream(wxFFile& file);
|
||||
wxFFileInputStream(FILE *file);
|
||||
virtual ~wxFFileInputStream();
|
||||
|
||||
wxFileOffset GetLength() const;
|
||||
|
||||
bool Ok() const { return IsOk(); }
|
||||
virtual bool IsOk() const;
|
||||
bool IsSeekable() const { return m_file->GetKind() == wxFILE_KIND_DISK; }
|
||||
|
||||
protected:
|
||||
wxFFileInputStream();
|
||||
|
||||
size_t OnSysRead(void *buffer, size_t size);
|
||||
wxFileOffset OnSysSeek(wxFileOffset pos, wxSeekMode mode);
|
||||
wxFileOffset OnSysTell() const;
|
||||
|
||||
protected:
|
||||
wxFFile *m_file;
|
||||
bool m_file_destroy;
|
||||
|
||||
wxDECLARE_NO_COPY_CLASS(wxFFileInputStream);
|
||||
};
|
||||
|
||||
class WXDLLIMPEXP_BASE wxFFileOutputStream : public wxOutputStream
|
||||
{
|
||||
public:
|
||||
wxFFileOutputStream(const wxString& fileName, const wxString& mode = "wb");
|
||||
wxFFileOutputStream(wxFFile& file);
|
||||
wxFFileOutputStream(FILE *file);
|
||||
virtual ~wxFFileOutputStream();
|
||||
|
||||
void Sync();
|
||||
bool Close() { return m_file_destroy ? m_file->Close() : true; }
|
||||
wxFileOffset GetLength() const;
|
||||
|
||||
bool Ok() const { return IsOk(); }
|
||||
virtual bool IsOk() const;
|
||||
bool IsSeekable() const { return m_file->GetKind() == wxFILE_KIND_DISK; }
|
||||
|
||||
protected:
|
||||
wxFFileOutputStream();
|
||||
|
||||
size_t OnSysWrite(const void *buffer, size_t size);
|
||||
wxFileOffset OnSysSeek(wxFileOffset pos, wxSeekMode mode);
|
||||
wxFileOffset OnSysTell() const;
|
||||
|
||||
protected:
|
||||
wxFFile *m_file;
|
||||
bool m_file_destroy;
|
||||
|
||||
wxDECLARE_NO_COPY_CLASS(wxFFileOutputStream);
|
||||
};
|
||||
|
||||
class WXDLLIMPEXP_BASE wxFFileStream : public wxFFileInputStream,
|
||||
public wxFFileOutputStream
|
||||
{
|
||||
public:
|
||||
wxFFileStream(const wxString& fileName, const wxString& mode = "w+b");
|
||||
|
||||
// override some virtual functions to resolve ambiguities, just as in
|
||||
// wxFileStream
|
||||
|
||||
virtual bool IsOk() const;
|
||||
|
||||
virtual bool IsSeekable() const
|
||||
{
|
||||
return wxFFileInputStream::IsSeekable();
|
||||
}
|
||||
|
||||
virtual wxFileOffset GetLength() const
|
||||
{
|
||||
return wxFFileInputStream::GetLength();
|
||||
}
|
||||
|
||||
protected:
|
||||
virtual wxFileOffset OnSysSeek(wxFileOffset pos, wxSeekMode mode)
|
||||
{
|
||||
return wxFFileInputStream::OnSysSeek(pos, mode);
|
||||
}
|
||||
|
||||
virtual wxFileOffset OnSysTell() const
|
||||
{
|
||||
return wxFFileInputStream::OnSysTell();
|
||||
}
|
||||
|
||||
private:
|
||||
wxDECLARE_NO_COPY_CLASS(wxFFileStream);
|
||||
};
|
||||
|
||||
#endif //wxUSE_FFILE
|
||||
|
||||
#endif // wxUSE_STREAMS
|
||||
|
||||
#endif // _WX_WXFSTREAM_H__
|
Reference in New Issue
Block a user