#include
Inheritance diagram for OMF::Boolean:
Note that the identity of a Boolean object is calculated on its string value as opposed to its integer value. This is because we assume a Boolean to actually be closer in nature to an enumerated value rather than an integer. Besides, it gives us a nice way of not equating Booleans and Integers.
Public Member Functions |
|
Boolean () | |
Boolean (const std::string value) | |
Boolean (bool value) | |
virtual | ~Boolean () |
const Boolean & | operator= (const std::string &value) |
const Boolean & | operator= (bool value) |
operator bool () const | |
virtual const std::string & | typeCode () const |
operator const std::string & () const | |
operator const char * () const | |
bool | empty () const |
void | clear () |
const std::string & | str () const |
virtual unsigned | hashCode () const |
ModelObject * | metaObject () |
Protected Attributes |
|
bool | _empty |
True indicates a non-value. |
|
std::string | _value |
The string value of the primitive. |
|
|
|
|
|
|
|
The default identity method for primitive types computes an integral hash on the string representation of the object. Derived primitives may overload this method to provide more accurate or efficient hashing capabilities. Note that this method will return the same hash for primitives of different types containing the same value. However, since we don't usually deal with arrays of mixed primitives, this shouldn't really be an issue. Implements OMF::Object. Reimplemented in OMF::Integer, and OMF::UnlimitedNatural. |
|
Return the meta-object of this instance. The meta-object is an instance of the metaclass of this object. For example, the metaclass of UML::Attribute is Model::Class. The metaobject for an instance of UML::Attribute is an instance of Model::Class. This method may force a load of an entire metamodel in order to return the correct object. |
|
|
|
|
|
Reimplemented from OMF::Primitive. |
|
Explicitly cast this object to a string. |
|
The typeCode method returns a textual description of an object's type. This can vary between classifications of objects. For primitives and collections, the names are essentially static. For model objects, enumerations and collections the name of the object is the scoped name of the instantiating class. Note that the names of primitives are not typed. Implements OMF::Object. |
|
True indicates a non-value. |
|
The string value of the primitive. |