Isis 3 Programmer Reference
|
Class for storing an Isis::Table's field information. More...
#include <TableField.h>
Public Types | |
enum | Type { Integer , Double , Text , Real } |
This enum describes the value type for the TableField. More... | |
Public Member Functions | |
TableField (const QString &name, Type type, int size=1) | |
Constructs a TableField object with the given field name, field value type, and field size. | |
TableField (PvlGroup &field) | |
Constructs a TableField object from a PvlGroup. | |
~TableField () | |
Destroys the TableField object. | |
QString | name () const |
Returns the name of the TableField. | |
Type | type () const |
Returns the enumerated value of the TableField value's type. | |
bool | isInteger () const |
Determines whether the field type is Integer. | |
bool | isDouble () const |
Determines whether the field type is Double. | |
bool | isText () const |
Determines whether the field type is Text. | |
bool | isReal () const |
Determines whether the field type is Text. | |
int | bytes () const |
Returns the number of bytes in the field value. | |
int | size () const |
Returns the number of values stored for the field at each record. | |
operator int () const | |
Casts the table field value to int if the type is Integer and the size is. | |
operator double () const | |
Casts the table field value to double if the type is Double and the size is. | |
operator float () const | |
Casts the table field value to float if the type is Real and the size is. | |
operator QString () const | |
Casts the table field value to string if the type is Text. | |
operator std::vector< int > () const | |
Casts the table field value to a vector of ints if the type is Integer. | |
operator std::vector< double > () const | |
Casts the table field value to a vector of doubles if the type is Double. | |
operator std::vector< float > () const | |
Casts the table field value to a vector of floats if the type is Real. | |
void | operator= (const int value) |
Sets field value equal to input if TableField::Type is Integer and size is 1. | |
void | operator= (const double value) |
Sets field value equal to input if TableField::Type is Double and size is 1. | |
void | operator= (const float value) |
Sets field value equal to input if the TableField::Type is Real and the size is 1. | |
void | operator= (const QString &value) |
Sets field value equal to input if the TableField::Type is Text. | |
void | operator= (const std::vector< int > &values) |
Sets field value equal to input if the TableField::Type is Integer and the input vector size matches the field size. | |
void | operator= (const std::vector< double > &values) |
Sets field value equal to the input if the TableField::Type is Double and the input vector size matches the field size. | |
void | operator= (const std::vector< float > &value) |
Sets field value equal to the input if the TableField::Type is Real and the input vector size matches the field size. | |
void | operator= (const char *buf) |
Sets field value equal to the values found in the character string array if the TableField::Type is Text. | |
void | operator= (const void *buf) |
Sets field value equal to the values found in the input binary buffer. | |
PvlGroup | pvlGroup () |
Creates and returns a PvlGroup named "Field" containing the following keywords and their respective values: "Name", "Type", and "Size". | |
Static Public Member Functions | |
static QString | toString (const TableField &field, QString delimiter=",") |
Private Attributes | |
QString | m_name |
Field name. | |
Type | m_type |
Field value type. | |
int | m_size |
Field size. | |
int | m_bytes |
Number of bytes in field. | |
std::vector< int > | m_ivalues |
Vector containing integer field values. | |
std::vector< double > | m_dvalues |
Vector containing double field values. | |
std::vector< float > | m_rvalues |
Vector containing Real field values. | |
QString | m_svalue |
String containing text value of field. | |
Class for storing an Isis::Table's field information.
This class represents the field values of an Isis table. In Isis3, fields correspond to column values. Each TableField object is a single table entry for a column value at a specific row (or record) of the table.
Be careful to note that the size of a field is the number of array values for a single column entry. It is not the number of rows or records of the table.
2005-03-18 Elizabeth Ribelin - Added documentation to the class
2007-05-28 Steven Lambright - Added 4 byte floating point capabilities
2012-10-04 Jeannie Backer - Added accessor method for FieldType. Moved method implementations to cpp file. Changed member variable prefix to m_. Changed methods to lower camel case. Added documentation. Moved PvlGroup from header include to forward declaration. Added includes to cpp and header. Ordered includes and changed methods to lower camel case in the unitTest. Improved test coverage in all categories. Added padding to control statements. Fixes #1169.
2012-11-21 Jeannie Backer - Added documentation and error message if a Text type field is set to a string value that is longer than the number of allowed bytes for the field. References #700.
2015-10-04 Jeannie Backer Improved coding standards. References #1178
Definition at line 47 of file TableField.h.
This enum describes the value type for the TableField.
Definition at line 52 of file TableField.h.
Isis::TableField::TableField | ( | const QString & | name, |
TableField::Type | type, | ||
int | size = 1 ) |
Constructs a TableField object with the given field name, field value type, and field size.
The size defaults to 1 entry value per field.
name | The name of the field. |
type | The type of the field value. |
size | The size of the field. This is the number of values for a single table entry. Defaults to 1. |
Definition at line 25 of file TableField.cpp.
References Double, Integer, m_bytes, m_dvalues, m_ivalues, m_name, m_rvalues, m_size, m_svalue, m_type, name(), Real, size(), Text, and type().
Isis::TableField::TableField | ( | PvlGroup & | field | ) |
Constructs a TableField object from a PvlGroup.
The given group must contain the PvlKeywords "Name", "Size", and "Type". "Size" must be an integer value and valid values for "Type" are "Integer", "Double", "Text", or "Real".
field | PvlGroup containing Name, Size, and Type for new TableField object |
IException::Programmer | - Invalid field type |
Definition at line 59 of file TableField.cpp.
References Double, Integer, m_bytes, m_dvalues, m_ivalues, m_name, m_rvalues, m_size, m_svalue, m_type, Isis::IException::Programmer, Real, and Text.
Isis::TableField::~TableField | ( | ) |
Destroys the TableField object.
Definition at line 89 of file TableField.cpp.
int Isis::TableField::bytes | ( | ) | const |
Returns the number of bytes in the field value.
Definition at line 159 of file TableField.cpp.
References m_bytes.
Referenced by operator=(), Isis::TableRecord::Swap(), and Isis::TableRecord::Unpack().
bool Isis::TableField::isDouble | ( | ) | const |
Determines whether the field type is Double.
Definition at line 132 of file TableField.cpp.
References Double, and m_type.
Referenced by Isis::Blobber::load().
bool Isis::TableField::isInteger | ( | ) | const |
Determines whether the field type is Integer.
Definition at line 122 of file TableField.cpp.
References Integer, and m_type.
Referenced by Isis::Blobber::load().
bool Isis::TableField::isReal | ( | ) | const |
Determines whether the field type is Text.
Definition at line 150 of file TableField.cpp.
bool Isis::TableField::isText | ( | ) | const |
Determines whether the field type is Text.
Definition at line 141 of file TableField.cpp.
QString Isis::TableField::name | ( | ) | const |
Returns the name of the TableField.
Definition at line 97 of file TableField.cpp.
References m_name.
Referenced by TableField().
Isis::TableField::operator double | ( | ) | const |
Casts the table field value to double if the type is Double and the size is.
TableField field("Field 1", FieldType::Double, 1); // The following lines are equivalent double value = double(field); double value = (double) field;
IException::Programmer | - Field is not a Double |
IException::Programmer | - Field has multiple Double values |
Definition at line 217 of file TableField.cpp.
References Double, and Isis::IException::Programmer.
Isis::TableField::operator float | ( | ) | const |
Casts the table field value to float if the type is Real and the size is.
TableField field("Field 1", FieldType::Real, 1); // The following lines are equivalent float value = float(field); float value = (float) field;
IException::Programmer | - Field is not a Real |
IException::Programmer | - Field has multiple Real values |
Definition at line 246 of file TableField.cpp.
References Isis::IException::Programmer, and Real.
Isis::TableField::operator int | ( | ) | const |
Casts the table field value to int if the type is Integer and the size is.
TableField field("Field 1", FieldType::Integer, 1); // The following lines are equivalent int value = int(field); int value = (int) field;
IException::Programmer | - Field is not an Integer |
IException::Programmer | - Field has multiple Integer values |
Definition at line 188 of file TableField.cpp.
References Integer, and Isis::IException::Programmer.
Isis::TableField::operator QString | ( | ) | const |
Casts the table field value to string if the type is Text.
TableField field("Field 1", FieldType::Text, 9); // The following lines are equivalent string value = QString(field); string value = (QString) field;
IException::Programmer | - Field is not a string |
Definition at line 273 of file TableField.cpp.
References Isis::IException::Programmer, and Text.
Isis::TableField::operator std::vector< double > | ( | ) | const |
Casts the table field value to a vector of doubles if the type is Double.
TableField field("Field 1", FieldType::Double, 3); vector<double> values = std::vector<double>(field);
IException::Programmer | - Field is not a Double array |
Definition at line 313 of file TableField.cpp.
References Double, and Isis::IException::Programmer.
Isis::TableField::operator std::vector< float > | ( | ) | const |
Casts the table field value to a vector of floats if the type is Real.
TableField field("Field 1", FieldType::Real, 3); vector<float> values = std::vector<float>(field);
IException::Programmer | - Field is not an Integer array |
Definition at line 333 of file TableField.cpp.
References Isis::IException::Programmer, and Real.
Isis::TableField::operator std::vector< int > | ( | ) | const |
Casts the table field value to a vector of ints if the type is Integer.
TableField field("Field 1", FieldType::Integer, 3); vector<int> values = std::vector<int>(field);
IException::Programmer | - Field is not an Integer array |
Definition at line 293 of file TableField.cpp.
References Integer, and Isis::IException::Programmer.
void Isis::TableField::operator= | ( | const char * | buf | ) |
Sets field value equal to the values found in the character string array if the TableField::Type is Text.
buf | Character array conataining text values to be assigned to the field value. |
IException::Programmer | - Field is not Text |
Definition at line 575 of file TableField.cpp.
References m_name, m_svalue, m_type, Isis::IException::Programmer, and Text.
void Isis::TableField::operator= | ( | const double | value | ) |
Sets field value equal to input if TableField::Type is Double and size is 1.
value | Double to be assigned to field value |
IException::Programmer | - Field is not a Double |
IException::Programmer | - Field has multiple Double values |
Definition at line 374 of file TableField.cpp.
References Double, m_dvalues, m_name, m_size, m_type, Isis::IException::Programmer, and Isis::toString().
void Isis::TableField::operator= | ( | const float | value | ) |
Sets field value equal to input if the TableField::Type is Real and the size is 1.
value | float to be assigned to field value |
IException::Programmer | - Field is not a Real |
IException::Programmer | - Field has multiple Real values |
Definition at line 398 of file TableField.cpp.
References m_name, m_rvalues, m_size, m_type, Isis::IException::Programmer, Real, and Isis::toString().
void Isis::TableField::operator= | ( | const int | value | ) |
Sets field value equal to input if TableField::Type is Integer and size is 1.
value | Integer to be assigned to field value |
IException::Programmer | - Field is not an Integer |
IException::Programmer | - Field has multiple Integer values |
Definition at line 350 of file TableField.cpp.
References Integer, m_ivalues, m_name, m_size, m_type, Isis::IException::Programmer, and Isis::toString().
void Isis::TableField::operator= | ( | const QString & | value | ) |
Sets field value equal to input if the TableField::Type is Text.
value | string to be assigned to field value |
IException::Programmer | - Field is not a string |
Definition at line 420 of file TableField.cpp.
References m_name, m_size, m_svalue, m_type, Isis::IException::Programmer, Text, Isis::toString(), and Isis::IException::Unknown.
void Isis::TableField::operator= | ( | const std::vector< double > & | values | ) |
Sets field value equal to the input if the TableField::Type is Double and the input vector size matches the field size.
values | Double vector of values to be assigned to field value |
IException::Programmer | - Field is not a Double |
IException::Programmer | - Vector is not the correct size |
Definition at line 477 of file TableField.cpp.
References Double, m_dvalues, m_name, m_size, m_type, Isis::IException::Programmer, and Isis::toString().
void Isis::TableField::operator= | ( | const std::vector< float > & | values | ) |
Sets field value equal to the input if the TableField::Type is Real and the input vector size matches the field size.
values | Float vector of values to be assigned to field value |
IException::Programmer | - Field is not a Real |
IException::Programmer | - Vector is not the correct size |
Definition at line 502 of file TableField.cpp.
References m_name, m_rvalues, m_size, m_type, Isis::IException::Programmer, Real, and Isis::toString().
void Isis::TableField::operator= | ( | const std::vector< int > & | values | ) |
Sets field value equal to input if the TableField::Type is Integer and the input vector size matches the field size.
values | Integer vector of values to be assigned to field value |
IException::Programmer | - Field is not an Integer |
IException::Programmer | - Vector is not the correct size |
Definition at line 453 of file TableField.cpp.
References Integer, m_ivalues, m_name, m_size, m_type, Isis::IException::Programmer, and Isis::toString().
void Isis::TableField::operator= | ( | const void * | ibuf | ) |
Sets field value equal to the values found in the input binary buffer.
This method reads the buffer by assuming that the buffer values are stored in the same number of bytes as the TableField::Type.
ibuf | Binary buffer containing values to be assigned to the field value. |
iException::Programmer | - Undefined field type. |
Definition at line 528 of file TableField.cpp.
References bytes(), Double, Integer, m_dvalues, m_ivalues, m_rvalues, m_svalue, m_type, Isis::IException::Programmer, Real, and Text.
PvlGroup Isis::TableField::pvlGroup | ( | ) |
Creates and returns a PvlGroup named "Field" containing the following keywords and their respective values: "Name", "Type", and "Size".
Definition at line 589 of file TableField.cpp.
References Double, Integer, m_name, m_size, m_type, Real, Text, and Isis::toString().
int Isis::TableField::size | ( | ) | const |
Returns the number of values stored for the field at each record.
Definition at line 168 of file TableField.cpp.
References m_size.
Referenced by TableField().
|
static |
Definition at line 610 of file TableField.cpp.
TableField::Type Isis::TableField::type | ( | ) | const |
Returns the enumerated value of the TableField value's type.
Definition at line 112 of file TableField.cpp.
References m_type.
Referenced by TableField().
|
private |
Number of bytes in field.
Definition at line 102 of file TableField.h.
Referenced by bytes(), TableField(), and TableField().
|
private |
Vector containing double field values.
If the field Type is not Double, this vector will be empty.
Definition at line 106 of file TableField.h.
Referenced by operator=(), operator=(), operator=(), TableField(), and TableField().
|
private |
Vector containing integer field values.
If the field Type is not Integer, this vector will be empty.
Definition at line 103 of file TableField.h.
Referenced by operator=(), operator=(), operator=(), TableField(), and TableField().
|
private |
Field name.
Definition at line 98 of file TableField.h.
Referenced by name(), operator=(), operator=(), operator=(), operator=(), operator=(), operator=(), operator=(), operator=(), pvlGroup(), TableField(), and TableField().
|
private |
Vector containing Real field values.
If the field Type is not Real, this vector will be empty.
Definition at line 109 of file TableField.h.
Referenced by operator=(), operator=(), operator=(), TableField(), and TableField().
|
private |
Field size.
This is the number of values per field entry of the table.
Definition at line 100 of file TableField.h.
Referenced by operator=(), operator=(), operator=(), operator=(), operator=(), operator=(), operator=(), pvlGroup(), size(), TableField(), and TableField().
|
private |
String containing text value of field.
If the field Type is not Text, this string will be empty.
Definition at line 112 of file TableField.h.
Referenced by operator=(), operator=(), operator=(), TableField(), and TableField().
|
private |
Field value type.
Definition at line 99 of file TableField.h.
Referenced by isDouble(), isInteger(), isReal(), isText(), operator=(), operator=(), operator=(), operator=(), operator=(), operator=(), operator=(), operator=(), operator=(), pvlGroup(), TableField(), TableField(), and type().