This CStream derived class allow using a file as a write-only, binary stream.
Definition at line 24 of file io/CFileOutputStream.h.
#include <mrpt/io/CFileOutputStream.h>
Public Types | |
enum | TSeekOrigin { sFromBeginning = 0, sFromCurrent = 1, sFromEnd = 2 } |
Used in CStream::Seek. More... | |
Public Member Functions | |
CFileOutputStream (const std::string &fileName, bool append=false) | |
Constructor. More... | |
CFileOutputStream () | |
Default constructor. More... | |
CFileOutputStream (const CFileOutputStream &)=delete | |
CFileOutputStream & | operator= (const CFileOutputStream &)=delete |
bool | open (const std::string &fileName, bool append=false) |
Open the given file for write. More... | |
void | close () |
Close the stream. More... | |
virtual | ~CFileOutputStream () |
Destructor. More... | |
bool | fileOpenCorrectly () const |
Returns true if the file was open without errors. More... | |
bool | is_open () |
Returns true if the file was open without errors. More... | |
uint64_t | Seek (int64_t Offset, CStream::TSeekOrigin Origin=sFromBeginning) override |
Introduces a pure virtual method for moving to a specified position in the streamed resource. More... | |
uint64_t | getTotalBytesCount () const override |
Method for getting the total number of bytes writen to buffer. More... | |
uint64_t | getPosition () const override |
Method for getting the current cursor position, where 0 is the first byte and TotalBytesCount-1 the last one. More... | |
size_t | Read (void *Buffer, size_t Count) override |
Introduces a pure virtual method responsible for reading from the stream. More... | |
size_t | Write (const void *Buffer, size_t Count) override |
Introduces a pure virtual method responsible for writing to the stream. More... | |
virtual size_t | ReadBufferImmediate (void *Buffer, size_t Count) |
Reads a block of bytes from the stream into Buffer, and returns the amound of bytes actually read, without waiting for more extra bytes to arrive (just those already enqued in the stream). More... | |
virtual int | printf (const char *fmt,...) MRPT_printf_format_check(2 |
Writes a string to the stream in a textual form. More... | |
template<typename CONTAINER_TYPE > | |
virtual int void | printf_vector (const char *fmt, const CONTAINER_TYPE &V, char separator=',') |
Prints a vector in the format [A,B,C,...] using CStream::printf, and the fmt string for each vector element T . More... | |
bool | getline (std::string &out_str) |
Reads from the stream until a ' ' character is found ('\r' characters are ignored). More... | |
Private Attributes | |
std::ofstream | m_of |
The actual output file stream. More... | |
|
inherited |
Used in CStream::Seek.
Enumerator | |
---|---|
sFromBeginning | |
sFromCurrent | |
sFromEnd |
Definition at line 34 of file io/CStream.h.
CFileOutputStream::CFileOutputStream | ( | const std::string & | fileName, |
bool | append = false |
||
) |
Constructor.
fileName | The file to be open in this stream |
append | If set to true, the file will be opened for writing and the current cursor position set at the end of the file. Otherwise, previous contents will be lost. |
std::exception | if the file cannot be opened. |
Definition at line 18 of file CFileOutputStream.cpp.
References MRPT_END, MRPT_START, open(), and THROW_EXCEPTION_FMT.
CFileOutputStream::CFileOutputStream | ( | ) |
Default constructor.
Definition at line 30 of file CFileOutputStream.cpp.
|
delete |
|
virtual |
void CFileOutputStream::close | ( | ) |
Close the stream.
Definition at line 43 of file CFileOutputStream.cpp.
References m_of.
Referenced by open(), and ~CFileOutputStream().
bool CFileOutputStream::fileOpenCorrectly | ( | ) | const |
Returns true if the file was open without errors.
Definition at line 112 of file CFileOutputStream.cpp.
References m_of.
Referenced by mrpt::hwdrivers::CGPSInterface::doProcess(), getTotalBytesCount(), and is_open().
|
inherited |
Reads from the stream until a '
' character is found ('\r' characters are ignored).
Definition at line 69 of file CStream.cpp.
|
overridevirtual |
Method for getting the current cursor position, where 0 is the first byte and TotalBytesCount-1 the last one.
Implements mrpt::io::CStream.
Definition at line 103 of file CFileOutputStream.cpp.
References m_of.
Referenced by Seek().
|
overridevirtual |
Method for getting the total number of bytes writen to buffer.
Implements mrpt::io::CStream.
Definition at line 90 of file CFileOutputStream.cpp.
References fileOpenCorrectly(), and m_of.
|
inline |
Returns true if the file was open without errors.
Definition at line 65 of file io/CFileOutputStream.h.
References fileOpenCorrectly().
bool CFileOutputStream::open | ( | const std::string & | fileName, |
bool | append = false |
||
) |
Open the given file for write.
fileName | The file to be open in this stream |
append | If set to true, the file will be opened for writing and the current cursor position set at the end of the file. Otherwise, previous contents will be lost. |
Definition at line 31 of file CFileOutputStream.cpp.
Referenced by CFileOutputStream(), and mrpt::hwdrivers::CGPSInterface::doProcess().
|
delete |
|
virtualinherited |
Writes a string to the stream in a textual form.
Definition at line 30 of file CStream.cpp.
References MRPT_END, MRPT_START, and vsnprintf.
Referenced by mrpt::hmtslam::CTopLCDetector_GridMatching::computeTopologicalObservationModel(), and mrpt::io::CStream::printf_vector().
|
inlineinherited |
Prints a vector in the format [A,B,C,...] using CStream::printf, and the fmt string for each vector element T
.
CONTAINER_TYPE | can be any vector<T>, deque<T> or alike. |
Definition at line 104 of file io/CStream.h.
References mrpt::io::CStream::printf().
Referenced by mrpt::hmtslam::CTopLCDetector_GridMatching::computeTopologicalObservationModel().
|
overridevirtual |
Introduces a pure virtual method responsible for reading from the stream.
Implements mrpt::io::CStream.
Definition at line 49 of file CFileOutputStream.cpp.
References MRPT_UNUSED_PARAM, and THROW_EXCEPTION.
|
inlinevirtualinherited |
Reads a block of bytes from the stream into Buffer, and returns the amound of bytes actually read, without waiting for more extra bytes to arrive (just those already enqued in the stream).
Note that this method will fallback to ReadBuffer() in most CStream classes but in some hardware-related classes.
std::exception | On any error, or if ZERO bytes are read. |
Reimplemented in mrpt::comms::CInterfaceFTDI.
Definition at line 64 of file io/CStream.h.
References mrpt::io::CStream::Read().
|
overridevirtual |
Introduces a pure virtual method for moving to a specified position in the streamed resource.
he Origin parameter indicates how to interpret the Offset parameter. Origin should be one of the following values:
Implements mrpt::io::CStream.
Definition at line 64 of file CFileOutputStream.cpp.
References getPosition(), m_of, mrpt::io::CStream::sFromBeginning, mrpt::io::CStream::sFromCurrent, mrpt::io::CStream::sFromEnd, and THROW_EXCEPTION.
|
overridevirtual |
Introduces a pure virtual method responsible for writing to the stream.
Write attempts to write up to Count bytes to Buffer, and returns the number of bytes actually written.
Implements mrpt::io::CStream.
Definition at line 56 of file CFileOutputStream.cpp.
References m_of.
Referenced by mrpt::hwdrivers::CGPSInterface::doProcess(), and mrpt::io::CMemoryStream::saveBufferToFile().
|
private |
The actual output file stream.
Definition at line 28 of file io/CFileOutputStream.h.
Referenced by close(), fileOpenCorrectly(), getPosition(), getTotalBytesCount(), open(), Seek(), and Write().
Page generated by Doxygen 1.8.17 for MRPT 1.9.9 Git: ad3a9d8ae Tue May 1 23:10:22 2018 -0700 at miƩ 12 jul 2023 10:03:34 CEST |