LSST Applications g063fba187b+66a50001ff,g0f08755f38+1a22dc2551,g1653933729+a8ce1bb630,g168dd56ebc+a8ce1bb630,g217e2c1bcf+12e87a5bd8,g246886dfd9+466c7b6c06,g28da252d5a+858b171e04,g2bbee38e9b+404b60ec9b,g2bc492864f+404b60ec9b,g3156d2b45e+6e55a43351,g347aa1857d+404b60ec9b,g35bb328faa+a8ce1bb630,g3a166c0a6a+404b60ec9b,g3e281a1b8c+c5dd892a6c,g414038480c+6b9177ef31,g41af890bb2+70bea58702,g599934f4f4+b8c5400ca5,g781aacb6e4+a8ce1bb630,g7af13505b9+b5b9cefdb8,g80478fca09+c2997882f3,g82479be7b0+8974e6af0f,g858d7b2824+1a22dc2551,g89c8672015+f4add4ffd5,g8f1c07a47a+de51c9b0a5,g9125e01d80+a8ce1bb630,ga5288a1d22+b66f8cf76b,gb58c049af0+d64f4d3760,gc28159a63d+404b60ec9b,gcab2d0539d+66cf1de5d4,gcf0d15dbbd+12cb7e2563,gda6a2b7d83+12cb7e2563,gdaeeff99f8+1711a396fd,ge79ae78c31+404b60ec9b,gef2f8181fd+414189b318,gf0baf85859+c1f95f4921,gf0c06eb49c+1a22dc2551,gfa517265be+1a22dc2551,gfa999e8aa5+17cd334064,v28.0.0.rc2
LSST Data Management Base Package
Loading...
Searching...
No Matches
FunctorKey.h
Go to the documentation of this file.
1// -*- lsst-c++ -*-
2/*
3 * LSST Data Management System
4 * Copyright 2008-2014 LSST Corporation.
5 *
6 * This product includes software developed by the
7 * LSST Project (http://www.lsst.org/).
8 *
9 * This program is free software: you can redistribute it and/or modify
10 * it under the terms of the GNU General Public License as published by
11 * the Free Software Foundation, either version 3 of the License, or
12 * (at your option) any later version.
13 *
14 * This program is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 * GNU General Public License for more details.
18 *
19 * You should have received a copy of the LSST License Statement and
20 * the GNU General Public License along with this program. If not,
21 * see <http://www.lsstcorp.org/LegalNotices/>.
22 */
23#ifndef AFW_TABLE_FunctorKey_h_INCLUDED
24#define AFW_TABLE_FunctorKey_h_INCLUDED
25
26#include "lsst/afw/table/fwd.h"
27#include "lsst/afw/table/Key.h"
28
29namespace lsst {
30namespace afw {
31namespace table {
32
39template <typename T>
41public:
43 using Value = T;
44
45 virtual T get(BaseRecord const& record) const = 0;
46
47 virtual ~OutputFunctorKey() noexcept = default;
48};
49
56template <typename T>
58public:
60 using Value = T;
61
62 virtual void set(BaseRecord& record, T const& value) const = 0;
63
64 virtual ~InputFunctorKey() noexcept = default;
65};
66
73template <typename T>
79
90template <typename T>
92public:
93 virtual T getReference(BaseRecord& record) const = 0;
94
95 virtual ~ReferenceFunctorKey() noexcept = default;
96};
97
108template <typename T>
110public:
111 virtual T getConstReference(BaseRecord const& record) const = 0;
112
114};
115} // namespace table
116} // namespace afw
117} // namespace lsst
118
119#endif // !AFW_TABLE_FunctorKey_h_INCLUDED
Tag types used to declare specialized field types.
Definition misc.h:31
Base class for all records.
Definition BaseRecord.h:31
Base class for objects that can return a const reference to part of a record, but are not a true Key.
Definition FunctorKey.h:109
virtual ~ConstReferenceFunctorKey() noexcept=default
virtual T getConstReference(BaseRecord const &record) const =0
Convenience base class that combines the OutputFunctorKey and InputFunctorKey.
Definition FunctorKey.h:74
T Value
The data type for get and set.
Definition FunctorKey.h:77
Base class for objects that can set a value on a record, but are not a true Key themselves.
Definition FunctorKey.h:57
virtual ~InputFunctorKey() noexcept=default
virtual void set(BaseRecord &record, T const &value) const =0
T Value
The data type for set.
Definition FunctorKey.h:60
Base class for objects that can extract a value from a record, but are not a true Key themselves.
Definition FunctorKey.h:40
T Value
The data type for get.
Definition FunctorKey.h:43
virtual ~OutputFunctorKey() noexcept=default
virtual T get(BaseRecord const &record) const =0
Base class for objects that can return a non-const reference to part of a record, but are not a true ...
Definition FunctorKey.h:91
virtual ~ReferenceFunctorKey() noexcept=default
virtual T getReference(BaseRecord &record) const =0