LSSTApplications  18.0.0+106,18.0.0+50,19.0.0,19.0.0+1,19.0.0+10,19.0.0+11,19.0.0+13,19.0.0+17,19.0.0+2,19.0.0-1-g20d9b18+6,19.0.0-1-g425ff20,19.0.0-1-g5549ca4,19.0.0-1-g580fafe+6,19.0.0-1-g6fe20d0+1,19.0.0-1-g7011481+9,19.0.0-1-g8c57eb9+6,19.0.0-1-gb5175dc+11,19.0.0-1-gdc0e4a7+9,19.0.0-1-ge272bc4+6,19.0.0-1-ge3aa853,19.0.0-10-g448f008b,19.0.0-12-g6990b2c,19.0.0-2-g0d9f9cd+11,19.0.0-2-g3d9e4fb2+11,19.0.0-2-g5037de4,19.0.0-2-gb96a1c4+3,19.0.0-2-gd955cfd+15,19.0.0-3-g2d13df8,19.0.0-3-g6f3c7dc,19.0.0-4-g725f80e+11,19.0.0-4-ga671dab3b+1,19.0.0-4-gad373c5+3,19.0.0-5-ga2acb9c+2,19.0.0-5-gfe96e6c+2,w.2020.01
LSSTDataManagementBasePackage
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) {}
ItemVariant const * other
Definition: Schema.cc:56

◆ 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()); }

◆ 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); }
ItemVariant const * other
Definition: Schema.cc:56

◆ operator=() [1/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 }
ItemVariant const * other
Definition: Schema.cc:56

◆ operator=() [2/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 }
T swap(T... args)
ItemVariant const * other
Definition: Schema.cc:56
void swap(PolymorphicValue &other) noexcept
Exchange the contents of this container and another.

◆ 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 }
ItemVariant const * other
Definition: Schema.cc:56
bool empty() const noexcept
Check whether this object contains a Storable.

◆ 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 }
T swap(T... args)
ItemVariant const * other
Definition: Schema.cc:56
void swap(PolymorphicValue &other) noexcept
Exchange the contents of this container and another.

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: