//%2006//////////////////////////////////////////////////////////////////////// // // Copyright (c) 2000, 2001, 2002 BMC Software; Hewlett-Packard Development // Company, L.P.; IBM Corp.; The Open Group; Tivoli Systems. // Copyright (c) 2003 BMC Software; Hewlett-Packard Development Company, L.P.; // IBM Corp.; EMC Corporation, The Open Group. // Copyright (c) 2004 BMC Software; Hewlett-Packard Development Company, L.P.; // IBM Corp.; EMC Corporation; VERITAS Software Corporation; The Open Group. // Copyright (c) 2005 Hewlett-Packard Development Company, L.P.; IBM Corp.; // EMC Corporation; VERITAS Software Corporation; The Open Group. // Copyright (c) 2006 Hewlett-Packard Development Company, L.P.; IBM Corp.; // EMC Corporation; Symantec Corporation; The Open Group. // // Permission is hereby granted, free of charge, to any person obtaining a copy // of this software and associated documentation files (the "Software"), to // deal in the Software without restriction, including without limitation the // rights to use, copy, modify, merge, publish, distribute, sublicense, and/or // sell copies of the Software, and to permit persons to whom the Software is // furnished to do so, subject to the following conditions: // // THE ABOVE COPYRIGHT NOTICE AND THIS PERMISSION NOTICE SHALL BE INCLUDED IN // ALL COPIES OR SUBSTANTIAL PORTIONS OF THE SOFTWARE. THE SOFTWARE IS PROVIDED // "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT // LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR // PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT // HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN // ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. // //============================================================================== // //%///////////////////////////////////////////////////////////////////////////// #ifndef Pegasus_Value_h #define Pegasus_Value_h #include #include #include #include #include #include #include #include #include PEGASUS_NAMESPACE_BEGIN class CIMValueRep; class CIMObject; #ifdef PEGASUS_USE_EXPERIMENTAL_INTERFACES #ifdef PEGASUS_EMBEDDED_INSTANCE_SUPPORT class CIMInstance; #endif // PEGASUS_EMBEDDED_INSTANCE_SUPPORT #endif // PEGASUS_USE_EXPERIMENTAL_INTERFACES /** The CIMValue class represents a value of any of the CIM data types (see \Ref{CIMType} for a list of valid CIM data types). This class encapsulates a union which holds the current value. The class also has a type field indicating the type of that value. */ class PEGASUS_COMMON_LINKAGE CIMValue { public: /** Constructor - Creates an NULL CIMValue object set to null and with type CIMType:none and !arraytype. */ CIMValue(); /** Constructor - Creates a NULL CIMValue object with the type and array indicator set as specified. @exception TypeMismatchException If the given type is not valid for a CIMValue object. */ CIMValue(CIMType type, Boolean isArray, Uint32 arraySize = 0); /// Constructor. CIMValue(Boolean x); /// Constructor. CIMValue(Uint8 x); /// Constructor. CIMValue(Sint8 x); /// Constructor. CIMValue(Uint16 x); /// Constructor. CIMValue(Sint16 x); /// Constructor. CIMValue(Uint32 x); /// Constructor. CIMValue(Sint32 x); /// Constructor. CIMValue(Uint64 x); /// Constructor. CIMValue(Sint64 x); /// Constructor. CIMValue(Real32 x); /// Constructor. CIMValue(Real64 x); /// Constructor. CIMValue(const Char16& x); /// Constructor. CIMValue(const String& x); /// Constructor. CIMValue(const CIMDateTime& x); /// Constructor. CIMValue(const CIMObjectPath& x); /** Constructor. Note: Constructing a CIMValue with an uninitialized CIMObject is not defined and results in a thrown UninitializedObjectException. Note: The input CIMObject will be cloned before putting it into the value of the constructed CIMValue. This is because CIMObjects use a shared representation model, but we don't want CIMObjects inside a CIMValue to be altered by other external changes. */ CIMValue(const CIMObject& x); /// Constructor. #ifdef PEGASUS_USE_EXPERIMENTAL_INTERFACES #ifdef PEGASUS_EMBEDDED_INSTANCE_SUPPORT CIMValue(const CIMInstance& x); #endif // PEGASUS_EMBEDDED_INSTANCE_SUPPORT #endif // PEGASUS_USE_EXPERIMENTAL_INTERFACES /// Constructor. CIMValue(const Array& x); /// Constructor. CIMValue(const Array& x); /// Constructor. CIMValue(const Array& x); /// Constructor. CIMValue(const Array& x); /// Constructor. CIMValue(const Array& x); /// Constructor. CIMValue(const Array& x); /// Constructor. CIMValue(const Array& x); /// Constructor. CIMValue(const Array& x); /// Constructor. CIMValue(const Array& x); /// Constructor. CIMValue(const Array& x); /// Constructor. CIMValue(const Array& x); /// Constructor. CIMValue(const Array& x); /// Constructor. CIMValue(const Array& x); /// Constructor. CIMValue(const Array& x); /// Constructor. CIMValue(const Array& x); /** Constructor. Note: Constructing a CIMValue with an uninitialized CIMObject anywhere in the input array is not defined and results in a thrown UninitializedObjectException. Note: Each CIMObject in the input Array will be cloned before putting the Array into the value of the constructed CIMValue. This is because CIMObjects use a shared representation model, but we don't want CIMObjects inside a CIMValue to be altered by other external changes. */ CIMValue(const Array& x); /// Constructor. #ifdef PEGASUS_USE_EXPERIMENTAL_INTERFACES #ifdef PEGASUS_EMBEDDED_INSTANCE_SUPPORT CIMValue(const Array& x); #endif // PEGASUS_EMBEDDED_INSTANCE_SUPPORT #endif // PEGASUS_USE_EXPERIMENTAL_INTERFACES /** Constructor. Note: If the input type is CIMObject, it/they will be cloned before putting it into the value of the constructed CIMValue. This is because CIMObjects use a shared representation model, but we don't want CIMObjects inside a CIMValue to be altered by other external changes. */ CIMValue(const CIMValue& x); /// Destructor. ~CIMValue(); /** Operator = Note: If the right hand side type is CIMObject, it/they will be cloned before putting it into the value of the target CIMValue. This is because CIMObjects use a shared representation model, but we don't want CIMObjects inside a CIMValue to be altered by other external changes. */ CIMValue& operator=(const CIMValue& x); /** Assigns one CIMValue object to another CIMValue object. @param x - CIMValue object to be used for assignment. Note: If the input type is CIMObject, it/they will be cloned before putting it into the value of the target CIMValue. This is because CIMObjects use a shared representation model, but we don't want CIMObjects inside a CIMValue to be altered by other external changes. */ void assign(const CIMValue& x); /** Clears the attributes and value of the CIMValue object. */ void clear(); /** Compares the types of two CIMValues. This compares the type field and the array indicators. @return true if both are of the same type and both are either arrays or not, false otherwise.
            CIMValue a(Boolean(true);
            CIMValue b = a;
            if b.typeCompatible(a)
                ...
        
*/ Boolean typeCompatible(const CIMValue& x) const; /** Determines if the value is an array. @return true if the value is an array, false otherwise. */ Boolean isArray() const; /** Determines whether the CIMvalue object is Null. Null is the specific condition where no value has yet been set. If a CIMValue object is Null, any get on that object will create an exception. @return true if the CIMValue object is Null, false otherwise. */ Boolean isNull() const; /** Gets the size of an Array CIMValue. @return The number of entries in the array. */ Uint32 getArraySize() const; /** Gets the CIMType attribute for the CIMValue. @return the CIMType value. */ CIMType getType() const; /** Sets the CIMValue a NULL, but with valid CIMType and array characteristics. @param type - CIMType for this CIMValue. @param isArray - Boolean indicating whether this is an array CIMValue. @param arraySize - Optional parameter indicating the array size.
            CIMValue value;
            value.setNullValue(CIMType::BOOLEAN, false);
        
*/ void setNullValue(CIMType type, Boolean isArray, Uint32 arraySize = 0); /** Sets the type, Array attribute and puts the value provided into the value of the target CIMValue.
            CIMValue x;
            x.set(Uint16(9));
        
@exception UninitializedObjectException If the given type is CIMObject, and the input CIMObject parameter is uninitialized or at least one entry in the Array of CIMObjects is uninitialized. Note: If the input type is CIMObject, it/they will be cloned before putting it into the value of the target CIMValue. This is because CIMObjects use a shared representation model, but we don't want CIMObjects inside a CIMValue to be altered by other external changes. */ void set(Boolean x); /// void set(Uint8 x); /// void set(Sint8 x); /// void set(Uint16 x); /// void set(Sint16 x); /// void set(Uint32 x); /// void set(Sint32 x); /// void set(Uint64 x); /// void set(Sint64 x); /// void set(Real32 x); /// void set(Real64 x); /// void set(const Char16& x); /// void set(const String& x); /// void set(const CIMDateTime& x); /// void set(const CIMObjectPath& x); /// void set(const CIMObject& x); /// #ifdef PEGASUS_USE_EXPERIMENTAL_INTERFACES #ifdef PEGASUS_EMBEDDED_INSTANCE_SUPPORT void set(const CIMInstance& x); #endif // PEGASUS_EMBEDDED_INSTANCE_SUPPORT #endif // PEGASUS_USE_EXPERIMENTAL_INTERFACES /// void set(const Array& x); /// void set(const Array& x); /// void set(const Array& x); /// void set(const Array& x); /// void set(const Array& x); /// void set(const Array& x); /// void set(const Array& x); /// void set(const Array& x); /// void set(const Array& x); /// void set(const Array& x); /// void set(const Array& x); /// void set(const Array& x); /// void set(const Array& x); /// void set(const Array& x); /// void set(const Array& x); /// void set(const Array& x); /// #ifdef PEGASUS_USE_EXPERIMENTAL_INTERFACES #ifdef PEGASUS_EMBEDDED_INSTANCE_SUPPORT void set(const Array& x); #endif // PEGASUS_EMBEDDED_INSTANCE_SUPPORT #endif // PEGASUS_USE_EXPERIMENTAL_INTERFACES /** Gets the value of a CIMValue. Note: Before using get, the caller should use getType () and isNull () to ensure that the value is not null, and is of the correct type. The behavior of get is undefined when the value is null. @param x Variable in which to return the value. @exception TypeMismatchException If the CIMValue type is not compatible with the type of the output parameter.
            Uint32 v;
            CIMValue value(CIMValue::UINT32, UINT32(99));
            value.get(v);
        
            Uint32 v;
            CIMValue value = property.getValue ();
            if ((value.getType () == CIMTYPE_UINT32) && (!value.isNull ()))
                value.get (v);
        
*/ void get(Boolean& x) const; /// void get(Uint8& x) const; /// void get(Sint8& x) const; /// void get(Uint16& x) const; /// void get(Sint16& x) const; /// void get(Uint32& x) const; /// void get(Sint32& x) const; /// void get(Uint64& x) const; /// void get(Sint64& x) const; /// void get(Real32& x) const; /// void get(Real64& x) const; /// void get(Char16& x) const; /// void get(String& x) const; /// void get(CIMDateTime& x) const; /// void get(CIMObjectPath& x) const; /// void get(CIMObject& x) const; /// #ifdef PEGASUS_USE_EXPERIMENTAL_INTERFACES #ifdef PEGASUS_EMBEDDED_INSTANCE_SUPPORT void get(CIMInstance& x) const; #endif // PEGASUS_EMBEDDED_INSTANCE_SUPPORT #endif // PEGASUS_USE_EXPERIMENTAL_INTERFACES /// void get(Array& x) const; /// void get(Array& x) const; /// void get(Array& x) const; /// void get(Array& x) const; /// void get(Array& x) const; /// void get(Array& x) const; /// void get(Array& x) const; /// void get(Array& x) const; /// void get(Array& x) const; /// void get(Array& x) const; /// void get(Array& x) const; /// void get(Array& x) const; /// void get(Array& x) const; /// void get(Array& x) const; /// void get(Array& x) const; /// void get(Array& x) const; /// #ifdef PEGASUS_USE_EXPERIMENTAL_INTERFACES #ifdef PEGASUS_EMBEDDED_INSTANCE_SUPPORT void get(Array& x) const; #endif // PEGASUS_EMBEDDED_INSTANCE_SUPPORT #endif // PEGASUS_USE_EXPERIMENTAL_INTERFACES /** Compares with another CIMValue object for equality. @param x - CIMValue to compare with. @return true if they are identical in type, attribute and value, false otherwise. */ Boolean equal(const CIMValue& x) const; /** Converts the CIMvalue to a string. Should only be used for output purposes. To get an actual String value, use get(String &). @return String output for CIMValue.
            String test;
            CIMValue value(Boolean(true));
            test = value.toString();  // puts "TRUE" into test
        
*/ String toString() const; #ifdef PEGASUS_USE_DEPRECATED_INTERFACES /** Deprecated Interface
Constructor. (Note: This constructor exists solely to support binary compatibility with a previous definition of the Sint8 type.) */ CIMValue(char x); /** Deprecated Interface
Constructor. (Note: This constructor exists solely to support binary compatibility with a previous definition of the Sint8 type.) */ CIMValue(const Array& x); /** Deprecated Interface
Sets an Sint8 value. (Note: This method exists solely to support binary compatibility with a previous definition of the Sint8 type.) */ void set(char x); /** Deprecated Interface
Sets an Sint8 array value. (Note: This method exists solely to support binary compatibility with a previous definition of the Sint8 type.) */ void set(const Array& x); /** Deprecated Interface
Gets an Sint8 value. (Note: This method exists solely to support binary compatibility with a previous definition of the Sint8 type.) */ void get(char& x) const; /** Deprecated Interface
Gets an Sint8 array value. (Note: This method exists solely to support binary compatibility with a previous definition of the Sint8 type.) */ void get(Array& x) const; #endif private: void _get(const String*& data, Uint32& size) const; CIMValueRep* _rep; friend class CIMMethodRep; friend class CIMParameterRep; friend class CIMPropertyRep; friend class CIMQualifierRep; friend class CIMQualifierDeclRep; friend class BinaryStreamer; friend class XmlWriter; }; /** operator == compares two CIMValue objects for equality. @param x - First CIMValue to compare @param y - Second CIMValue to compare @return true if they are identical in type, attribute and value, false otherwise. */ PEGASUS_COMMON_LINKAGE Boolean operator==(const CIMValue& x, const CIMValue& y); /** operator != compares two CIMValue objects for inequality. @param x - First CIMValue to compare @param y - Second CIMValue to compare @return true if they are NOT identical in type, attribute or value, false otherwise. */ PEGASUS_COMMON_LINKAGE Boolean operator!=(const CIMValue& x, const CIMValue& y); #define PEGASUS_ARRAY_T CIMValue # include #undef PEGASUS_ARRAY_T PEGASUS_NAMESPACE_END #ifdef PEGASUS_INTERNALONLY #include #endif #endif /* Pegasus_Value_h */