Disk ARchive  2.4.5
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Macros Groups
Public Member Functions | Protected Member Functions
libdar::zapette Class Reference

zapette emulate a file that is remotely controlled by slave_zapette More...

#include <zapette.hpp>

Inherits libdar::generic_file, libdar::contextual, and libdar::mem_ui.

List of all members.

Public Member Functions

 zapette (user_interaction &dialog, generic_file *input, generic_file *output)
 zapette constructor
bool skip (const infinint &pos)
 skip at the absolute position
bool skip_to_eof ()
 skip to the end of file
bool skip_relative (S_I x)
 skip relatively to the current position
infinint get_position ()
 get the current read/write position
void set_info_status (const std::string &s)
bool is_an_old_start_end_archive () const
const label & get_data_name () const
- Public Member Functions inherited from libdar::generic_file
 generic_file (gf_mode m)
 main constructor
 generic_file (const generic_file &ref)
 copy constructor
void terminate () const
 virtual destructor, this let inherited destructor to be called even from a generic_file pointer to an inherited class
const generic_fileoperator= (const generic_file &ref)
 assignment operator
gf_mode get_mode () const
 retreive the openning mode for this object
U_I read (char *a, U_I size)
 read data from the generic_file
void write (const char *a, U_I size)
 write data to the generic_file
void write (const std::string &arg)
 write a string to the generic_file
S_I read_back (char &a)
 skip back one char, read on char and skip back one char
S_I read_forward (char &a)
 read one char
virtual void copy_to (generic_file &ref)
 copy all data from current position to the object in argument
virtual void copy_to (generic_file &ref, const infinint &crc_size, crc *&value)
 copy all data from the current position to the object in argument and computes a CRC value of the transmitted data
U_32 copy_to (generic_file &ref, U_32 size)
 small copy (up to 4GB) with CRC calculation
infinint copy_to (generic_file &ref, infinint size)
 copy the given amount to the object in argument
bool diff (generic_file &f, const infinint &crc_size, crc *&value)
 compares the contents with the object in argument
void reset_crc (const infinint &width)
 reset CRC on read or writen data
bool crc_status () const
 to known whether CRC calculation is activated or not
crc * get_crc ()
 get CRC of the transfered date since last reset
void sync_write ()
 write any pending data
- Public Member Functions inherited from libdar::contextual
virtual void set_info_status (const std::string &s)
virtual std::string get_info_status () const
virtual bool is_an_old_start_end_archive () const =0
virtual const label & get_data_name () const =0

Protected Member Functions

U_I inherited_read (char *a, U_I size)
 implementation of read() operation
void inherited_write (const char *a, U_I size)
 implementation of the write() operation
void inherited_sync_write ()
 write down any pending data
void inherited_terminate ()
 destructor-like call, except that it is allowed to throw exceptions
- Protected Member Functions inherited from libdar::generic_file
void set_mode (gf_mode x)
bool is_terminated () const
- Protected Member Functions inherited from libdar::mem_ui
 mem_ui (user_interaction &dialog)
 constructor
 mem_ui (const mem_ui &ref)
 the copy constructor
virtual ~mem_ui ()
 destructor
const mem_uioperator= (const mem_ui &ref)
 assignement operator
user_interactionget_ui () const
 get access to the user_interaction cloned object

Detailed Description

zapette emulate a file that is remotely controlled by slave_zapette

class zapette sends order to slave_zapette throw a a first pipe and receive informations or data in return from a second pipe from slave_zapette

Definition at line 57 of file zapette.hpp.


Constructor & Destructor Documentation

libdar::zapette::zapette ( user_interaction dialog,
generic_file input,
generic_file output 
)

zapette constructor

Parameters:
[in]dialogis used to return status information to the user
[in]inputis the pipe (see class tuyau) from which is received the information or data
[in]outputis used to send orders to slave_zapette

Member Function Documentation

U_I libdar::zapette::inherited_read ( char *  a,
U_I  size 
)
protectedvirtual

implementation of read() operation

Parameters:
[in,out]awhere to put the data to read
[in]sizesays how much data to read
Returns:
the exact amount of data read and put into 'a'
Note:
read as much byte as requested, up to end of file stays blocked if not enough data is available and EOF not yet met. May return less data than requested only if EOF as been reached. in other worlds, EOF is reached when returned data is stricly less than the requested data Any problem shall be reported by throwing an exception.

Implements libdar::generic_file.

void libdar::zapette::inherited_sync_write ( )
inlineprotectedvirtual

write down any pending data

Note:
this method is called after read/write mode checking from sync_write() public method;

Implements libdar::generic_file.

Definition at line 83 of file zapette.hpp.

void libdar::zapette::inherited_terminate ( )
protectedvirtual

destructor-like call, except that it is allowed to throw exceptions

Note:
this method must never be called directly but using terminate() instead, generic_file class manages it to never be called more than once

Implements libdar::generic_file.

void libdar::zapette::inherited_write ( const char *  a,
U_I  size 
)
protectedvirtual

implementation of the write() operation

Parameters:
[in]awhat data to write
[in]sizeamount of data to write
Note:
must either write all data or report an error by throwing an exception

Implements libdar::generic_file.

bool libdar::zapette::skip ( const infinint pos)
virtual

skip at the absolute position

Parameters:
[in]posthe offset in byte where next read/write operation must start
Returns:
true if operation was successfull and false if the requested position is not valid (after end of file)
Note:
if requested position is not valid the reading/writing cursor must be set to the closest valid position

Implements libdar::generic_file.


The documentation for this class was generated from the following file: