2002-01-14 16:40:44 +00:00
|
|
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
|
|
|
%% Name: ffile.tex
|
|
|
|
%% Purpose: wxFFile documentation
|
|
|
|
%% Author: Vadim Zeitlin
|
|
|
|
%% Modified by:
|
|
|
|
%% Created: 14.01.02 (extracted from file.tex)
|
|
|
|
%% RCS-ID: $Id$
|
|
|
|
%% Copyright: (c) Vadim Zeitlin
|
2005-02-22 15:09:56 +00:00
|
|
|
%% License: wxWindows license
|
2002-01-14 16:40:44 +00:00
|
|
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
|
|
|
|
|
|
|
\section{\class{wxFFile}}\label{wxffile}
|
|
|
|
|
|
|
|
wxFFile implements buffered file I/O. This is a very small class designed to
|
|
|
|
minimize the overhead of using it - in fact, there is hardly any overhead at
|
|
|
|
all, but using it brings you automatic error checking and hides differences
|
|
|
|
between platforms and compilers. It wraps inside it a {\tt FILE *} handle used
|
|
|
|
by standard C IO library (also known as {\tt stdio}).
|
|
|
|
|
|
|
|
\wxheading{Derived from}
|
|
|
|
|
|
|
|
None.
|
|
|
|
|
|
|
|
\wxheading{Include files}
|
|
|
|
|
|
|
|
<wx/ffile.h>
|
|
|
|
|
|
|
|
\twocolwidtha{7cm}
|
|
|
|
\begin{twocollist}\itemsep=0pt%
|
|
|
|
\twocolitem{{\bf wxFromStart}}{Count offset from the start of the file}
|
|
|
|
\twocolitem{{\bf wxFromCurrent}}{Count offset from the current position of the file pointer}
|
|
|
|
\twocolitem{{\bf wxFromEnd}}{Count offset from the end of the file (backwards)}
|
|
|
|
\end{twocollist}
|
|
|
|
|
|
|
|
\latexignore{\rtfignore{\wxheading{Members}}}
|
|
|
|
|
2004-02-07 15:43:22 +00:00
|
|
|
|
2004-09-30 11:15:59 +00:00
|
|
|
\membersection{wxFFile::wxFFile}\label{wxffilector}
|
2002-01-14 16:40:44 +00:00
|
|
|
|
|
|
|
\func{}{wxFFile}{\void}
|
|
|
|
|
|
|
|
Default constructor.
|
|
|
|
|
|
|
|
\func{}{wxFFile}{\param{const char*}{ filename}, \param{const char*}{ mode = "r"}}
|
|
|
|
|
|
|
|
Opens a file with the given mode. As there is no way to return whether the
|
|
|
|
operation was successful or not from the constructor you should test the
|
|
|
|
return value of \helpref{IsOpened}{wxffileisopened} to check that it didn't
|
|
|
|
fail.
|
|
|
|
|
|
|
|
\func{}{wxFFile}{\param{FILE*}{ fp}}
|
|
|
|
|
|
|
|
Opens a file with the given file pointer, which has already been opened.
|
|
|
|
|
|
|
|
\wxheading{Parameters}
|
|
|
|
|
|
|
|
\docparam{filename}{The filename.}
|
|
|
|
|
|
|
|
\docparam{mode}{The mode in which to open the file using standard C strings.
|
|
|
|
Note that you should use {\tt "b"} flag if you use binary files under Windows
|
|
|
|
or the results might be unexpected due to automatic newline conversion done
|
|
|
|
for the text files.}
|
|
|
|
|
|
|
|
\docparam{fp}{An existing file descriptor, such as stderr.}
|
|
|
|
|
2004-02-07 15:43:22 +00:00
|
|
|
|
2004-09-30 11:15:59 +00:00
|
|
|
\membersection{wxFFile::\destruct{wxFFile}}\label{wxffiledtor}
|
2002-01-14 16:40:44 +00:00
|
|
|
|
|
|
|
\func{}{\destruct{wxFFile}}{\void}
|
|
|
|
|
|
|
|
Destructor will close the file.
|
|
|
|
|
|
|
|
NB: it is not virtual so you should {\it not} derive from wxFFile!
|
|
|
|
|
2004-02-07 15:43:22 +00:00
|
|
|
|
2002-01-14 16:40:44 +00:00
|
|
|
\membersection{wxFFile::Attach}\label{wxffileattach}
|
|
|
|
|
|
|
|
\func{void}{Attach}{\param{FILE*}{ fp}}
|
|
|
|
|
|
|
|
Attaches an existing file pointer to the wxFFile object.
|
|
|
|
|
|
|
|
The descriptor should be already opened and it will be closed by wxFFile
|
|
|
|
object.
|
|
|
|
|
2004-02-07 15:43:22 +00:00
|
|
|
|
2002-01-14 16:40:44 +00:00
|
|
|
\membersection{wxFFile::Close}\label{wxffileclose}
|
|
|
|
|
|
|
|
\func{bool}{Close}{\void}
|
|
|
|
|
2004-02-07 15:43:22 +00:00
|
|
|
Closes the file and returns \true on success.
|
|
|
|
|
2002-01-14 16:40:44 +00:00
|
|
|
|
|
|
|
\membersection{wxFFile::Detach}\label{wxffiledetach}
|
|
|
|
|
|
|
|
\func{void}{Detach}{\void}
|
|
|
|
|
2004-02-07 15:43:22 +00:00
|
|
|
Get back a file pointer from wxFFile object -- the caller is responsible for closing the file if this
|
|
|
|
descriptor is opened. \helpref{IsOpened()}{wxffileisopened} will return \false after call to Detach().
|
|
|
|
|
2002-01-14 16:40:44 +00:00
|
|
|
|
|
|
|
\membersection{wxFFile::fp}\label{wxffilefp}
|
|
|
|
|
|
|
|
\constfunc{FILE *}{fp}{\void}
|
|
|
|
|
|
|
|
Returns the file pointer associated with the file.
|
|
|
|
|
2004-02-07 15:43:22 +00:00
|
|
|
|
2002-01-14 16:40:44 +00:00
|
|
|
\membersection{wxFFile::Eof}\label{wxffileeof}
|
|
|
|
|
|
|
|
\constfunc{bool}{Eof}{\void}
|
|
|
|
|
2004-02-07 15:43:22 +00:00
|
|
|
Returns \true if the an attempt has been made to read {\it past}
|
2002-01-14 16:40:44 +00:00
|
|
|
the end of the file.
|
|
|
|
|
|
|
|
Note that the behaviour of the file descriptor based class
|
|
|
|
\helpref{wxFile}{wxfile} is different as \helpref{wxFile::Eof}{wxfileeof}
|
2004-02-07 15:43:22 +00:00
|
|
|
will return \true here as soon as the last byte of the file has been
|
2002-01-14 16:40:44 +00:00
|
|
|
read.
|
|
|
|
|
2004-02-07 15:43:22 +00:00
|
|
|
Also note that this method may only be called for opened files and may crash if
|
|
|
|
the file is not opened.
|
|
|
|
|
|
|
|
\wxheading{See also}
|
|
|
|
|
|
|
|
\helpref{IsOpened}{wxffileisopened}
|
|
|
|
|
|
|
|
|
|
|
|
\membersection{wxFFile::Error}\label{wxffileerror}
|
|
|
|
|
|
|
|
Returns \true if an error has occured on this file, similar to the standard
|
|
|
|
\texttt{ferror()} function.
|
|
|
|
|
|
|
|
Please note that this method may only be called for opened files and may crash
|
|
|
|
if the file is not opened.
|
|
|
|
|
|
|
|
\wxheading{See also}
|
|
|
|
|
|
|
|
\helpref{IsOpened}{wxffileisopened}
|
|
|
|
|
|
|
|
|
2002-01-14 16:40:44 +00:00
|
|
|
\membersection{wxFFile::Flush}\label{wxffileflush}
|
|
|
|
|
|
|
|
\func{bool}{Flush}{\void}
|
|
|
|
|
2004-02-07 15:43:22 +00:00
|
|
|
Flushes the file and returns \true on success.
|
|
|
|
|
2002-01-14 16:40:44 +00:00
|
|
|
|
2005-02-12 21:53:51 +00:00
|
|
|
\membersection{wxFFile::GetKind}\label{wxffilegetfilekind}
|
2005-02-11 12:39:03 +00:00
|
|
|
|
2005-02-12 21:53:51 +00:00
|
|
|
\constfunc{wxFileKind}{GetKind}{\void}
|
2005-02-11 12:39:03 +00:00
|
|
|
|
|
|
|
Returns the type of the file. Possible return values are:
|
|
|
|
|
|
|
|
\begin{verbatim}
|
2005-02-12 21:53:51 +00:00
|
|
|
enum wxFileKind
|
2005-02-11 12:39:03 +00:00
|
|
|
{
|
2005-02-12 21:53:51 +00:00
|
|
|
wxFILE_KIND_UNKNOWN,
|
|
|
|
wxFILE_KIND_DISK, // a file supporting seeking to arbitrary offsets
|
|
|
|
wxFILE_KIND_TERMINAL, // a tty
|
|
|
|
wxFILE_KIND_PIPE // a pipe
|
2005-02-11 12:39:03 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
\end{verbatim}
|
|
|
|
|
|
|
|
|
2002-01-14 16:40:44 +00:00
|
|
|
\membersection{wxFFile::IsOpened}\label{wxffileisopened}
|
|
|
|
|
|
|
|
\constfunc{bool}{IsOpened}{\void}
|
|
|
|
|
2004-02-07 15:43:22 +00:00
|
|
|
Returns \true if the file is opened. Most of the methods of this class may only
|
|
|
|
be used for an opened file.
|
|
|
|
|
2002-01-14 16:40:44 +00:00
|
|
|
|
|
|
|
\membersection{wxFFile::Length}\label{wxffilelength}
|
|
|
|
|
2004-12-12 11:53:53 +00:00
|
|
|
\constfunc{wxFileOffset}{Length}{\void}
|
2002-01-14 16:40:44 +00:00
|
|
|
|
|
|
|
Returns the length of the file.
|
|
|
|
|
2004-02-07 15:43:22 +00:00
|
|
|
|
2002-01-14 16:40:44 +00:00
|
|
|
\membersection{wxFFile::Open}\label{wxffileopen}
|
|
|
|
|
|
|
|
\func{bool}{Open}{\param{const char*}{ filename}, \param{const char*}{ mode = "r"}}
|
|
|
|
|
2004-02-07 15:43:22 +00:00
|
|
|
Opens the file, returning \true if successful.
|
2002-01-14 16:40:44 +00:00
|
|
|
|
|
|
|
\wxheading{Parameters}
|
|
|
|
|
|
|
|
\docparam{filename}{The filename.}
|
|
|
|
|
|
|
|
\docparam{mode}{The mode in which to open the file.}
|
|
|
|
|
2004-02-07 15:43:22 +00:00
|
|
|
|
2002-01-14 16:40:44 +00:00
|
|
|
\membersection{wxFFile::Read}\label{wxffileread}
|
|
|
|
|
2004-12-12 11:53:53 +00:00
|
|
|
\func{size\_t}{Read}{\param{void*}{ buffer}, \param{size\_t}{ count}}
|
2002-01-14 16:40:44 +00:00
|
|
|
|
|
|
|
Reads the specified number of bytes into a buffer, returning the actual number read.
|
|
|
|
|
|
|
|
\wxheading{Parameters}
|
|
|
|
|
|
|
|
\docparam{buffer}{A buffer to receive the data.}
|
|
|
|
|
|
|
|
\docparam{count}{The number of bytes to read.}
|
|
|
|
|
|
|
|
\wxheading{Return value}
|
|
|
|
|
|
|
|
The number of bytes read.
|
|
|
|
|
2004-02-07 15:43:22 +00:00
|
|
|
|
2005-02-19 15:53:04 +00:00
|
|
|
\membersection{wxFFile::ReadAll}\label{wxffilereadall}
|
|
|
|
|
|
|
|
\func{bool}{ReadAll}{\param{wxString *}{ str}, \param{wxMBConv\&}{ conv = wxConvUTF8}}
|
|
|
|
|
|
|
|
Reads the entire contents of the file into a string.
|
|
|
|
|
|
|
|
\wxheading{Parameters}
|
|
|
|
|
|
|
|
\docparam{str}{String to read data into.}
|
|
|
|
|
|
|
|
\docparam{conv}{Conversion object to use in Unicode build; by default supposes
|
|
|
|
that file contents is encoded in UTF-8.}
|
|
|
|
|
|
|
|
\wxheading{Return value}
|
|
|
|
|
|
|
|
\true if file was read successfully, \false otherwise.
|
|
|
|
|
|
|
|
|
2002-01-14 16:40:44 +00:00
|
|
|
\membersection{wxFFile::Seek}\label{wxffileseek}
|
|
|
|
|
2004-12-12 11:53:53 +00:00
|
|
|
\func{bool}{Seek}{\param{wxFileOffset }{ofs}, \param{wxSeekMode }{mode = wxFromStart}}
|
2002-01-14 16:40:44 +00:00
|
|
|
|
2004-02-07 15:43:22 +00:00
|
|
|
Seeks to the specified position and returns \true on success.
|
2002-01-14 16:40:44 +00:00
|
|
|
|
|
|
|
\wxheading{Parameters}
|
|
|
|
|
|
|
|
\docparam{ofs}{Offset to seek to.}
|
|
|
|
|
|
|
|
\docparam{mode}{One of {\bf wxFromStart}, {\bf wxFromEnd}, {\bf wxFromCurrent}.}
|
|
|
|
|
2004-02-07 15:43:22 +00:00
|
|
|
|
2002-01-14 16:40:44 +00:00
|
|
|
\membersection{wxFFile::SeekEnd}\label{wxffileseekend}
|
|
|
|
|
2004-12-12 11:53:53 +00:00
|
|
|
\func{bool}{SeekEnd}{\param{wxFileOffset }{ofs = 0}}
|
2002-01-14 16:40:44 +00:00
|
|
|
|
|
|
|
Moves the file pointer to the specified number of bytes before the end of the file
|
2004-02-07 15:43:22 +00:00
|
|
|
and returns \true on success.
|
2002-01-14 16:40:44 +00:00
|
|
|
|
|
|
|
\wxheading{Parameters}
|
|
|
|
|
|
|
|
\docparam{ofs}{Number of bytes before the end of the file.}
|
|
|
|
|
2004-02-07 15:43:22 +00:00
|
|
|
|
2002-01-14 16:40:44 +00:00
|
|
|
\membersection{wxFFile::Tell}\label{wxffiletell}
|
|
|
|
|
2004-12-12 11:53:53 +00:00
|
|
|
\constfunc{wxFileOffset}{Tell}{\void}
|
2002-01-14 16:40:44 +00:00
|
|
|
|
|
|
|
Returns the current position.
|
|
|
|
|
2004-02-07 15:43:22 +00:00
|
|
|
|
2002-01-14 16:40:44 +00:00
|
|
|
\membersection{wxFFile::Write}\label{wxffilewrite}
|
|
|
|
|
|
|
|
\func{size\_t}{Write}{\param{const void*}{ buffer}, \param{size\_t}{ count}}
|
|
|
|
|
|
|
|
Writes the specified number of bytes from a buffer.
|
|
|
|
|
|
|
|
\wxheading{Parameters}
|
|
|
|
|
|
|
|
\docparam{buffer}{A buffer containing the data.}
|
|
|
|
|
|
|
|
\docparam{count}{The number of bytes to write.}
|
|
|
|
|
|
|
|
\wxheading{Return value}
|
|
|
|
|
|
|
|
Number of bytes written.
|
|
|
|
|
2004-02-07 15:43:22 +00:00
|
|
|
|
2002-01-14 16:40:44 +00:00
|
|
|
\membersection{wxFFile::Write}\label{wxffilewrites}
|
|
|
|
|
2003-02-26 19:31:44 +00:00
|
|
|
\func{bool}{Write}{\param{const wxString\& }{s}, \param{wxMBConv\&}{ conv = wxConvUTF8}}
|
2002-01-14 16:40:44 +00:00
|
|
|
|
2004-02-07 15:43:22 +00:00
|
|
|
Writes the contents of the string to the file, returns \true on success.
|
2002-01-14 16:40:44 +00:00
|
|
|
|
2004-05-04 08:27:20 +00:00
|
|
|
The second argument is only meaningful in Unicode build of wxWidgets when
|
2002-01-14 16:40:44 +00:00
|
|
|
{\it conv} is used to convert {\it s} to multibyte representation.
|
|
|
|
|
|
|
|
|