libUTL++
utl::Pair Class Reference

Simple container for two objects. More...

#include <Pair.h>

Inheritance diagram for utl::Pair:

Public Member Functions

 Pair (const Object &first, const Object &second, bool firstOwner=true, bool secondOwner=true)
 Constructor. More...
 
 Pair (const Object *first, const Object *second, bool firstOwner=true, bool secondOwner=true)
 Constructor. More...
 
void clear ()
 Disassociate both objects. More...
 
virtual int compare (const Object &rhs) const
 Compare with another object. More...
 
virtual void copy (const Object &rhs)
 Copy another instance. More...
 
virtual void steal (Object &rhs)
 "Steal" the internal representation from another instance. More...
 
virtual void vclone (const Object &rhs)
 Make an exact copy of another instance. More...
 
virtual const ObjectgetKey () const
 Get the key (the first object). More...
 
virtual void serialize (Stream &stream, uint_t io, uint_t mode=ser_default)
 Serialize to or from a stream. More...
 
virtual String toString () const
 Return a string representation of self. More...
 
virtual size_t innerAllocatedSize () const
 Get the "inner" allocated size. More...
 
Objectfirst () const
 Return the first object. More...
 
Objectsecond () const
 Return the second object. More...
 
ObjectgetFirst () const
 Return the first object. More...
 
ObjectgetSecond () const
 Return the second object. More...
 
void setFirst (const Object *first)
 Set the first object. More...
 
void setSecond (const Object *second)
 Set the second object. More...
 
void setFirst (const Object &first)
 Set the first object (make a copy if isFirstOwner()). More...
 
void setSecond (const Object &second)
 Set the second object (make a copy if isSecondOwner()). More...
 
bool isFirstOwner () const
 Return the owner flag for the first object. More...
 
bool isSecondOwner () const
 Return the owner flag for the second object. More...
 
void setFirstOwner (bool firstOwner)
 Set the owner flag for the first object. More...
 
void setSecondOwner (bool secondOwner)
 Set the owner flag for the second object. More...
 
- Public Member Functions inherited from utl::Object
void clear ()
 Revert to initial state. More...
 
virtual void dump (Stream &os, uint_t level=uint_t_max) const
 Dump a human-readable representation of self to the given output stream. More...
 
void dumpWithClassName (Stream &os, uint_t indent=4, uint_t level=uint_t_max) const
 Front-end for dump() that prints the object's class name. More...
 
bool hasKey () const
 Determine whether or not the object has a key. More...
 
virtual const ObjectgetProxiedObject () const
 Get the proxied object (= self if none). More...
 
virtual ObjectgetProxiedObject ()
 Get the proxied object (= self if none). More...
 
virtual size_t hash (size_t size) const
 Get the hash code for the object. More...
 
bool _isA (const RunTimeClass *runTimeClass) const
 Determine whether self's class is a descendent of the given class. More...
 
 operator String () const
 Conversion to String. More...
 
size_t allocatedSize () const
 Get the total allocated size of this object. More...
 
virtual void addOwnedIt (const class FwdIt *it) const
 Notify self that it owns the given iterator. More...
 
virtual void removeOwnedIt (const class FwdIt *it) const
 Notify self that the given owned iterator has been destroyed. More...
 
bool operator< (const Object &rhs) const
 Less-than operator. More...
 
bool operator<= (const Object &rhs) const
 Less-than-or-equal-to operator. More...
 
bool operator> (const Object &rhs) const
 Greater-than operator. More...
 
bool operator>= (const Object &rhs) const
 Greater-than-or-equal-to operator. More...
 
bool operator== (const Object &rhs) const
 Equal-to operator. More...
 
bool operator!= (const Object &rhs) const
 Unequal-to operator. More...
 
void serializeIn (Stream &is, uint_t mode=ser_default)
 Serialize from an input stream. More...
 
void serializeOut (Stream &os, uint_t mode=ser_default) const
 Serialize to an output stream. More...
 
void serializeOutBoxed (Stream &os, uint_t mode=ser_default) const
 Serialize a boxed object to an output stream. More...
 

Additional Inherited Members

- Static Public Member Functions inherited from utl::Object
static ObjectserializeInNullable (Stream &is, uint_t mode=ser_default)
 Serialize a nullptr-able object from an input stream. More...
 
static void serializeOutNullable (const Object *object, Stream &os, uint_t mode=ser_default)
 Serialize a nullptr-able object to an output stream. More...
 
static void serializeNullable (Object *&object, Stream &stream, uint_t io, uint_t mode=ser_default)
 Serialize a nullptr-able object to or from a stream. More...
 
static ObjectserializeInBoxed (Stream &is, uint_t mode=ser_default)
 Serialize a boxed object from an input stream. More...
 
static void serializeBoxed (Object *&object, Stream &stream, uint_t io, uint_t mode=ser_default)
 Serialize a boxed object to or from a stream. More...
 
- Protected Member Functions inherited from utl::FlagsMI
 FlagsMI ()
 Constructor. More...
 
virtual ~FlagsMI ()
 Destructor. More...
 
void copyFlags (const FlagsMI &rhs)
 Copy the given flags. More...
 
void copyFlags (const FlagsMI &rhs, uint_t lsb, uint_t msb)
 Copy (some of) the given flags. More...
 
void copyFlags (uint64_t flags, uint_t lsb, uint_t msb)
 Copy (some of) the given flags. More...
 
bool getFlag (uint_t flagNum) const
 Get a user-defined flag. More...
 
void setFlag (uint_t flagNum, bool val)
 Set a user-defined flag. More...
 
uint64_t getFlagsNumber (uint64_t mask, uint64_t shift=0)
 Get a multi-bit value in the flags data (which is stored as one 64-bit integer). More...
 
void setFlagsNumber (uint64_t mask, uint64_t shift, uint64_t num)
 Set a multi-bit value in the flags data (which is stored as one 64-bit integer). More...
 
uint64_t getFlags () const
 Get the flags. More...
 
void setFlags (uint64_t flags)
 Set the flags. More...
 

Detailed Description

Simple container for two objects.

Pair represents a pair of objects. The first object is designated the key (see getKey()). Pair provides a useful way of associating two objects without writing a special class. When used in conjunction with a container class, Pair can be used to provide a mapping from one set of objects to another.

Author
Adam McKee

Definition at line 25 of file Pair.h.

Constructor & Destructor Documentation

◆ Pair() [1/2]

utl::Pair::Pair ( const Object first,
const Object second,
bool  firstOwner = true,
bool  secondOwner = true 
)

Constructor.

Parameters
firstfirst object
secondsecond object
firstOwnerowner flag for first object (make a copy if true)
secondOwnerowner flag for second object (make a copy if true)

◆ Pair() [2/2]

utl::Pair::Pair ( const Object first,
const Object second,
bool  firstOwner = true,
bool  secondOwner = true 
)

Constructor.

Parameters
firstfirst object
secondsecond object
firstOwnerowner flag for first object
secondOwnerowner flag for second object

Member Function Documentation

◆ clear()

void utl::Pair::clear ( )
inline

Disassociate both objects.

Definition at line 56 of file Pair.h.

References utl::compare(), utl::copy(), utl::ser_default, utl::serialize(), and utl::toString().

◆ compare()

virtual int utl::Pair::compare ( const Object rhs) const
virtual

Compare with another object.

If no overridden version succeeds in doing the comparison, then an attempt will be made to re-start the comparison process using one or both of the objects' keys. Usually, an override of compare() should call the superclass's compare() if it doesn't know how to compare itself with the rhs object.

See also
getKey
Returns
< 0 if self < rhs, 0 if self = rhs, > 0 if self > rhs
Parameters
rhsobject to compare with

Reimplemented from utl::Object.

◆ copy()

virtual void utl::Pair::copy ( const Object rhs)
virtual

Copy another instance.

When you override copy(), you should usually call the superclass's copy().

Parameters
rhsobject to copy

Reimplemented from utl::Object.

◆ steal()

virtual void utl::Pair::steal ( Object rhs)
virtual

"Steal" the internal representation from another instance.

The default implementation just calls vclone(), so you have to override this if you want a "move" capability.

Reimplemented from utl::Object.

◆ vclone()

virtual void utl::Pair::vclone ( const Object rhs)
virtual

Make an exact copy of another instance.

The default implementation just calls copy(), so you have to override this if you want different behavior for copy construction and cloning.

Reimplemented from utl::Object.

◆ getKey()

virtual const Object& utl::Pair::getKey ( ) const
virtual

Get the key (the first object).

Reimplemented from utl::Object.

◆ serialize()

virtual void utl::Pair::serialize ( Stream stream,
uint_t  io,
uint_t  mode = ser_default 
)
virtual

Serialize to or from a stream.

This is the only virtual method for serialization. You must override this in any class that has data to be serialized, and ensure that the superclass's serialize() gets called.

Parameters
streamstream to serialize from/to
iosee utl::io_t
modesee utl::serialize_t

Reimplemented from utl::Object.

◆ toString()

virtual String utl::Pair::toString ( ) const
virtual

Return a string representation of self.

Reimplemented from utl::Object.

◆ innerAllocatedSize()

virtual size_t utl::Pair::innerAllocatedSize ( ) const
virtual

Get the "inner" allocated size.

Reimplemented from utl::Object.

◆ first()

Object* utl::Pair::first ( ) const
inline

Return the first object.

Definition at line 81 of file Pair.h.

◆ second()

Object* utl::Pair::second ( ) const
inline

Return the second object.

Definition at line 88 of file Pair.h.

◆ getFirst()

Object* utl::Pair::getFirst ( ) const
inline

Return the first object.

Definition at line 95 of file Pair.h.

◆ getSecond()

Object* utl::Pair::getSecond ( ) const
inline

Return the second object.

Definition at line 102 of file Pair.h.

◆ setFirst() [1/2]

void utl::Pair::setFirst ( const Object first)

Set the first object.

◆ setSecond() [1/2]

void utl::Pair::setSecond ( const Object second)

Set the second object.

◆ setFirst() [2/2]

void utl::Pair::setFirst ( const Object first)
inline

Set the first object (make a copy if isFirstOwner()).

Definition at line 115 of file Pair.h.

◆ setSecond() [2/2]

void utl::Pair::setSecond ( const Object second)
inline

Set the second object (make a copy if isSecondOwner()).

Definition at line 125 of file Pair.h.

◆ isFirstOwner()

bool utl::Pair::isFirstOwner ( ) const
inline

Return the owner flag for the first object.

Definition at line 135 of file Pair.h.

◆ isSecondOwner()

bool utl::Pair::isSecondOwner ( ) const
inline

Return the owner flag for the second object.

Definition at line 142 of file Pair.h.

◆ setFirstOwner()

void utl::Pair::setFirstOwner ( bool  firstOwner)
inline

Set the owner flag for the first object.

Definition at line 149 of file Pair.h.

◆ setSecondOwner()

void utl::Pair::setSecondOwner ( bool  secondOwner)
inline

Set the owner flag for the second object.

Definition at line 156 of file Pair.h.

References utl::deInit(), and utl::init().


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