LSST Applications g0b6bd0c080+a72a5dd7e6,g1182afd7b4+2a019aa3bb,g17e5ecfddb+2b8207f7de,g1d67935e3f+06cf436103,g38293774b4+ac198e9f13,g396055baef+6a2097e274,g3b44f30a73+6611e0205b,g480783c3b1+98f8679e14,g48ccf36440+89c08d0516,g4b93dc025c+98f8679e14,g5c4744a4d9+a302e8c7f0,g613e996a0d+e1c447f2e0,g6c8d09e9e7+25247a063c,g7271f0639c+98f8679e14,g7a9cd813b8+124095ede6,g9d27549199+a302e8c7f0,ga1cf026fa3+ac198e9f13,ga32aa97882+7403ac30ac,ga786bb30fb+7a139211af,gaa63f70f4e+9994eb9896,gabf319e997+ade567573c,gba47b54d5d+94dc90c3ea,gbec6a3398f+06cf436103,gc6308e37c7+07dd123edb,gc655b1545f+ade567573c,gcc9029db3c+ab229f5caf,gd01420fc67+06cf436103,gd877ba84e5+06cf436103,gdb4cecd868+6f279b5b48,ge2d134c3d5+cc4dbb2e3f,ge448b5faa6+86d1ceac1d,gecc7e12556+98f8679e14,gf3ee170dca+25247a063c,gf4ac96e456+ade567573c,gf9f5ea5b4d+ac198e9f13,gff490e6085+8c2580be5c,w.2022.27
LSST Data Management Base Package
Access.h
Go to the documentation of this file.
1// -*- lsst-c++ -*-
2#ifndef AFW_TABLE_DETAIL_Access_h_INCLUDED
3#define AFW_TABLE_DETAIL_Access_h_INCLUDED
4
5#include <cstring>
6
7#include "ndarray/Manager.h"
11
12namespace lsst {
13namespace afw {
14namespace table {
15
16class BaseRecord;
17class BaseTable;
18
19namespace detail {
20
31class Access final {
32public:
34 template <typename T>
36 if (!static_cast<Key<T> const &>(kb).isValid()) {
37 throw LSST_EXCEPT(
40 "Cannot extract subfield key from invalid key of type '%s' "
41 "(most often this is caused by failing to setup centroid or shape slots)") %
43 .str());
44 }
45 return Key<typename Key<T>::Element>(static_cast<Key<T> const &>(kb).getOffset() +
46 n * sizeof(typename Key<T>::Element));
47 }
48
50 template <typename T>
52 if (!static_cast<Key<Array<T> > const &>(kb).isValid()) {
54 (boost::format("Cannot extract subfield key from invalid key of type '%s' ") %
56 .str());
57 }
58 return Key<Array<T> >(static_cast<Key<Array<T> > const &>(kb).getOffset() +
59 begin * sizeof(typename Key<T>::Element),
60 end - begin);
61 }
62
64 template <typename T>
65 static Key<T> makeKey(std::size_t offset) {
66 return Key<T>(offset);
67 }
68
70 template <typename T>
71 static Key<T> makeKey(Field<T> const &field, std::size_t offset) {
72 return Key<T>(offset, field);
73 }
74
76 static Key<Flag> makeKey(std::size_t offset, std::size_t bit) { return Key<Flag>(offset, bit); }
77
79 static Key<std::string> makeKeyString(std::size_t offset, std::size_t size) { return Key<std::string>(offset, size); }
80
82 template <typename T>
84 return Key<Array<T>>(offset, size);
85 }
86
89 schema._edit();
90 schema._impl->_recordSize += bytes;
91 }
92};
93} // namespace detail
94} // namespace table
95} // namespace afw
96} // namespace lsst
97
98#endif // !AFW_TABLE_DETAIL_Access_h_INCLUDED
table::Key< int > field
Definition: ApCorrMap.cc:77
int end
#define LSST_EXCEPT(type,...)
Create an exception with a given type.
Definition: Exception.h:48
table::Schema schema
Definition: python.h:134
table::Key< table::Array< std::uint8_t > > bytes
Definition: python.h:135
Tag types used to declare specialized field types.
Definition: misc.h:31
Key specialization for Flag.
Definition: Flag.h:94
A base class for Key that allows subfield keys to be extracted for some field types.
Definition: KeyBase.h:20
A class used as a handle to a particular field in a table.
Definition: Key.h:53
Defines the fields and offsets for a table.
Definition: Schema.h:51
static Key< typename Key< T >::Element > extractElement(KeyBase< T > const &kb, std::size_t n)
Definition: Access.h:35
static Key< Array< T > > extractRange(KeyBase< Array< T > > const &kb, std::size_t begin, std::size_t end)
Definition: Access.h:51
static Key< T > makeKey(std::size_t offset)
Definition: Access.h:65
static void padSchema(Schema &schema, std::size_t bytes)
Definition: Access.h:88
static Key< T > makeKey(Field< T > const &field, std::size_t offset)
Definition: Access.h:71
static Key< Array< T > > makeKeyArray(std::size_t offset, std::size_t size)
Definition: Access.h:83
static Key< Flag > makeKey(std::size_t offset, std::size_t bit)
Definition: Access.h:76
static Key< std::string > makeKeyString(std::size_t offset, std::size_t size)
Definition: Access.h:79
Reports errors in the logical structure of the program.
Definition: Runtime.h:46
bool isValid
Definition: fits.cc:399
def format(config, name=None, writeSourceLine=True, prefix="", verbose=False)
Definition: history.py:174
A base class for image defects.
T Element
the type of subfields (the same as the type itself for scalars)
Definition: FieldBase.h:45
A description of a field in a table.
Definition: Field.h:24