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
StorableMap.cc
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 #include <unordered_map>
26 #include <utility>
27 
29 
30 namespace lsst {
31 namespace afw {
32 namespace image {
33 namespace detail {
34 
35 StorableMap::StorableMap() = default;
36 StorableMap::StorableMap(StorableMap const& other) = default;
37 StorableMap::StorableMap(StorableMap&& other) = default;
38 StorableMap& StorableMap::operator=(StorableMap const& other) = default;
39 StorableMap& StorableMap::operator=(StorableMap&& other) = default;
40 StorableMap::~StorableMap() noexcept = default;
41 
42 StorableMap::StorableMap(std::initializer_list<value_type> init) : _contents(init){};
43 
44 StorableMap::size_type StorableMap::size() const noexcept { return _contents.size(); }
45 
46 bool StorableMap::empty() const noexcept { return _contents.empty(); }
47 
48 StorableMap::size_type StorableMap::max_size() const noexcept { return _contents.max_size(); }
49 
50 bool StorableMap::contains(std::string const& key) const { return _contents.count(key_type(key)) == 1; }
51 
52 bool StorableMap::operator==(StorableMap const& other) const noexcept { return _contents == other._contents; }
53 
54 void StorableMap::clear() noexcept { _contents.clear(); }
55 
57  return StorableMap::const_iterator(_contents.begin());
58 }
60  return StorableMap::const_iterator(_contents.end());
61 };
62 
65 
66 } // namespace detail
67 } // namespace image
68 } // namespace afw
69 } // namespace lsst
bool empty() const noexcept
Return true if this map contains no key-value pairs.
Definition: StorableMap.cc:46
T empty(T... args)
void clear() noexcept
Remove all of the mappings from this map.
Definition: StorableMap.cc:54
def init()
Definition: tests.py:65
typehandling::Key< std::string, mapped_type > key_type
Definition: StorableMap.h:62
STL namespace.
T end(T... args)
ItemVariant const * other
Definition: Schema.cc:56
StorableMap & operator=(StorableMap const &other)
STL class.
bool operator==(StorableMap const &other) const noexcept
Test for map equality.
Definition: StorableMap.cc:52
size_type max_size() const noexcept
Return the maximum number of elements the container is able to hold due to system or library implemen...
Definition: StorableMap.cc:48
A base class for image defects.
Key< U > key
Definition: Schema.cc:281
_Impl::const_iterator const_iterator
Definition: StorableMap.h:77
T clear(T... args)
A map of Storable supporting strongly-typed access.
Definition: StorableMap.h:59
T count(T... args)
size_type size() const noexcept
Return the number of key-value pairs in the map.
Definition: StorableMap.cc:44
bool contains(std::string const &key) const
Return true if this map contains a mapping whose key has the specified label.
Definition: StorableMap.cc:50
T size(T... args)
T begin(T... args)
iterator end() noexcept
Return an iterator to the element past the end of the map.
Definition: StorableMap.cc:64
T max_size(T... args)
Backwards-compatibility support for depersisting the old Calib (FluxMag0/FluxMag0Err) objects...
iterator begin() noexcept
Return an iterator to the first element of the map.
Definition: StorableMap.cc:63