LSST Applications  21.0.0-172-gfb10e10a+18fedfabac,22.0.0+297cba6710,22.0.0+80564b0ff1,22.0.0+8d77f4f51a,22.0.0+a28f4c53b1,22.0.0+dcf3732eb2,22.0.1-1-g7d6de66+2a20fdde0d,22.0.1-1-g8e32f31+297cba6710,22.0.1-1-geca5380+7fa3b7d9b6,22.0.1-12-g44dc1dc+2a20fdde0d,22.0.1-15-g6a90155+515f58c32b,22.0.1-16-g9282f48+790f5f2caa,22.0.1-2-g92698f7+dcf3732eb2,22.0.1-2-ga9b0f51+7fa3b7d9b6,22.0.1-2-gd1925c9+bf4f0e694f,22.0.1-24-g1ad7a390+a9625a72a8,22.0.1-25-g5bf6245+3ad8ecd50b,22.0.1-25-gb120d7b+8b5510f75f,22.0.1-27-g97737f7+2a20fdde0d,22.0.1-32-gf62ce7b1+aa4237961e,22.0.1-4-g0b3f228+2a20fdde0d,22.0.1-4-g243d05b+871c1b8305,22.0.1-4-g3a563be+32dcf1063f,22.0.1-4-g44f2e3d+9e4ab0f4fa,22.0.1-42-gca6935d93+ba5e5ca3eb,22.0.1-5-g15c806e+85460ae5f3,22.0.1-5-g58711c4+611d128589,22.0.1-5-g75bb458+99c117b92f,22.0.1-6-g1c63a23+7fa3b7d9b6,22.0.1-6-g50866e6+84ff5a128b,22.0.1-6-g8d3140d+720564cf76,22.0.1-6-gd805d02+cc5644f571,22.0.1-8-ge5750ce+85460ae5f3,master-g6e05de7fdc+babf819c66,master-g99da0e417a+8d77f4f51a,w.2021.48
LSST Data Management Base Package
Public Member Functions | Related Functions | List of all members
lsst::afw::typehandling::PolymorphicValue Class Referencefinal

Container that passes Storable objects by value while preserving type. More...

#include <PolymorphicValue.h>

Public Member Functions

 PolymorphicValue (Storable const &value)
 Create a new object containing a copy of a Storable. More...
 
 ~PolymorphicValue () noexcept
 
bool empty () const noexcept
 Check whether this object contains a Storable. More...
 
std::size_t hash_value () const
 Return a hash of this object (optional operation). More...
 
 PolymorphicValue (PolymorphicValue const &other)
 Try to copy a PolymorphicValue. More...
 
 PolymorphicValue (PolymorphicValue &&other) noexcept
 Try to copy a PolymorphicValue. More...
 
PolymorphicValueoperator= (PolymorphicValue const &other)
 Try to assign a PolymorphicValue. More...
 
PolymorphicValueoperator= (PolymorphicValue &&other) noexcept
 Try to assign a PolymorphicValue. More...
 
void swap (PolymorphicValue &other) noexcept
 Exchange the contents of this container and another. More...
 
 operator Storable & ()
 Return a reference to the internal Storable, if one exists. More...
 
 operator Storable const & () const
 Return a reference to the internal Storable, if one exists. More...
 
Storableget ()
 Return a reference to the internal Storable, if one exists. More...
 
Storable const & get () const
 Return a reference to the internal Storable, if one exists. More...
 
bool operator== (PolymorphicValue const &other) const noexcept
 Test whether the contained Storables are equal. More...
 
bool operator!= (PolymorphicValue const &other) const noexcept
 Test whether the contained Storables are equal. More...
 

Related Functions

(Note that these are not member functions.)

void swap (PolymorphicValue &lhs, PolymorphicValue &rhs) noexcept
 Swap specialization for PolymorphicValue. More...
 

Detailed Description

Container that passes Storable objects by value while preserving type.

This class is implicitly convertible to and from a reference to Storable, but behaves like a value: changing the internal Storable changes the object's state, and copying the object creates a new Storable.

Note
While a PolymorphicValue is always initialized with a Storable, it may become empty if it is the source of a move-construction or move-assignment. Conversion of an empty value to Storable& throws.

Definition at line 52 of file PolymorphicValue.h.

Constructor & Destructor Documentation

◆ PolymorphicValue() [1/3]

lsst::afw::typehandling::PolymorphicValue::PolymorphicValue ( Storable const &  value)

Create a new object containing a copy of a Storable.

Parameters
valuethe value to copy into a PolymorphicValue

Definition at line 33 of file PolymorphicValue.cc.

33 : _value(value.cloneStorable()) {}

◆ ~PolymorphicValue()

lsst::afw::typehandling::PolymorphicValue::~PolymorphicValue ( )
defaultnoexcept

◆ PolymorphicValue() [2/3]

lsst::afw::typehandling::PolymorphicValue::PolymorphicValue ( PolymorphicValue const &  other)

Try to copy a PolymorphicValue.

Parameters
otherthe PolymorphicValue to copy.
Exceptions
UnsupportedOperationExceptionThrown if a copy is required and the object in other does not implement Storable::cloneStorable.

Definition at line 39 of file PolymorphicValue.cc.

40  : _value(other._value ? other._value->cloneStorable() : nullptr) {}

◆ PolymorphicValue() [3/3]

lsst::afw::typehandling::PolymorphicValue::PolymorphicValue ( PolymorphicValue &&  other)
defaultnoexcept

Try to copy a PolymorphicValue.

Parameters
otherthe PolymorphicValue to copy.
Exceptions
UnsupportedOperationExceptionThrown if a copy is required and the object in other does not implement Storable::cloneStorable.

