LSST Applications  21.0.0-147-g0e635eb1+1acddb5be5,22.0.0+052faf71bd,22.0.0+1ea9a8b2b2,22.0.0+6312710a6c,22.0.0+729191ecac,22.0.0+7589c3a021,22.0.0+9f079a9461,22.0.1-1-g7d6de66+b8044ec9de,22.0.1-1-g87000a6+536b1ee016,22.0.1-1-g8e32f31+6312710a6c,22.0.1-10-gd060f87+016f7cdc03,22.0.1-12-g9c3108e+df145f6f68,22.0.1-16-g314fa6d+c825727ab8,22.0.1-19-g93a5c75+d23f2fb6d8,22.0.1-19-gb93eaa13+aab3ef7709,22.0.1-2-g8ef0a89+b8044ec9de,22.0.1-2-g92698f7+9f079a9461,22.0.1-2-ga9b0f51+052faf71bd,22.0.1-2-gac51dbf+052faf71bd,22.0.1-2-gb66926d+6312710a6c,22.0.1-2-gcb770ba+09e3807989,22.0.1-20-g32debb5+b8044ec9de,22.0.1-23-gc2439a9a+fb0756638e,22.0.1-3-g496fd5d+09117f784f,22.0.1-3-g59f966b+1e6ba2c031,22.0.1-3-g849a1b8+f8b568069f,22.0.1-3-gaaec9c0+c5c846a8b1,22.0.1-32-g5ddfab5d3+60ce4897b0,22.0.1-4-g037fbe1+64e601228d,22.0.1-4-g8623105+b8044ec9de,22.0.1-5-g096abc9+d18c45d440,22.0.1-5-g15c806e+57f5c03693,22.0.1-7-gba73697+57f5c03693,master-g6e05de7fdc+c1283a92b8,master-g72cdda8301+729191ecac,w.2021.39
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: