Quick Links:

bal | bbl | bdl | bsl

Public Types | Public Member Functions | Static Public Member Functions | Static Public Attributes

baljsn::EncoderTestEmployee Class Reference

#include <baljsn_encoder_testtypes.h>

List of all members.

Public Types

enum  { ATTRIBUTE_ID_NAME = 0, ATTRIBUTE_ID_HOME_ADDRESS = 1, ATTRIBUTE_ID_AGE = 2 }
enum  { NUM_ATTRIBUTES = 3 }
enum  { ATTRIBUTE_INDEX_NAME = 0, ATTRIBUTE_INDEX_HOME_ADDRESS = 1, ATTRIBUTE_INDEX_AGE = 2 }

Public Member Functions

 EncoderTestEmployee (bslma::Allocator *basicAllocator=0)
 EncoderTestEmployee (const EncoderTestEmployee &original, bslma::Allocator *basicAllocator=0)
 ~EncoderTestEmployee ()
EncoderTestEmployeeoperator= (const EncoderTestEmployee &rhs)
void reset ()
template<class MANIPULATOR >
int manipulateAttributes (MANIPULATOR &manipulator)
template<class MANIPULATOR >
int manipulateAttribute (MANIPULATOR &manipulator, int id)
template<class MANIPULATOR >
int manipulateAttribute (MANIPULATOR &manipulator, const char *name, int nameLength)
bsl::stringname ()
EncoderTestAddresshomeAddress ()
int & age ()
bsl::ostream & print (bsl::ostream &stream, int level=0, int spacesPerLevel=4) const
template<class ACCESSOR >
int accessAttributes (ACCESSOR &accessor) const
template<class ACCESSOR >
int accessAttribute (ACCESSOR &accessor, int id) const
template<class ACCESSOR >
int accessAttribute (ACCESSOR &accessor, const char *name, int nameLength) const
const bsl::stringname () const
const EncoderTestAddresshomeAddress () const
int age () const

Static Public Member Functions

static const bdlat_AttributeInfolookupAttributeInfo (int id)
static const bdlat_AttributeInfolookupAttributeInfo (const char *name, int nameLength)

Static Public Attributes

static const char CLASS_NAME []
static const bdlat_AttributeInfo ATTRIBUTE_INFO_ARRAY []

Member Enumeration Documentation

anonymous enum
Enumerator:
ATTRIBUTE_ID_NAME 
ATTRIBUTE_ID_HOME_ADDRESS 
ATTRIBUTE_ID_AGE 
anonymous enum
Enumerator:
NUM_ATTRIBUTES 
anonymous enum
Enumerator:
ATTRIBUTE_INDEX_NAME 
ATTRIBUTE_INDEX_HOME_ADDRESS 
ATTRIBUTE_INDEX_AGE 

Constructor & Destructor Documentation

baljsn::EncoderTestEmployee::EncoderTestEmployee ( bslma::Allocator basicAllocator = 0  )  [explicit]

Create an object of type EncoderTestEmployee having the default value. Use the optionally specified basicAllocator to supply memory. If basicAllocator is 0, the currently installed default allocator is used.

baljsn::EncoderTestEmployee::EncoderTestEmployee ( const EncoderTestEmployee original,
bslma::Allocator basicAllocator = 0 
)

Create an object of type EncoderTestEmployee having the value of the specified original object. Use the optionally specified basicAllocator to supply memory. If basicAllocator is 0, the currently installed default allocator is used.

baljsn::EncoderTestEmployee::~EncoderTestEmployee (  ) 

Destroy this object.


Member Function Documentation

static const bdlat_AttributeInfo* baljsn::EncoderTestEmployee::lookupAttributeInfo ( int  id  )  [static]

Return attribute information for the attribute indicated by the specified id if the attribute exists, and 0 otherwise.

static const bdlat_AttributeInfo* baljsn::EncoderTestEmployee::lookupAttributeInfo ( const char *  name,
int  nameLength 
) [static]

Return attribute information for the attribute indicated by the specified name of the specified nameLength if the attribute exists, and 0 otherwise.

EncoderTestEmployee& baljsn::EncoderTestEmployee::operator= ( const EncoderTestEmployee rhs  ) 