Member Function Documentation

◆ empty()

bool lsst::afw::typehandling::PolymorphicValue::empty ( ) const
noexcept

Check whether this object contains a Storable.

Returns
true if this object has no Storable, false otherwise

Definition at line 62 of file PolymorphicValue.cc.

62 { return !_value; }

◆ get() [1/2]

Storable & lsst::afw::typehandling::PolymorphicValue::get ( )

Return a reference to the internal Storable, if one exists.

Returns
a reference to the internal object
Exceptions
pex::exceptions::LogicErrorThrown if this object is empty.

Definition at line 66 of file PolymorphicValue.cc.

66  {
67  // Both casts are safe; see Effective C++, Item 3
68  return const_cast<Storable&>(static_cast<PolymorphicValue const&>(*this).get());
69 }
PolymorphicValue(Storable const &value)
Create a new object containing a copy of a Storable.

◆ get() [2/2]

Storable const & lsst::afw::typehandling::PolymorphicValue::get ( ) const

Return a reference to the internal Storable, if one exists.

Returns
a reference to the internal object
Exceptions
pex::exceptions::LogicErrorThrown if this object is empty.

Definition at line 70 of file PolymorphicValue.cc.

70  {
71  if (_value) {
72  return *_value;
73  } else {
74  throw LSST_EXCEPT(pex::exceptions::LogicError, "Dereferenced empty PolymorphicValue.");
75  }
76 }
#define LSST_EXCEPT(type,...)
Create an exception with a given type.
Definition: Exception.h:48

◆ hash_value()

std::size_t lsst::afw::typehandling::PolymorphicValue::hash_value ( ) const

Return a hash of this object (optional operation).

Exceptions
UnsupportedOperationExceptionThrown if the internal Storable is not hashable.

Definition at line 87 of file PolymorphicValue.cc.

87 { return std::hash<Storable>()(get()); }
Storable & get()
Return a reference to the internal Storable, if one exists.

◆ operator Storable &()

lsst::afw::typehandling::PolymorphicValue::operator Storable & ( )

Return a reference to the internal Storable, if one exists.

Returns
a reference to the internal object
Exceptions
pex::exceptions::LogicErrorThrown if this object is empty.

Definition at line 64 of file PolymorphicValue.cc.

64 { return get(); }

◆ operator Storable const &()

lsst::afw::typehandling::PolymorphicValue::operator Storable const & ( ) const

Return a reference to the internal Storable, if one exists.

Returns
a reference to the internal object
Exceptions
pex::exceptions::LogicErrorThrown if this object is empty.

◆ operator!=()

bool lsst::afw::typehandling::PolymorphicValue::operator!= ( PolymorphicValue const &  other) const
inlinenoexcept

Test whether the contained Storables are equal.

Empty PolymorphicValues compare equal to each other and unequal to any non-empty PolymorphicValue.

Definition at line 130 of file PolymorphicValue.h.

130 { return !(*this == other); }

◆ operator=() [1/2]

PolymorphicValue & lsst::afw::typehandling::PolymorphicValue::operator= ( PolymorphicValue &&  other)
noexcept

Try to assign a PolymorphicValue.

To preserve the run-time type of the object in other, this method swaps (and possibly copies) the Storables instead of relying on the Storable's operator=.

Parameters
otherthe PolymorphicValue to overwrite this value with.
Exceptions
UnsupportedOperationExceptionThrown if a copy is required and the object in other does not implement Storable::cloneStorable.

Definition at line 51 of file PolymorphicValue.cc.

51  {
52  using std::swap;
53  swap(_value, other._value);
54  return *this;
55 }
void swap(PolymorphicValue &other) noexcept
Exchange the contents of this container and another.
T swap(T... args)

◆ operator=() [2/2]

PolymorphicValue & lsst::afw::typehandling::PolymorphicValue::operator= ( PolymorphicValue const &  other)

Try to assign a PolymorphicValue.

To preserve the run-time type of the object in other, this method swaps (and possibly copies) the Storables instead of relying on the Storable's operator=.

Parameters
otherthe PolymorphicValue to overwrite this value with.
Exceptions
UnsupportedOperationExceptionThrown if a copy is required and the object in other does not implement Storable::cloneStorable.

Definition at line 43 of file PolymorphicValue.cc.

43  {
44  if (other._value) {
45  _value = other._value->cloneStorable();
46  } else {
47  _value.reset();
48  }
49  return *this;
50 }

◆ operator==()

bool lsst::afw::typehandling::PolymorphicValue::operator== ( PolymorphicValue const &  other) const
noexcept

Test whether the contained Storables are equal.

Empty PolymorphicValues compare equal to each other and unequal to any non-empty PolymorphicValue.

Definition at line 78 of file PolymorphicValue.cc.

78  {
79  if (!empty() && !other.empty()) {
80  return get().equals(other.get());
81  } else {
82  // At least one pointer is null; pointer comparison has desired behavior
83  return _value == other._value;
84  }
85 }
bool empty() const noexcept
Check whether this object contains a Storable.
virtual bool equals(Storable const &other) const noexcept
Compare this object to another Storable.
Definition: Storable.cc:48

◆ swap()

void lsst::afw::typehandling::PolymorphicValue::swap ( PolymorphicValue other)
noexcept

Exchange the contents of this container and another.

Definition at line 57 of file PolymorphicValue.cc.

57  {
58  using std::swap;
59  swap(_value, other._value);
60 }

Friends And Related Function Documentation

◆ swap()

void swap ( PolymorphicValue lhs,
PolymorphicValue rhs 
)
related

Swap specialization for PolymorphicValue.

Definition at line 152 of file PolymorphicValue.h.

152 { lhs.swap(rhs); }

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