LSST Applications  21.0.0+04719a4bac,21.0.0-1-ga51b5d4+f5e6047307,21.0.0-11-g2b59f77+a9c1acf22d,21.0.0-11-ga42c5b2+86977b0b17,21.0.0-12-gf4ce030+76814010d2,21.0.0-13-g1721dae+760e7a6536,21.0.0-13-g3a573fe+768d78a30a,21.0.0-15-g5a7caf0+f21cbc5713,21.0.0-16-g0fb55c1+b60e2d390c,21.0.0-19-g4cded4ca+71a93a33c0,21.0.0-2-g103fe59+bb20972958,21.0.0-2-g45278ab+04719a4bac,21.0.0-2-g5242d73+3ad5d60fb1,21.0.0-2-g7f82c8f+8babb168e8,21.0.0-2-g8f08a60+06509c8b61,21.0.0-2-g8faa9b5+616205b9df,21.0.0-2-ga326454+8babb168e8,21.0.0-2-gde069b7+5e4aea9c2f,21.0.0-2-gecfae73+1d3a86e577,21.0.0-2-gfc62afb+3ad5d60fb1,21.0.0-25-g1d57be3cd+e73869a214,21.0.0-3-g357aad2+ed88757d29,21.0.0-3-g4a4ce7f+3ad5d60fb1,21.0.0-3-g4be5c26+3ad5d60fb1,21.0.0-3-g65f322c+e0b24896a3,21.0.0-3-g7d9da8d+616205b9df,21.0.0-3-ge02ed75+a9c1acf22d,21.0.0-4-g591bb35+a9c1acf22d,21.0.0-4-g65b4814+b60e2d390c,21.0.0-4-gccdca77+0de219a2bc,21.0.0-4-ge8a399c+6c55c39e83,21.0.0-5-gd00fb1e+05fce91b99,21.0.0-6-gc675373+3ad5d60fb1,21.0.0-64-g1122c245+4fb2b8f86e,21.0.0-7-g04766d7+cd19d05db2,21.0.0-7-gdf92d54+04719a4bac,21.0.0-8-g5674e7b+d1bd76f71f,master-gac4afde19b+a9c1acf22d,w.2021.13
LSST Data Management Base Package
SimpleGenericMap.h
Go to the documentation of this file.
1 // -*- LSST-C++ -*-
2 /*
3  * This file is part of afw.
4  *
5  * Developed for the LSST Data Management System.
6  * This product includes software developed by the LSST Project
7  * (https://www.lsst.org).
8  * See the COPYRIGHT file at the top-level directory of this distribution
9  * for details of code ownership.
10  *
11  * This program is free software: you can redistribute it and/or modify
12  * it under the terms of the GNU General Public License as published by
13  * the Free Software Foundation, either version 3 of the License, or
14  * (at your option) any later version.
15  *
16  * This program is distributed in the hope that it will be useful,
17  * but WITHOUT ANY WARRANTY; without even the implied warranty of
18  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
19  * GNU General Public License for more details.
20  *
21  * You should have received a copy of the GNU General Public License
22  * along with this program. If not, see <https://www.gnu.org/licenses/>.
23  */
24 
25 #ifndef LSST_AFW_TYPEHANDLING_SIMPLEGENERICMAP_H
26 #define LSST_AFW_TYPEHANDLING_SIMPLEGENERICMAP_H
27 
28 #include <exception>
29 #include <sstream>
30 #include <unordered_map>
31 #include <utility>
32 
33 #include "boost/variant.hpp"
34 
36 
37 namespace lsst {
38 namespace afw {
39 namespace typehandling {
40 
49 template <typename K>
51 protected:
52  using typename GenericMap<K>::StorableType;
54 
55 public:
56  SimpleGenericMap() = default;
58  SimpleGenericMap(SimpleGenericMap&&) noexcept = default;
66  SimpleGenericMap(GenericMap<K> const& other) : _storage(_convertStorage(other)), _keyView(other.keys()) {}
67  virtual ~SimpleGenericMap() noexcept = default;
68 
70  std::vector<K> newKeys = other._keyView;
71  _storage = other._storage;
72  // strong exception safety because no exceptions can occur past this point
73  using std::swap;
74  swap(_keyView, newKeys);
75  return *this;
76  }
78  SimpleGenericMap& operator=(GenericMap<K> const& other) {
79  std::vector<K> newKeys = other.keys();
80  // strong exception safety: unordered_map is nothrow move-assignable and
81  // vector is nothrow swappable, so no exceptions can occur after _convertStorage returns
82  _storage = _convertStorage(other);
83  using std::swap;
84  swap(_keyView, newKeys);
85  return *this;
86  }
87 
88  typename GenericMap<K>::size_type size() const noexcept override { return _storage.size(); }
89 
90  bool empty() const noexcept override { return _storage.empty(); }
91 
92  typename GenericMap<K>::size_type max_size() const noexcept override {
93  return std::min(_storage.max_size(), _keyView.max_size());
94  }
95 
96  bool contains(K const& key) const override { return _storage.count(key) > 0; }
97 
98  std::vector<K> const& keys() const noexcept override { return _keyView; }
99 
100  void clear() noexcept override {
101  _storage.clear();
102  _keyView.clear();
103  }
104 
105 protected:
107  try {
108  return _storage.at(key);
109  } catch (std::out_of_range& e) {
110  std::stringstream message;
111  message << "Key not found: " << key;
113  }
114  }
115 
116  bool unsafeInsert(K key, StorableType&& value) override {
117  std::vector<K> newKeys = _keyView;
118  newKeys.emplace_back(key);
119  bool inserted = _storage.emplace(key, std::move(value)).second;
120  // strong exception safety because no exceptions can occur past this point
121  if (inserted) {
122  // _storage did not previously include key, so the key appended to newKeys is unique
123  using std::swap;
124  swap(_keyView, newKeys);
125  }
126  return inserted;
127  }
128 
129  bool unsafeErase(K key) override {
130  std::vector<K> newKeys = _keyView;
131  for (auto it = newKeys.cbegin(); it != newKeys.cend();) {
132  if (*it == key) {
133  it = newKeys.erase(it);
134  } else {
135  ++it;
136  }
137  }
138  // strong exception safety because no exceptions can occur past this point
139  bool erased = _storage.erase(key) > 0;
140  if (erased) {
141  using std::swap;
142  swap(_keyView, newKeys);
143  }
144  return erased;
145  }
146 
147 private:
148  // StorableType is a value, so we might as well use it in the implementation
150  std::vector<K> _keyView;
151  // Class invariant: the elements of _keyView are unique
152  // Class invariant: the elements of _keyView and the keys of _storage are the same
153  // Class invariant: the elements of _keyView are arranged in insertion order, oldest to newest
154 
163  static std::unordered_map<K, StorableType> _convertStorage(GenericMap<K> const& map) {
165  map.apply([&newStorage](K const& key, auto const& value) { newStorage.emplace(key, value); });
166  return newStorage;
167  }
168 };
169 
170 } // namespace typehandling
171 } // namespace afw
172 } // namespace lsst
173 
174 #endif
#define LSST_EXCEPT(type,...)
Create an exception with a given type.
Definition: Exception.h:48
ItemVariant const * other
Definition: Schema.cc:56
Key< U > key
Definition: Schema.cc:281
T at(T... args)
T cbegin(T... args)
Interface for a heterogeneous map.
Definition: GenericMap.h:78
boost::variant< bool, int, long, long long, float, double, std::string, PolymorphicValue, std::shared_ptr< Storable const > > StorableType
The types that can be stored in a map.
Definition: GenericMap.h:358
decltype(_typeToConstRef(std::declval< StorableType >())) ConstValueReference
A type-agnostic reference to the value stored inside the map.
Definition: GenericMap.h:367
auto apply(Visitor &&visitor) const
Apply an operation to each key-value pair in the map.
Definition: GenericMap.h:306
Interface for a GenericMap that allows element addition and removal.
Definition: GenericMap.h:606
A GenericMap that allows insertion and deletion of arbitrary values.
virtual ~SimpleGenericMap() noexcept=default
std::vector< K > const & keys() const noexcept override
Return the set of all keys, without type information.
GenericMap< K >::size_type size() const noexcept override
Return the number of key-value pairs in the map.
void clear() noexcept override
Remove all of the mappings from this map.
SimpleGenericMap(SimpleGenericMap const &other)=default
bool unsafeErase(K key) override
Remove the mapping for a key from this map, if it exists.
bool empty() const noexcept override
Return true if this map contains no key-value pairs.
SimpleGenericMap & operator=(SimpleGenericMap &&) noexcept=default
bool contains(K const &key) const override
Return true if this map contains a mapping whose key has the specified label.
GenericMap< K >::size_type max_size() const noexcept override
Return the maximum number of elements the container is able to hold due to system or library implemen...
ConstValueReference unsafeLookup(K key) const override
Return a reference to the mapped value of the element with key equal to key.
bool unsafeInsert(K key, StorableType &&value) override
Create a new mapping with key equal to key and value equal to value.
SimpleGenericMap(SimpleGenericMap &&) noexcept=default
Reports attempts to access elements outside a valid range of indices.
Definition: Runtime.h:89
T clear(T... args)
T count(T... args)
T emplace_back(T... args)
T emplace(T... args)
T empty(T... args)
T cend(T... args)
T erase(T... args)
T max_size(T... args)
T min(T... args)
T move(T... args)
class[[deprecated("Removed with no replacement (but see lsst::afw::image::TransmissionCurve). Will be " "removed after v22.")]] FilterProperty final
Describe the properties of a Filter (e.g.
Definition: Filter.h:53
void swap(PolymorphicValue &lhs, PolymorphicValue &rhs) noexcept
Swap specialization for PolymorphicValue.
A base class for image defects.
T size(T... args)
T str(T... args)
T swap(T... args)
T throw_with_nested(T... args)