Assign to this object the value of the specified rhs object.

void baljsn::EncoderTestEmployee::reset (  ) 

Reset this object to the default value (i.e., its value upon default construction).

template<class MANIPULATOR >
int baljsn::EncoderTestEmployee::manipulateAttributes ( MANIPULATOR &  manipulator  ) 

Invoke the specified manipulator sequentially on the address of each (modifiable) attribute of this object, supplying manipulator with the corresponding attribute information structure until such invocation returns a non-zero value. Return the value from the last invocation of manipulator (i.e., the invocation that terminated the sequence).

template<class MANIPULATOR >
int baljsn::EncoderTestEmployee::manipulateAttribute ( MANIPULATOR &  manipulator,
int  id 
)

Invoke the specified manipulator on the address of the (modifiable) attribute indicated by the specified id, supplying manipulator with the corresponding attribute information structure. Return the value returned from the invocation of manipulator if id identifies an attribute of this class, and -1 otherwise.

template<class MANIPULATOR >
int baljsn::EncoderTestEmployee::manipulateAttribute ( MANIPULATOR &  manipulator,
const char *  name,
int  nameLength 
)

Invoke the specified manipulator on the address of the (modifiable) attribute indicated by the specified name of the specified nameLength, supplying manipulator with the corresponding attribute information structure. Return the value returned from the invocation of manipulator if name identifies an attribute of this class, and -1 otherwise.

bsl::string& baljsn::EncoderTestEmployee::name (  ) 

Return a reference to the modifiable "Name" attribute of this object.

EncoderTestAddress& baljsn::EncoderTestEmployee::homeAddress (  ) 

Return a reference to the modifiable "HomeAddress" attribute of this object.

int& baljsn::EncoderTestEmployee::age (  ) 

Return a reference to the modifiable "Age" attribute of this object.

bsl::ostream& baljsn::EncoderTestEmployee::print ( bsl::ostream &  stream,
int  level = 0,
int  spacesPerLevel = 4 
) const

Format this object to the specified output stream at the optionally specified indentation level and return a reference to the modifiable stream. If level is specified, optionally specify spacesPerLevel, the number of spaces per indentation level for this and all of its nested objects. Each line is indented by the absolute value of level * spacesPerLevel. If level is negative, suppress indentation of the first line. If spacesPerLevel is negative, suppress line breaks and format the entire output on one line. If stream is initially invalid, this operation has no effect. Note that a trailing newline is provided in multiline mode only.

template<class ACCESSOR >
int baljsn::EncoderTestEmployee::accessAttributes ( ACCESSOR &  accessor  )  const

Invoke the specified accessor sequentially on each (non-modifiable) attribute of this object, supplying accessor with the corresponding attribute information structure until such invocation returns a non-zero value. Return the value from the last invocation of accessor (i.e., the invocation that terminated the sequence).

template<class ACCESSOR >
int baljsn::EncoderTestEmployee::accessAttribute ( ACCESSOR &  accessor,
int  id 
) const

Invoke the specified accessor on the (non-modifiable) attribute of this object indicated by the specified id, supplying accessor with the corresponding attribute information structure. Return the value returned from the invocation of accessor if id identifies an attribute of this class, and -1 otherwise.

template<class ACCESSOR >
int baljsn::EncoderTestEmployee::accessAttribute ( ACCESSOR &  accessor,
const char *  name,
int  nameLength 
) const

Invoke the specified accessor on the (non-modifiable) attribute of this object indicated by the specified name of the specified nameLength, supplying accessor with the corresponding attribute information structure. Return the value returned from the invocation of accessor if name identifies an attribute of this class, and -1 otherwise.

const bsl::string& baljsn::EncoderTestEmployee::name (  )  const

Return a reference to the non-modifiable "Name" attribute of this object.

const EncoderTestAddress& baljsn::EncoderTestEmployee::homeAddress (  )  const

Return a reference to the non-modifiable "HomeAddress" attribute of this object.

int baljsn::EncoderTestEmployee::age (  )  const

Return a reference to the non-modifiable "Age" attribute of this object.


Member Data Documentation


The documentation for this class was generated from the following file: