LSST Applications  21.0.0-172-gfb10e10a+18fedfabac,22.0.0+297cba6710,22.0.0+80564b0ff1,22.0.0+8d77f4f51a,22.0.0+a28f4c53b1,22.0.0+dcf3732eb2,22.0.1-1-g7d6de66+2a20fdde0d,22.0.1-1-g8e32f31+297cba6710,22.0.1-1-geca5380+7fa3b7d9b6,22.0.1-12-g44dc1dc+2a20fdde0d,22.0.1-15-g6a90155+515f58c32b,22.0.1-16-g9282f48+790f5f2caa,22.0.1-2-g92698f7+dcf3732eb2,22.0.1-2-ga9b0f51+7fa3b7d9b6,22.0.1-2-gd1925c9+bf4f0e694f,22.0.1-24-g1ad7a390+a9625a72a8,22.0.1-25-g5bf6245+3ad8ecd50b,22.0.1-25-gb120d7b+8b5510f75f,22.0.1-27-g97737f7+2a20fdde0d,22.0.1-32-gf62ce7b1+aa4237961e,22.0.1-4-g0b3f228+2a20fdde0d,22.0.1-4-g243d05b+871c1b8305,22.0.1-4-g3a563be+32dcf1063f,22.0.1-4-g44f2e3d+9e4ab0f4fa,22.0.1-42-gca6935d93+ba5e5ca3eb,22.0.1-5-g15c806e+85460ae5f3,22.0.1-5-g58711c4+611d128589,22.0.1-5-g75bb458+99c117b92f,22.0.1-6-g1c63a23+7fa3b7d9b6,22.0.1-6-g50866e6+84ff5a128b,22.0.1-6-g8d3140d+720564cf76,22.0.1-6-gd805d02+cc5644f571,22.0.1-8-ge5750ce+85460ae5f3,master-g6e05de7fdc+babf819c66,master-g99da0e417a+8d77f4f51a,w.2021.48
LSST Data Management Base Package
Public Types | Public Member Functions | Static Public Member Functions | Protected Member Functions | Static Protected Member Functions | Friends | List of all members
lsst::afw::table::Field< T > Struct Template Reference

A description of a field in a table. More...

#include <Field.h>

Inheritance diagram for lsst::afw::table::Field< T >:
lsst::afw::table::FieldBase< T >

Public Types

using Element = typename FieldBase< T >::Element
 Type used to store field data in the table (a field may have multiple elements). More...
 
using Value = T
 the type returned by BaseRecord::get More...
 
using Reference = T &
 the type returned by BaseRecord::operator[] (non-const) More...
 
using ConstReference = const T &
 the type returned by BaseRecord::operator[] (const) More...
 

Public Member Functions

 Field (std::string const &name, std::string const &doc, std::string const &units="", FieldBase< T > const &size=FieldBase< T >())
 Construct a new field. More...
 
 Field (std::string const &name, std::string const &doc, FieldBase< T > const &size)
 Construct a new field. More...
 
 Field (Field const &)=default
 
 Field (Field &&) noexcept=default
 
Fieldoperator= (Field const &)=default
 
Fieldoperator= (Field &&) noexcept=default
 
 ~Field () noexcept=default
 
std::string const & getName () const noexcept
 Return the name of the field. More...
 
std::string const & getDoc () const noexcept
 Return the documentation for the field. More...
 
std::string const & getUnits () const noexcept
 Return the units for the field. More...
 
Field< T > copyRenamed (std::string const &newName) const
 Return a new Field with a new name and other properties the same as this. More...
 
std::size_t getElementCount () const noexcept
 Return the number of subfield elements (always one for scalars). More...
 

Static Public Member Functions

static std::string getTypeString ()
 Return a string description of the field type. More...
 

Protected Member Functions

void stream (std::ostream &os) const
 Defines how Fields are printed. More...
 
Reference getReference (Element *p, ndarray::Manager::Ptr const &) const
 Used to implement BaseRecord::operator[] (non-const). More...
 
ConstReference getConstReference (Element const *p, ndarray::Manager::Ptr const &) const
 Used to implement BaseRecord::operator[] (const). More...
 
Value getValue (Element const *p, ndarray::Manager::Ptr const &) const
 Used to implement BaseRecord::get. More...
 
void setValue (Element *p, ndarray::Manager::Ptr const &, Value v) const
 Used to implement BaseRecord::set. More...
 

Static Protected Member Functions

static FieldBase makeDefault () noexcept
 Needed to allow Keys to be default-constructed. More...
 

Friends

std::ostreamoperator<< (std::ostream &os, Field< T > const &field)
 Stringification. More...
 

Detailed Description

template<typename T>
struct lsst::afw::table::Field< T >

A description of a field in a table.

Field combines a type with the field name, documentation, units, and in some cases, the size of the field.

Specializations for different field types are inherited through FieldBase; see the documentation for those specializations for additional information about particular field types.

Definition at line 24 of file Field.h.

Member Typedef Documentation

◆ ConstReference

template<typename T >
using lsst::afw::table::FieldBase< T >::ConstReference = const T &
inherited

the type returned by BaseRecord::operator[] (const)

Definition at line 44 of file FieldBase.h.

◆ Element

template<typename T >
using lsst::afw::table::Field< T >::Element = typename FieldBase<T>::Element

Type used to store field data in the table (a field may have multiple elements).

Definition at line 26 of file Field.h.

◆ Reference

template<typename T >
using lsst::afw::table::FieldBase< T >::Reference = T &
inherited

the type returned by BaseRecord::operator[] (non-const)

Definition at line 43 of file FieldBase.h.

◆ Value

template<typename T >
using lsst::afw::table::FieldBase< T >::Value = T
inherited

the type returned by BaseRecord::get

Definition at line 42 of file FieldBase.h.

Constructor & Destructor Documentation

◆ Field() [1/4]

template<typename T >
lsst::afw::table::Field< T >::Field ( std::string const &  name,
std::string const &  doc,
std::string const &  units = "",
FieldBase< T > const &  size = FieldBase<T>() 
)
inline

Construct a new field.

Parameters
[in]nameName of the field. Schemas provide extra functionality for names whose components are separated by underscores. Field names should be limited to letters, numbers, and underscores.
[in]docDocumentation for the field. Should not contain single-quotes to avoid FITS round-trip problems.
[in]unitsUnits for the field. Should not contain single-quotes to avoid FITS round-trip problems.
[in]sizeSize of the field as an integer, if appropriate. Field types that accept a size have a FieldBase that is implicitly constructable from an integer, so the argument type should be considered to effectively be int; using FieldBase here allows use to throw when the signature does not match the field type.

Definition at line 44 of file Field.h.

46  : FieldBase<T>(size), _name(name), _doc(doc), _units(units) {}
table::Key< std::string > name
Definition: Amplifier.cc:116

◆ Field() [2/4]

template<typename T >
lsst::afw::table::Field< T >::Field ( std::string const &  name,
std::string const &  doc,
FieldBase< T > const &  size 
)
inline

Construct a new field.

Parameters
[in]nameName of the field. Schemas provide extra functionality for names whose components are separated by underscores. Field names should be limited to letters, numbers, and underscores.
[in]docDocumentation for the field.
[in]sizeSize of the field as an integer, if appropriate. Field types that accept a size have a FieldBase that is implicitly constructable from an integer, so the argument type should be considered to effectively be int; using FieldBase here allows use to throw when the signature does not match the field type.

Definition at line 61 of file Field.h.

62  : FieldBase<T>(size), _name(name), _doc(doc), _units() {}

◆ Field() [3/4]

template<typename T >
lsst::afw::table::Field< T >::Field ( Field< T > const &  )
default

◆ Field() [4/4]

template<typename T >
lsst::afw::table::Field< T >::Field ( Field< T > &&  )
defaultnoexcept

◆ ~Field()

template<typename T >
lsst::meas::extensions::psfex::Field::~Field ( )
defaultnoexcept

Definition at line 50 of file fieldImpl.cc.

51 {
52  for (int i = 0; i != impl->next; ++i) {
53  free(impl->wcs[i]); // psfex's wcs isn't quite the same as ours ...
54  impl->wcs[i] = NULL; // ... so don't let psfex free it
55  }
56  field_end(impl);
57  impl = NULL;
58 }
T free(T... args)

Member Function Documentation

◆ copyRenamed()

template<typename T >
Field<T> lsst::afw::table::Field< T >::copyRenamed ( std::string const &  newName) const
inline

Return a new Field with a new name and other properties the same as this.

Definition at line 89 of file Field.h.

89  {
90  return Field<T>(newName, getDoc(), getUnits(), *this);
91  }
std::string const & getUnits() const noexcept
Return the units for the field.
Definition: Field.h:77
std::string const & getDoc() const noexcept
Return the documentation for the field.
Definition: Field.h:74

◆ getConstReference()

template<typename T >
ConstReference lsst::afw::table::FieldBase< T >::getConstReference ( Element const *  p,
ndarray::Manager::Ptr const &   
) const
inlineprotectedinherited

Used to implement BaseRecord::operator[] (const).

Definition at line 78 of file FieldBase.h.

78 { return *p; }

◆ getDoc()

template<typename T >
std::string const& lsst::afw::table::Field< T >::getDoc ( ) const
inlinenoexcept

Return the documentation for the field.

Definition at line 74 of file Field.h.

74 { return _doc; }

◆ getElementCount()

template<typename T >
std::size_t lsst::afw::table::FieldBase< T >::getElementCount ( ) const
inlinenoexceptinherited

Return the number of subfield elements (always one for scalars).

Definition at line 48 of file FieldBase.h.

48 { return 1; }

◆ getName()

template<typename T >
std::string const& lsst::afw::table::Field< T >::getName ( ) const
inlinenoexcept

Return the name of the field.

Definition at line 71 of file Field.h.

71 { return _name; }

◆ getReference()

template<typename T >
Reference lsst::afw::table::FieldBase< T >::getReference ( Element p,
ndarray::Manager::Ptr const &   
) const
inlineprotectedinherited

Used to implement BaseRecord::operator[] (non-const).

Definition at line 75 of file FieldBase.h.

75 { return *p; }

◆ getTypeString()

template<typename T >
std::string lsst::afw::table::FieldBase< T >::getTypeString
staticinherited

Return a string description of the field type.

Definition at line 56 of file FieldBase.cc.

56  {
57  return TypeTraits<T>::getName();
58 }
std::string const & getName() const noexcept
Return a filter's name.
Definition: Filter.h:78

◆ getUnits()

template<typename T >
std::string const& lsst::afw::table::Field< T >::getUnits ( ) const
inlinenoexcept

Return the units for the field.

Definition at line 77 of file Field.h.

77 { return _units; }

◆ getValue()

template<typename T >
Value lsst::afw::table::FieldBase< T >::getValue ( Element const *  p,
ndarray::Manager::Ptr const &   
) const
inlineprotectedinherited

Used to implement BaseRecord::get.

Definition at line 81 of file FieldBase.h.

81 { return *p; }

◆ makeDefault()

template<typename T >
static FieldBase lsst::afw::table::FieldBase< T >::makeDefault ( )
inlinestaticprotectednoexceptinherited

Needed to allow Keys to be default-constructed.

Definition at line 69 of file FieldBase.h.

69 { return FieldBase(); }

◆ operator=() [1/2]

template<typename T >
Field& lsst::afw::table::Field< T >::operator= ( Field< T > &&  )
defaultnoexcept

◆ operator=() [2/2]

template<typename T >
Field& lsst::afw::table::Field< T >::operator= ( Field< T > const &  )
default

◆ setValue()

template<typename T >
void lsst::afw::table::FieldBase< T >::setValue ( Element p,
ndarray::Manager::Ptr const &  ,
Value  v 
) const
inlineprotectedinherited

Used to implement BaseRecord::set.

Definition at line 84 of file FieldBase.h.

84 { *p = v; }

◆ stream()

template<typename T >
void lsst::afw::table::FieldBase< T >::stream ( std::ostream os) const
inlineprotectedinherited

Defines how Fields are printed.

Definition at line 72 of file FieldBase.h.

72 {}

Friends And Related Function Documentation

◆ operator<<

template<typename T >
std::ostream& operator<< ( std::ostream os,
Field< T > const &  field 
)
friend

Stringification.

Definition at line 80 of file Field.h.

80  {
81  os << "Field['" << Field<T>::getTypeString() << "'](name=\"" << field.getName() << "\"";
82  if (!field.getDoc().empty()) os << ", doc=\"" << field.getDoc() << "\"";
83  if (!field.getUnits().empty()) os << ", units=\"" << field.getUnits() << "\"";
84  field.stream(os);
85  return os << ")";
86  }
table::Key< int > field
Definition: ApCorrMap.cc:77
std::ostream * os
Definition: Schema.cc:557
static std::string getTypeString()
Return a string description of the field type.
Definition: FieldBase.cc:56

The documentation for this struct was generated from the following files: