casacore
Loading...
Searching...
No Matches
casacore::CanonicalIO Class Reference

More...

#include <CanonicalIO.h>

Public Member Functions

 CanonicalIO (const std::shared_ptr< ByteIO > &byteIO, uInt bufferLength=4096)
 Constructor.
 
 CanonicalIO (const CanonicalIO &canonicalIO)
 The copy constructor uses reference semantics.
 
CanonicalIOoperator= (const CanonicalIO &canonicalIO)
 The assignment operator uses reference semantics.
 
 ~CanonicalIO ()
 Destructor, deletes allocated memory.
 
virtual size_t write (size_t nvalues, const Bool *value)
 Convert the values and write them to the ByteIO object.
 
virtual size_t write (size_t nvalues, const Char *data)
 
virtual size_t write (size_t nvalues, const uChar *data)
 
virtual size_t write (size_t nvalues, const Short *data)
 
virtual size_t write (size_t nvalues, const uShort *data)
 
virtual size_t write (size_t nvalues, const Int *data)
 
virtual size_t write (size_t nvalues, const uInt *data)
 
virtual size_t write (size_t nvalues, const Int64 *data)
 
virtual size_t write (size_t nvalues, const uInt64 *data)
 
virtual size_t write (size_t nvalues, const Float *data)
 
virtual size_t write (size_t nvalues, const Double *data)
 
virtual size_t write (size_t nvalues, const Complex *value)
 
virtual size_t write (size_t nvalues, const DComplex *value)
 
virtual size_t write (size_t nvalues, const String *value)
 
virtual size_t read (size_t nvalues, Bool *value)
 Read the values from the ByteIO object and convert them.
 
virtual size_t read (size_t nvalues, Char *data)
 
virtual size_t read (size_t nvalues, uChar *data)
 
virtual size_t read (size_t nvalues, Short *data)
 
virtual size_t read (size_t nvalues, uShort *data)
 
virtual size_t read (size_t nvalues, Int *data)
 
virtual size_t read (size_t nvalues, uInt *data)
 
virtual size_t read (size_t nvalues, Int64 *data)
 
virtual size_t read (size_t nvalues, uInt64 *data)
 
virtual size_t read (size_t nvalues, Float *data)
 
virtual size_t read (size_t nvalues, Double *data)
 
virtual size_t read (size_t nvalues, Complex *value)
 
virtual size_t read (size_t nvalues, DComplex *value)
 
virtual size_t read (size_t nvalues, String *value)
 
- Public Member Functions inherited from casacore::TypeIO
 TypeIO (const std::shared_ptr< ByteIO > &byteIO)
 Constructor.
 
virtual ~TypeIO ()
 
const ByteIObyteIO () const
 Functions to return a reference to the ByteIO class.
 
ByteIObyteIO ()
 
Int64 seek (Int64 offset, ByteIO::SeekOption=ByteIO::Begin)
 This function sets the position on the given offset.
 
Int64 seek (Int offset, ByteIO::SeekOption=ByteIO::Begin)
 
Bool isReadable () const
 Is the TypeIO stream readable?
 
Bool isWritable () const
 Is the TypeIO stream writable?
 
Bool isSeekable () const
 Is the TypeIO stream seekable?
 

Private Attributes

char * itsBuffer
 
uInt itsBufferLength
 

Additional Inherited Members

- Protected Member Functions inherited from casacore::TypeIO
 TypeIO (const TypeIO &TypeIO)
 The copy constructor uses reference semantics.
 
TypeIOoperator= (const TypeIO &typeIO)
 The assignment operator uses reference semantics.
 
- Protected Attributes inherited from casacore::TypeIO
std::shared_ptr< ByteIOitsByteIO
 This variable keeps a pointer to a ByteIO.
 

Detailed Description

Class for IO in canonical format.

Intended use:

Public interface

Review Status

Reviewed By:
Friso Olnon
Date Reviewed:
1996/11/06
Test programs:
tTypeIO

Prerequisite

Synopsis

CanonicalIO is a specialization of class TypeIO to store data in canonical format.

The class converts the data to/from canonical data and reads/writes them from/into the ByteIO object given at construction time. Conversion is only done when really needed. If not needed, the data is directly read or written.

Canonical format is big-endian IEEE format, where longs are 8 bytes. Bools are stored as bits to be as space-efficient as possible. This means that on a 32-bit SUN or HP conversions only have to be done for Bools and longs. For a DEC-alpha, however, the data will always be converted because it is a little-endian machine.

Definition at line 71 of file CanonicalIO.h.

Constructor & Destructor Documentation

◆ CanonicalIO() [1/2]

casacore::CanonicalIO::CanonicalIO ( const std::shared_ptr< ByteIO > & byteIO,
uInt bufferLength = 4096 )
explicit

Constructor.

The read/write functions will use the given ByteIO object as the data store.

The read and write functions use an intermediate buffer to hold the data in canonical format. For small arrays it uses a fixed buffer with length bufferLength. For arrays not fitting in this buffer, it uses a temporary buffer allocated on the heap.

◆ CanonicalIO() [2/2]

casacore::CanonicalIO::CanonicalIO ( const CanonicalIO & canonicalIO)

The copy constructor uses reference semantics.

◆ ~CanonicalIO()

casacore::CanonicalIO::~CanonicalIO ( )

Destructor, deletes allocated memory.

Member Function Documentation

◆ operator=()

CanonicalIO & casacore::CanonicalIO::operator= ( const CanonicalIO & canonicalIO)

The assignment operator uses reference semantics.

◆ read() [1/14]

virtual size_t casacore::CanonicalIO::read ( size_t nvalues,
Bool * value )
virtual

Read the values from the ByteIO object and convert them.

Bool, complex and String values are handled by the base class.

Reimplemented from casacore::TypeIO.

◆ read() [2/14]

virtual size_t casacore::CanonicalIO::read ( size_t nvalues,
Char * data )
virtual

Implements casacore::TypeIO.

◆ read() [3/14]

virtual size_t casacore::CanonicalIO::read ( size_t nvalues,
Complex * value )
virtual

Reimplemented from casacore::TypeIO.

◆ read() [4/14]

virtual size_t casacore::CanonicalIO::read ( size_t nvalues,
DComplex * value )
virtual

Reimplemented from casacore::TypeIO.

◆ read() [5/14]

virtual size_t casacore::CanonicalIO::read ( size_t nvalues,
Double * data )
virtual

Implements casacore::TypeIO.

◆ read() [6/14]

virtual size_t casacore::CanonicalIO::read ( size_t nvalues,
Float * data )
virtual

Implements casacore::TypeIO.

◆ read() [7/14]

virtual size_t casacore::CanonicalIO::read ( size_t nvalues,
Int * data )
virtual

Implements casacore::TypeIO.

◆ read() [8/14]

virtual size_t casacore::CanonicalIO::read ( size_t nvalues,
Int64 * data )
virtual

Implements casacore::TypeIO.

◆ read() [9/14]

virtual size_t casacore::CanonicalIO::read ( size_t nvalues,
Short * data )
virtual

Implements casacore::TypeIO.

◆ read() [10/14]

virtual size_t casacore::CanonicalIO::read ( size_t nvalues,
String * value )
virtual

Reimplemented from casacore::TypeIO.

◆ read() [11/14]

virtual size_t casacore::CanonicalIO::read ( size_t nvalues,
uChar * data )
virtual

Implements casacore::TypeIO.

◆ read() [12/14]

virtual size_t casacore::CanonicalIO::read ( size_t nvalues,
uInt * data )
virtual

Implements casacore::TypeIO.

◆ read() [13/14]

virtual size_t casacore::CanonicalIO::read ( size_t nvalues,
uInt64 * data )
virtual

Implements casacore::TypeIO.

◆ read() [14/14]

virtual size_t casacore::CanonicalIO::read ( size_t nvalues,
uShort * data )
virtual

Implements casacore::TypeIO.

◆ write() [1/14]

virtual size_t casacore::CanonicalIO::write ( size_t nvalues,
const Bool * value )
virtual

Convert the values and write them to the ByteIO object.

Bool, complex and String values are handled by the base class.

Reimplemented from casacore::TypeIO.

◆ write() [2/14]

virtual size_t casacore::CanonicalIO::write ( size_t nvalues,
const Char * data )
virtual

Implements casacore::TypeIO.

◆ write() [3/14]

virtual size_t casacore::CanonicalIO::write ( size_t nvalues,
const Complex * value )
virtual

Reimplemented from casacore::TypeIO.

◆ write() [4/14]

virtual size_t casacore::CanonicalIO::write ( size_t nvalues,
const DComplex * value )
virtual

Reimplemented from casacore::TypeIO.

◆ write() [5/14]

virtual size_t casacore::CanonicalIO::write ( size_t nvalues,
const Double * data )
virtual

Implements casacore::TypeIO.

◆ write() [6/14]

virtual size_t casacore::CanonicalIO::write ( size_t nvalues,
const Float * data )
virtual

Implements casacore::TypeIO.

◆ write() [7/14]

virtual size_t casacore::CanonicalIO::write ( size_t nvalues,
const Int * data )
virtual

Implements casacore::TypeIO.

◆ write() [8/14]

virtual size_t casacore::CanonicalIO::write ( size_t nvalues,
const Int64 * data )
virtual

Implements casacore::TypeIO.

◆ write() [9/14]

virtual size_t casacore::CanonicalIO::write ( size_t nvalues,
const Short * data )
virtual

Implements casacore::TypeIO.

◆ write() [10/14]

virtual size_t casacore::CanonicalIO::write ( size_t nvalues,
const String * value )
virtual

Reimplemented from casacore::TypeIO.

◆ write() [11/14]

virtual size_t casacore::CanonicalIO::write ( size_t nvalues,
const uChar * data )
virtual

Implements casacore::TypeIO.

◆ write() [12/14]

virtual size_t casacore::CanonicalIO::write ( size_t nvalues,
const uInt * data )
virtual

Implements casacore::TypeIO.

◆ write() [13/14]

virtual size_t casacore::CanonicalIO::write ( size_t nvalues,
const uInt64 * data )
virtual

Implements casacore::TypeIO.

◆ write() [14/14]

virtual size_t casacore::CanonicalIO::write ( size_t nvalues,
const uShort * data )
virtual

Implements casacore::TypeIO.

Member Data Documentation

◆ itsBuffer

char* casacore::CanonicalIO::itsBuffer
private

Definition at line 134 of file CanonicalIO.h.

◆ itsBufferLength

uInt casacore::CanonicalIO::itsBufferLength
private

Definition at line 135 of file CanonicalIO.h.


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