(file) Return to CIMValue.cpp CVS log (file) (dir) Up to [Pegasus] / pegasus / src / Pegasus / Common

Diff for /pegasus/src/Pegasus/Common/CIMValue.cpp between version 1.27 and 1.75

version 1.27, 2002/05/11 21:36:29 version 1.75, 2008/12/02 09:00:46
Line 1 
Line 1 
 //%/////////////////////////////////////////////////////////////////////////////  //%LICENSE////////////////////////////////////////////////////////////////
 //  
 // Copyright (c) 2000, 2001 The Open group, BMC Software, Tivoli Systems, IBM  
 // //
 // Permission is hereby granted, free of charge, to any person obtaining a copy  // Licensed to The Open Group (TOG) under one or more contributor license
 // of this software and associated documentation files (the "Software"), to  // agreements.  Refer to the OpenPegasusNOTICE.txt file distributed with
 // deal in the Software without restriction, including without limitation the  // this work for additional information regarding copyright ownership.
 // rights to use, copy, modify, merge, publish, distribute, sublicense, and/or  // Each contributor licenses this file to you under the OpenPegasus Open
 // sell copies of the Software, and to permit persons to whom the Software is  // Source License; you may not use this file except in compliance with the
 // furnished to do so, subject to the following conditions:  // License.
 // //
 // THE ABOVE COPYRIGHT NOTICE AND THIS PERMISSION NOTICE SHALL BE INCLUDED IN  // Permission is hereby granted, free of charge, to any person obtaining a
 // ALL COPIES OR SUBSTANTIAL PORTIONS OF THE SOFTWARE. THE SOFTWARE IS PROVIDED  // copy of this software and associated documentation files (the "Software"),
 // "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT  // to deal in the Software without restriction, including without limitation
 // LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR  // the rights to use, copy, modify, merge, publish, distribute, sublicense,
 // PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT  // and/or sell copies of the Software, and to permit persons to whom the
 // HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN  // Software is furnished to do so, subject to the following conditions:
 // 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.  
 // //
 //==============================================================================  // The above copyright notice and this permission notice shall be included
   // in all copies or substantial portions of the Software.
 // //
 // Author: Mike Brasher (mbrasher@bmc.com)  // 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.
 // //
 // Modified By: Roger Kumpf, Hewlett-Packard Company (roger_kumpf@hp.com)  //////////////////////////////////////////////////////////////////////////
 //              Karl Schopmeyer, (k.schopmeyer@opengroup.org)  
 // //
 //%///////////////////////////////////////////////////////////////////////////// //%/////////////////////////////////////////////////////////////////////////////
  
 #include <cstring> #include <cstring>
 #include <cstdio> #include <cstdio>
 #include <cassert>  
 #include <cctype> #include <cctype>
 #include "CIMValue.h" #include "CIMValue.h"
   #include "CIMInstance.h"
 #include "Union.h" #include "Union.h"
 #include "Indentor.h"  
 #include "XmlWriter.h" #include "XmlWriter.h"
   #include "CommonUTF.h"
   #include "CIMValueRep.h"
   #include "Config.h"
   #include "CIMType.h"
   #include "String.h"
   #include "CIMDateTime.h"
   #include "CIMObjectPath.h"
   #include "CIMObject.h"
   #include "Array.h"
   #include <Pegasus/Common/PegasusAssert.h>
  
 PEGASUS_NAMESPACE_BEGIN PEGASUS_NAMESPACE_BEGIN
  
Line 42 
Line 53 
 # include "ArrayImpl.h" # include "ArrayImpl.h"
 #undef PEGASUS_ARRAY_T #undef PEGASUS_ARRAY_T
  
 template<class T>  // ATTN: By getting a CIMObject from a CIMValue, the client of CIMValue can
 inline void _Inc(ArrayRep<T>* rep)  // modify the internals of that CIMObject and thus change what CIMValue
 {  // itself refers to. There are two solutions: clone() at ever juncture or
     ArrayRep<T>::inc(rep);  // force CIMValue to make its own unique copy when the client calls get()
 }  // to get a CIMObject.
   
 template<class T>  
 inline void _Dec(ArrayRep<T>* rep)  
 {  
     ArrayRep<T>::dec(rep);  
 }  
  
 ////////////////////////////////////////////////////////////////////////////////  //==============================================================================
 //  
 // Local helper functions:  
 //  
 ////////////////////////////////////////////////////////////////////////////////  
   
 // Too complicated.  Commented out in favor of sprintf("%lld"/"%llu").  
 #if 0  
 //------------------------------------------------------------------------------  
 // //
 // _SignedIntToStr()  // _toString() routines:
 // //
 //------------------------------------------------------------------------------  //==============================================================================
   
 static void _SignedIntToStr(Sint64 x, char* result)  
 {  
     if (!result)  
         return;  
  
     if (x == 0)  inline void _toString(Buffer& out, Boolean x)
     {     {
         result[0] = '0';      XmlWriter::append(out, x);
         result[1] = '\0';  
         return;  
     }     }
  
     char buffer[32];  inline void _toString(Buffer& out, Uint8 x)
     Uint32 len = 0;  
     Boolean negative = false;  
   
     while (x)  
     {     {
         Sint32 r = x % 10;      XmlWriter::append(out, Uint32(x));
         x = x / 10;  
   
         if (r < 0)  
         {  
             r = -r;  
             negative = true;  
         }         }
  
         buffer[len++] = r + '0';  inline void _toString(Buffer& out, Sint8 x)
   {
       XmlWriter::append(out, Sint32(x));
     }     }
  
     buffer[len] = '\0';  inline void _toString(Buffer& out, Uint16 x)
   {
     // If buffer was negative, prepend sign:      XmlWriter::append(out, Uint32(x));
   
     char* q = result;  
   
     if (negative)  
         *q++ = '-';  
   
     // Reverse the buffer:  
   
     char* p = &buffer[len];  
   
     while (len--)  
         *q++ = *--p;  
   
     *q++ = '\0';  
 } }
  
 //------------------------------------------------------------------------------  inline void _toString(Buffer& out, Sint16 x)
 //  
 // _UnsignedIntToStr()  
 //  
 //------------------------------------------------------------------------------  
   
 static void _UnsignedIntToStr(Uint64 x, char* result)  
 { {
     if (!result)      XmlWriter::append(out, Sint32(x));
         return;  }
  
     if (x == 0)  inline void _toString(Buffer& out, Uint32 x)
     {     {
         result[0] = '0';      XmlWriter::append(out, x);
         result[1] = '\0';  
         return;  
     }     }
  
     char buffer[32];  inline void _toString(Buffer& out, Sint32 x)
     Uint32 len = 0;  
   
     while (x)  
     {     {
         Uint32 r = x % 10;      XmlWriter::append(out, x);
         x = x / 10;  
   
         buffer[len++] = r + '0';  
     }     }
  
     buffer[len] = '\0';  inline void _toString(Buffer& out, Uint64 x)
   {
     // Reverse the buffer onto output:      XmlWriter::append(out, x);
   
     char* q = result;  
   
     char* p = &buffer[len];  
   
     while (len--)  
         *q++ = *--p;  
   
     *q++ = '\0';  
 } }
 #endif  
  
 //------------------------------------------------------------------------------  inline void _toString(Buffer& out, Sint64 x)
 //  
 // _toString, _toXml(), and _toMof routines:  
 //  
 //------------------------------------------------------------------------------  
   
 inline void _toString(Array<Sint8>& out, Boolean x)  
 { {
     out << (x ? "TRUE" : "FALSE");      XmlWriter::append(out, x);
 } }
  
 inline void _toXml(Array<Sint8>& out, Boolean x) { _toString(out, x); }  inline void _toString(Buffer& out, Real32 x)
 inline void _toMof(Array<Sint8>& out, Boolean x) { _toString(out, x); }  
   
 inline void _integerToString(Array<Sint8>& out, Sint32 x)  
 { {
     char buffer[32];      XmlWriter::append(out, Real64(x));
     sprintf(buffer, "%d", x);  
     out << (char*)buffer;  
 } }
  
 inline void _unsignedIntegerToString(Array<Sint8>& out, Uint32 x)  inline void _toString(Buffer& out, Real64 x)
 { {
     char buffer[32];      XmlWriter::append(out, x);
     sprintf(buffer, "%u", x);  
     out << (char*)buffer;  
 } }
  
 inline void _toString(Array<Sint8>& out, Uint8 x) { _unsignedIntegerToString(out, x); }  inline void _toString(Buffer& out, Char16 x)
 inline void _toXml(Array<Sint8>& out, Uint8 x) { _toString(out, x); }  {
 inline void _toMof(Array<Sint8>& out, Uint8 x) { _toString(out, x); }      // We need to convert the Char16 to UTF8 then append the UTF8
       // character into the array.
 inline void _toString(Array<Sint8>& out, Sint8 x) { _integerToString(out, x); }      // NOTE: The UTF8 character could be several bytes long.
 inline void _toXml(Array<Sint8>& out, Sint8 x) { _toString(out, x); }      // WARNING: This function will put in replacement character for
 inline void _toMof(Array<Sint8>& out, Sint8 x) { _toString(out, x); }      // all characters that have surogate pairs.
   
 inline void _toString(Array<Sint8>& out, Uint16 x) { _unsignedIntegerToString(out, x); }  
 inline void _toXml(Array<Sint8>& out, Uint16 x) { _toString(out, x); }  
 inline void _toMof(Array<Sint8>& out, Uint16 x) { _toString(out, x); }  
  
 inline void _toString(Array<Sint8>& out, Sint16 x) { _integerToString(out, x); }      char str[6];
 inline void _toXml(Array<Sint8>& out, Sint16 x) { _toString(out, x); }      memset(str,0x00,sizeof(str));
 inline void _toMof(Array<Sint8>& out, Sint16 x) { _toString(out, x); }      char* charIN = (char *)&x;
  
 inline void _toString(Array<Sint8>& out, Uint32 x) { _unsignedIntegerToString(out, x); }      const Uint16 *strsrc = (Uint16 *)charIN;
 inline void _toXml(Array<Sint8>& out, Uint32 x) { _toString(out, x); }      Uint16 *endsrc = (Uint16 *)&charIN[1];
 inline void _toMof(Array<Sint8>& out, Uint32 x) { _toString(out, x); }  
  
 inline void _toString(Array<Sint8>& out, Sint32 x) { _integerToString(out, x); }      Uint8 *strtgt = (Uint8 *)str;
 inline void _toXml(Array<Sint8>& out, Sint32 x) { _toString(out, x); }      Uint8 *endtgt = (Uint8 *)&str[5];
 inline void _toMof(Array<Sint8>& out, Sint32 x) { _toString(out, x); }  
  
 inline void _toString(Array<Sint8>& out, Uint64 x)      UTF16toUTF8(&strsrc, endsrc, &strtgt, endtgt);
 {      out.append(str, UTF_8_COUNT_TRAIL_BYTES(str[0]) +1);
     char buffer[32];  // Should need 21 chars max  
     // I know I shouldn't put platform flags here, but the other was is too hard  
 #if defined(PEGASUS_PLATFORM_WIN32_IX86_MSVC)  
     sprintf(buffer, "%I64u", x);  
 #else  
     sprintf(buffer, "%llu", x);  
 #endif  
     out << buffer;  
 } }
  
 inline void _toXml(Array<Sint8>& out, Uint64 x) { _toString(out, x); }  inline void _toString(Buffer& out, const String& x)
 inline void _toMof(Array<Sint8>& out, Uint64 x) { _toString(out, x); }  
   
 inline void _toString(Array<Sint8>& out, Sint64 x)  
 { {
     char buffer[32];  // Should need 21 chars max      out << x;
     // I know I shouldn't put platform flags here, but the other was is too hard  
 #if defined(PEGASUS_PLATFORM_WIN32_IX86_MSVC)  
     sprintf(buffer, "%I64d", x);  
 #else  
     sprintf(buffer, "%lld", x);  
 #endif  
     out << buffer;  
 } }
  
 inline void _toXml(Array<Sint8>& out, Sint64 x) { _toString(out, x); }  inline void _toString(Buffer& out, const CIMDateTime& x)
 inline void _toMof(Array<Sint8>& out, Sint64 x) { _toString(out, x); }  
   
 void _toString(Array<Sint8>& out, Real64 x)  
 { {
     char buffer[128];      out << x.toString();
     // %e gives '[-]m.dddddde+/-xx', which seems compatible with CIM/XML spec  
     sprintf(buffer, "%e", x);  
     out << buffer;  
 } }
  
 inline void _toXml(Array<Sint8>& out, Real64 x) { _toString(out, x); }  inline void _toString(Buffer& out, const CIMObjectPath& x)
 inline void _toMof(Array<Sint8>& out, Real64 x) { _toString(out, x); }  
   
 inline void _toString(Array<Sint8>& out, Real32 x) { _toString(out, Real64(x)); }  
 inline void _toXml(Array<Sint8>& out, Real32 x) { _toString(out, x); }  
 inline void _toMof(Array<Sint8>& out, Real32 x) { _toString(out, x); }  
   
 inline void _toString(Array<Sint8>& out, Char16 x)  
 { {
     // ATTN: How to convert 16-bit characters to printable form?      out << x.toString();
     out.append(Sint8(x));  
 } }
 inline void _toXml(Array<Sint8>& out, Char16 x)  
   inline void _toString(Buffer& out, const CIMObject& x)
 { {
     XmlWriter::appendSpecial(out, x);      out << x.toString();
 } }
 inline void _toMof(Array<Sint8>& out, Char16 x)  inline void _toString(Buffer& out, const CIMInstance& x)
 { {
     XmlWriter::appendSpecial(out, x);      out << CIMObject(x).toString();
 } }
  
 inline void _toString(Array<Sint8>& out, const String& x)  template<class T>
   void _toString(Buffer& out, const T* p, Uint32 size)
 { {
     out << x;      while (size--)
 }  
   
 inline void _toXml(Array<Sint8>& out, const String& x)  
 { {
     XmlWriter::appendSpecial(out, x);          _toString(out, *p++);
           out.append(' ');
 } }
   }
   
   //==============================================================================
   //
   // CIMValueRep
   //
   //==============================================================================
   
   CIMValueRep CIMValueRep::_emptyRep((int*)0);
  
 /** _toMof Internal function to convert the string back  void CIMValueRep::release()
     to MOF format and output it.  
     The conversions are:  
     \b // \x0008: backspace BS  
     \t // \x0009: horizontal tab HT  
     \n // \x000A: linefeed LF  
     \f // \x000C: form feed FF  
     \r // \x000D: carriage return CR  
     \" // \x0022: double quote "  
     \’ // \x0027: single quote '  
     \\ // \x005C: backslash \  
     \x<hex> // where <hex> is one to four hex digits  
     \X<hex> // where <hex> is one to four hex digits  
 */  
 /* ATTN:KS - We need to account for characters greater than x'7f  
 */  
 inline void _toMof(Array<Sint8>& out, const String& x)  
 { {
     out << "\"";      if (isArray)
     const Char16* tmp = x.getData();  
     char c;  
     while ((c = *tmp++))  
     {     {
         switch (c)          switch (type)
         {         {
         case '\\':              case CIMTYPE_BOOLEAN:
                 out.append("\\\\",2);                  CIMValueType<Boolean>::destructArray(this);
                 break;                 break;
  
             case '\b':              case CIMTYPE_UINT8:
                 out.append("\\b",2);                  CIMValueType<Uint8>::destructArray(this);
                 break;                 break;
  
             case '\t':              case CIMTYPE_SINT8:
                 out.append("\\t",2);                  CIMValueType<Sint8>::destructArray(this);
                 break;                 break;
  
             case '\n':              case CIMTYPE_UINT16:
                 out.append("\\n",2);                  CIMValueType<Uint16>::destructArray(this);
                 break;                 break;
  
             case '\f':              case CIMTYPE_SINT16:
                 out.append("\\f",2);                  CIMValueType<Sint16>::destructArray(this);
                 break;                 break;
  
             case '\r':              case CIMTYPE_UINT32:
                 out.append("\\r",2);                  CIMValueType<Uint32>::destructArray(this);
                 break;                 break;
  
            /* case '\'':              case CIMTYPE_SINT32:
                 out.append("\\'", 2);                  CIMValueType<Sint32>::destructArray(this);
                 break;*/                  break;
  
             case '"':              case CIMTYPE_UINT64:
                 out.append("\\\"", 2);                  CIMValueType<Uint64>::destructArray(this);
                 break;                 break;
  
             default:              case CIMTYPE_SINT64:
                 out.append(Sint8(c));                  CIMValueType<Sint64>::destructArray(this);
         }                  break;
  
     }              case CIMTYPE_REAL32:
     out << "\"";                  CIMValueType<Real32>::destructArray(this);
 }                  break;
  
 inline void _toString(Array<Sint8>& out, const CIMDateTime& x)              case CIMTYPE_REAL64:
 {                  CIMValueType<Real64>::destructArray(this);
     out << x.getString();                  break;
 }  
  
 inline void _toXml(Array<Sint8>& out, const CIMDateTime& x) { _toString(out, x); }              case CIMTYPE_CHAR16:
 inline void _toMof(Array<Sint8>& out, const CIMDateTime& x) { _toString(out, x); }                  CIMValueType<Char16>::destructArray(this);
                   break;
  
 inline void _toString(Array<Sint8>& out, const CIMReference& x)              case CIMTYPE_STRING:
 {                  CIMValueType<String>::destructArray(this);
     out << x.toString();                  break;
 }  
 inline void _toXml(Array<Sint8>& out, const CIMReference& x)  
 {  
     x.toXml(out);  
 }  
 inline void _toMof(Array<Sint8>& out, const CIMReference& x)  
 {  
     x.toMof(out);  
 }  
  
 template<class T>              case CIMTYPE_DATETIME:
 void _toString(Array<Sint8>& out, const T* p, Uint32 size)                  CIMValueType<CIMDateTime>::destructArray(this);
 {                  break;
     while (size--)  
     {  
         _toString(out, *p++);  
         out << " ";  
     }  
 }  
  
 void _toXml(Array<Sint8>& out, const CIMReference* p, Uint32 size)              case CIMTYPE_REFERENCE:
 {                  CIMValueType<CIMObjectPath>::destructArray(this);
     out << "<VALUE.REFARRAY>\n";                  break;
     while (size--)  
     {              case CIMTYPE_OBJECT:
         _toXml(out, *p++);                  CIMValueType<CIMObject>::destructArray(this);
                   break;
               case CIMTYPE_INSTANCE:
                   CIMValueType<CIMInstance>::destructArray(this);
                   break;
     }     }
     out << "</VALUE.REFARRAY>\n";  
 } }
       else
 template<class T>  
 void _toXml(Array<Sint8>& out, const T* p, Uint32 size)  
 { {
     out << "<VALUE.ARRAY>\n";          switch (type)
   
     while (size--)  
     {     {
         out << "<VALUE>";              case CIMTYPE_BOOLEAN:
               case CIMTYPE_UINT8:
               case CIMTYPE_SINT8:
               case CIMTYPE_UINT16:
               case CIMTYPE_SINT16:
               case CIMTYPE_UINT32:
               case CIMTYPE_SINT32:
               case CIMTYPE_UINT64:
               case CIMTYPE_SINT64:
               case CIMTYPE_REAL32:
               case CIMTYPE_REAL64:
               case CIMTYPE_CHAR16:
                   break;
  
         _toXml(out, *p++);              case CIMTYPE_STRING:
                   CIMValueType<String>::destruct(this);
                   break;
  
         out << "</VALUE>\n";              case CIMTYPE_DATETIME:
     }                  CIMValueType<CIMDateTime>::destruct(this);
                   break;
  
     out << "</VALUE.ARRAY>\n";              case CIMTYPE_REFERENCE:
 }                  CIMValueType<CIMObjectPath>::destruct(this);
 /** _toMof Array -                  break;
     arrayInitializer  = "{" constantValue*( "," constantValue)"}"  
  
 */              case CIMTYPE_OBJECT:
 template<class T>                  CIMValueType<CIMObject>::destruct(this);
 void _toMof(Array<Sint8>& out, const T* p, Uint32 size)                  break;
 {              case CIMTYPE_INSTANCE:
     Boolean isFirstEntry = true;                  CIMValueType<CIMInstance>::destruct(this);
     // if there are any entries in the array output them                  break;
     if (size)  
     {  
         out << "{";  
         while (size--)  
         {  
             // Put comma on all but first entry.  
             if (!isFirstEntry)  
             {  
                 out << ", ";  
             }  
             isFirstEntry = false;  
             _toMof(out, *p++);  
         }         }
         out << "}";  
   
     }     }
 } }
  
 ////////////////////////////////////////////////////////////////////////////////  //==============================================================================
 // //
 // CIMValueRep  // CIMValue
 // //
 ////////////////////////////////////////////////////////////////////////////////  //==============================================================================
  
 class CIMValueRep  static inline void _release(CIMValueRep*& rep)
 { {
 public:      if (rep->refs.get() == 1)
     CIMValueRep()          rep->release();
       else
     {     {
         reset();          CIMValueRep::unref(rep);
           rep = new CIMValueRep;
       }
     }     }
  
     ~CIMValueRep()  CIMValue::CIMValue(CIMType type, Boolean isArray, Uint32 arraySize)
     {     {
     }      _rep = new CIMValueRep;
  
     void reset()      switch (type)
     {     {
         _type = CIMType::NONE;          case CIMTYPE_BOOLEAN:
         _isArray = false;              CIMValueType<Boolean>::setNull(_rep, type, isArray, arraySize);
         _isNull = true;              break;
         _u._voidPtr = 0;  
     }  
  
     CIMType _type;          case CIMTYPE_UINT8:
     Boolean _isArray;              CIMValueType<Uint8>::setNull(_rep, type, isArray, arraySize);
     Boolean _isNull;              break;
     Union _u;  
 };  
  
           case CIMTYPE_SINT8:
               CIMValueType<Sint8>::setNull(_rep, type, isArray, arraySize);
               break;
  
 ////////////////////////////////////////////////////////////////////////////////          case CIMTYPE_UINT16:
 //              CIMValueType<Uint16>::setNull(_rep, type, isArray, arraySize);
 // CIMValue              break;
 //  
 ////////////////////////////////////////////////////////////////////////////////  
  
 CIMValue::CIMValue()          case CIMTYPE_SINT16:
 {              CIMValueType<Sint16>::setNull(_rep, type, isArray, arraySize);
     _rep = new CIMValueRep();              break;
 }  
  
 CIMValue::CIMValue(CIMType type, Boolean isArray, Uint32 arraySize)          case CIMTYPE_UINT32:
 {              CIMValueType<Uint32>::setNull(_rep, type, isArray, arraySize);
     _rep = new CIMValueRep();              break;
     setNullValue(type, isArray, arraySize);  
           case CIMTYPE_SINT32:
               CIMValueType<Sint32>::setNull(_rep, type, isArray, arraySize);
               break;
   
           case CIMTYPE_UINT64:
               CIMValueType<Uint64>::setNull(_rep, type, isArray, arraySize);
               break;
   
           case CIMTYPE_SINT64:
               CIMValueType<Sint64>::setNull(_rep, type, isArray, arraySize);
               break;
   
           case CIMTYPE_REAL32:
               CIMValueType<Real32>::setNull(_rep, type, isArray, arraySize);
               break;
   
           case CIMTYPE_REAL64:
               CIMValueType<Real64>::setNull(_rep, type, isArray, arraySize);
               break;
   
           case CIMTYPE_CHAR16:
               CIMValueType<Char16>::setNull(_rep, type, isArray, arraySize);
               break;
   
           case CIMTYPE_STRING:
               CIMValueType<String>::setNull(_rep, type, isArray, arraySize);
               break;
   
           case CIMTYPE_DATETIME:
               CIMValueType<CIMDateTime>::setNull(_rep, type, isArray, arraySize);
               break;
   
           case CIMTYPE_REFERENCE:
               CIMValueType<CIMObjectPath>::setNull(_rep, type, isArray,arraySize);
               break;
   
           case CIMTYPE_OBJECT:
               CIMValueType<CIMObject>::setNull(_rep, type, isArray, arraySize);
               break;
           case CIMTYPE_INSTANCE:
               CIMValueType<CIMInstance>::setNull(_rep, type, isArray, arraySize);
               break;
   
           default:
               PEGASUS_ASSERT(0);
       }
 } }
  
 CIMValue::CIMValue(Boolean x) CIMValue::CIMValue(Boolean x)
 { {
     _rep = new CIMValueRep();      _rep = new CIMValueRep;
     set(x);      CIMValueType<Boolean>::set(_rep, x);
 } }
  
 CIMValue::CIMValue(Uint8 x) CIMValue::CIMValue(Uint8 x)
 { {
     _rep = new CIMValueRep();      _rep = new CIMValueRep;
     set(x);      CIMValueType<Uint8>::set(_rep, x);
 } }
  
 CIMValue::CIMValue(Sint8 x) CIMValue::CIMValue(Sint8 x)
 { {
     _rep = new CIMValueRep();      _rep = new CIMValueRep;
     set(x);      CIMValueType<Sint8>::set(_rep, x);
 } }
  
 CIMValue::CIMValue(Uint16 x) CIMValue::CIMValue(Uint16 x)
 { {
     _rep = new CIMValueRep();      _rep = new CIMValueRep;
     set(x);      CIMValueType<Uint16>::set(_rep, x);
 } }
  
 CIMValue::CIMValue(Sint16 x) CIMValue::CIMValue(Sint16 x)
 { {
     _rep = new CIMValueRep();      _rep = new CIMValueRep;
     set(x);      CIMValueType<Sint16>::set(_rep, x);
 } }
  
 CIMValue::CIMValue(Uint32 x) CIMValue::CIMValue(Uint32 x)
 { {
     _rep = new CIMValueRep();      _rep = new CIMValueRep;
     set(x);      CIMValueType<Uint32>::set(_rep, x);
 } }
  
 CIMValue::CIMValue(Sint32 x) CIMValue::CIMValue(Sint32 x)
 { {
     _rep = new CIMValueRep();      _rep = new CIMValueRep;
     set(x);      CIMValueType<Sint32>::set(_rep, x);
 } }
  
 CIMValue::CIMValue(Uint64 x) CIMValue::CIMValue(Uint64 x)
 { {
     _rep = new CIMValueRep();      _rep = new CIMValueRep;
     set(x);      CIMValueType<Uint64>::set(_rep, x);
 } }
  
 CIMValue::CIMValue(Sint64 x) CIMValue::CIMValue(Sint64 x)
 { {
     _rep = new CIMValueRep();      _rep = new CIMValueRep;
     set(x);      CIMValueType<Sint64>::set(_rep, x);
 } }
  
 CIMValue::CIMValue(Real32 x) CIMValue::CIMValue(Real32 x)
 { {
     _rep = new CIMValueRep();      _rep = new CIMValueRep;
     set(x);      CIMValueType<Real32>::set(_rep, x);
 } }
  
 CIMValue::CIMValue(Real64 x) CIMValue::CIMValue(Real64 x)
 { {
     _rep = new CIMValueRep();      _rep = new CIMValueRep;
     set(x);      CIMValueType<Real64>::set(_rep, x);
 } }
  
 CIMValue::CIMValue(const Char16& x) CIMValue::CIMValue(const Char16& x)
 { {
     _rep = new CIMValueRep();      _rep = new CIMValueRep;
     set(x);      CIMValueType<Char16>::set(_rep, x);
 } }
  
 CIMValue::CIMValue(const String& x) CIMValue::CIMValue(const String& x)
 { {
     _rep = new CIMValueRep();      _rep = new CIMValueRep;
     set(x);      CIMValueType<String>::set(_rep, x);
 } }
  
 CIMValue::CIMValue(const char* x)  CIMValue::CIMValue(const CIMDateTime& x)
 { {
     _rep = new CIMValueRep();      _rep = new CIMValueRep;
     set(x);      CIMValueType<CIMDateTime>::set(_rep, x);
 } }
  
 CIMValue::CIMValue(const CIMDateTime& x)  CIMValue::CIMValue(const CIMObjectPath& x)
   {
       _rep = new CIMValueRep;
       CIMValueType<CIMObjectPath>::set(_rep, x);
   }
   
   CIMValue::CIMValue(const CIMObject& x)
   {
       if (x.isUninitialized())
 { {
     _rep = new CIMValueRep();          // Bug 3373, throw exception if uninitialized object is passed to set().
     set(x);          throw UninitializedObjectException();
 } }
  
 CIMValue::CIMValue(const CIMReference& x)      _rep = new CIMValueRep;
       CIMValueType<CIMObject>::set(_rep, x.clone());
   }
   CIMValue::CIMValue(const CIMInstance& x)
   {
       if (x.isUninitialized())
 { {
     _rep = new CIMValueRep();          // Bug 3373, throw exception if uninitialized object is passed to set().
     set(x);          throw UninitializedObjectException();
 } }
  
       _rep = new CIMValueRep;
       CIMValueType<CIMInstance>::set(_rep, x.clone());
   }
 CIMValue::CIMValue(const Array<Boolean>& x) CIMValue::CIMValue(const Array<Boolean>& x)
 { {
     _rep = new CIMValueRep();      _rep = new CIMValueRep;
     set(x);      CIMValueType<Boolean>::setArray(_rep, x);
 } }
  
 CIMValue::CIMValue(const Array<Uint8>& x) CIMValue::CIMValue(const Array<Uint8>& x)
 { {
     _rep = new CIMValueRep();      _rep = new CIMValueRep;
     set(x);      CIMValueType<Uint8>::setArray(_rep, x);
 } }
  
 CIMValue::CIMValue(const Array<Sint8>& x) CIMValue::CIMValue(const Array<Sint8>& x)
 { {
     _rep = new CIMValueRep();      _rep = new CIMValueRep;
     set(x);      CIMValueType<Sint8>::setArray(_rep, x);
 } }
  
 CIMValue::CIMValue(const Array<Uint16>& x) CIMValue::CIMValue(const Array<Uint16>& x)
 { {
     _rep = new CIMValueRep();      _rep = new CIMValueRep;
     set(x);      CIMValueType<Uint16>::setArray(_rep, x);
 } }
  
 CIMValue::CIMValue(const Array<Sint16>& x) CIMValue::CIMValue(const Array<Sint16>& x)
 { {
     _rep = new CIMValueRep();      _rep = new CIMValueRep;
     set(x);      CIMValueType<Sint16>::setArray(_rep, x);
 } }
  
 CIMValue::CIMValue(const Array<Uint32>& x) CIMValue::CIMValue(const Array<Uint32>& x)
 { {
     _rep = new CIMValueRep();      _rep = new CIMValueRep;
     set(x);      CIMValueType<Uint32>::setArray(_rep, x);
 } }
  
 CIMValue::CIMValue(const Array<Sint32>& x) CIMValue::CIMValue(const Array<Sint32>& x)
 { {
     _rep = new CIMValueRep();      _rep = new CIMValueRep;
     set(x);      CIMValueType<Sint32>::setArray(_rep, x);
 } }
  
 CIMValue::CIMValue(const Array<Uint64>& x) CIMValue::CIMValue(const Array<Uint64>& x)
 { {
     _rep = new CIMValueRep();      _rep = new CIMValueRep;
     set(x);      CIMValueType<Uint64>::setArray(_rep, x);
 } }
  
 CIMValue::CIMValue(const Array<Sint64>& x) CIMValue::CIMValue(const Array<Sint64>& x)
 { {
     _rep = new CIMValueRep();      _rep = new CIMValueRep;
     set(x);      CIMValueType<Sint64>::setArray(_rep, x);
 } }
  
 CIMValue::CIMValue(const Array<Real32>& x) CIMValue::CIMValue(const Array<Real32>& x)
 { {
     _rep = new CIMValueRep();      _rep = new CIMValueRep;
     set(x);      CIMValueType<Real32>::setArray(_rep, x);
 } }
  
 CIMValue::CIMValue(const Array<Real64>& x) CIMValue::CIMValue(const Array<Real64>& x)
 { {
     _rep = new CIMValueRep();      _rep = new CIMValueRep;
     set(x);      CIMValueType<Real64>::setArray(_rep, x);
 } }
  
 CIMValue::CIMValue(const Array<Char16>& x) CIMValue::CIMValue(const Array<Char16>& x)
 { {
     _rep = new CIMValueRep();      _rep = new CIMValueRep;
     set(x);      CIMValueType<Char16>::setArray(_rep, x);
 } }
  
 CIMValue::CIMValue(const Array<String>& x) CIMValue::CIMValue(const Array<String>& x)
 { {
     _rep = new CIMValueRep();      _rep = new CIMValueRep;
     set(x);      CIMValueType<String>::setArray(_rep, x);
 } }
  
 CIMValue::CIMValue(const Array<CIMDateTime>& x) CIMValue::CIMValue(const Array<CIMDateTime>& x)
 { {
     _rep = new CIMValueRep();      _rep = new CIMValueRep;
     set(x);      CIMValueType<CIMDateTime>::setArray(_rep, x);
 } }
  
 CIMValue::CIMValue(const Array<CIMReference>& x)  CIMValue::CIMValue(const Array<CIMObjectPath>& x)
 { {
     _rep = new CIMValueRep();      _rep = new CIMValueRep;
     set(x);      CIMValueType<CIMObjectPath>::setArray(_rep, x);
 } }
  
 CIMValue::CIMValue(const CIMValue& x)  CIMValue::CIMValue(const Array<CIMObject>& x)
 { {
     _rep = new CIMValueRep();      Array<CIMObject> tmp;
     assign(x);  
 }  
  
 CIMValue::~CIMValue()      for (Uint32 i = 0, n = x.size(); i < n; i++)
 { {
     clear();          if (x[i].isUninitialized())
     delete _rep;  
 }  
   
 CIMValue& CIMValue::operator=(const CIMValue& x)  
 { {
     assign(x);              // Bug 3373, throw exception on uninitialized object.
     return *this;              _rep = &CIMValueRep::_emptyRep;
               throw UninitializedObjectException();
 } }
  
 void CIMValue::assign(const CIMValue& x)          tmp.append(x[i].clone());
 {      }
     if (this == &x)  
         return;  
   
     clear();  
  
     _rep->_type = x._rep->_type;      _rep = new CIMValueRep;
     _rep->_isArray = x._rep->_isArray;      CIMValueType<CIMObject>::setArray(_rep, tmp);
     _rep->_isNull = x._rep->_isNull;  }
     _rep->_u._voidPtr = 0;  
  
     if (_rep->_isArray)  CIMValue::CIMValue(const Array<CIMInstance>& x)
     {  
         switch (_rep->_type)  
         {         {
             case CIMType::BOOLEAN:      Array<CIMInstance> tmp;
                 _Inc(_rep->_u._booleanArray = x._rep->_u._booleanArray);  
                 break;  
   
             case CIMType::UINT8:  
                 _Inc(_rep->_u._uint8Array = x._rep->_u._uint8Array);  
                 break;  
   
             case CIMType::SINT8:  
                 _Inc(_rep->_u._sint8Array = x._rep->_u._sint8Array);  
                 break;  
   
             case CIMType::UINT16:  
                 _Inc(_rep->_u._uint16Array = x._rep->_u._uint16Array);  
                 break;  
   
             case CIMType::SINT16:  
                 _Inc(_rep->_u._sint16Array = x._rep->_u._sint16Array);  
                 break;  
  
             case CIMType::UINT32:      for (Uint32 i = 0, n = x.size(); i < n; i++)
                 _Inc(_rep->_u._uint32Array = x._rep->_u._uint32Array);  
                 break;  
   
             case CIMType::SINT32:  
                 _Inc(_rep->_u._sint32Array = x._rep->_u._sint32Array);  
                 break;  
   
             case CIMType::UINT64:  
                 _Inc(_rep->_u._uint64Array = x._rep->_u._uint64Array);  
                 break;  
   
             case CIMType::SINT64:  
                 _Inc(_rep->_u._sint64Array = x._rep->_u._sint64Array);  
                 break;  
   
             case CIMType::REAL32:  
                 _Inc(_rep->_u._real32Array = x._rep->_u._real32Array);  
                 break;  
   
             case CIMType::REAL64:  
                 _Inc(_rep->_u._real64Array = x._rep->_u._real64Array);  
                 break;  
   
             case CIMType::CHAR16:  
                 _Inc(_rep->_u._char16Array = x._rep->_u._char16Array);  
                 break;  
   
             case CIMType::STRING:  
                 _Inc(_rep->_u._stringArray = x._rep->_u._stringArray);  
                 break;  
   
             case CIMType::DATETIME:  
                 _Inc(_rep->_u._dateTimeArray = x._rep->_u._dateTimeArray);  
                 break;  
   
             case CIMType::REFERENCE:  
                 _Inc(_rep->_u._referenceArray = x._rep->_u._referenceArray);  
                 break;  
             default:  
                 throw CIMValueInvalidType();  
         }  
     }  
     else  
     {     {
         switch (_rep->_type)          if (x[i].isUninitialized())
         {         {
             case CIMType::NONE:            // Bug 3373, throw exception on uninitialized object.
                 break;            _rep = &CIMValueRep::_emptyRep;
             throw UninitializedObjectException();
             case CIMType::BOOLEAN:  
                 _rep->_u._booleanValue = x._rep->_u._booleanValue;  
                 break;  
   
             case CIMType::UINT8:  
                 _rep->_u._uint8Value = x._rep->_u._uint8Value;  
                 break;  
   
             case CIMType::SINT8:  
                 _rep->_u._sint8Value = x._rep->_u._sint8Value;  
                 break;  
   
             case CIMType::UINT16:  
                 _rep->_u._uint16Value = x._rep->_u._uint16Value;  
                 break;  
   
             case CIMType::SINT16:  
                 _rep->_u._sint16Value = x._rep->_u._sint16Value;  
                 break;  
   
             case CIMType::UINT32:  
                 _rep->_u._uint32Value = x._rep->_u._uint32Value;  
                 break;  
   
             case CIMType::SINT32:  
                 _rep->_u._sint32Value = x._rep->_u._sint32Value;  
                 break;  
   
             case CIMType::UINT64:  
                 _rep->_u._uint64Value = x._rep->_u._uint64Value;  
                 break;  
   
             case CIMType::SINT64:  
                 _rep->_u._sint64Value = x._rep->_u._sint64Value;  
                 break;  
   
             case CIMType::REAL32:  
                 _rep->_u._real32Value = x._rep->_u._real32Value;  
                 break;  
   
             case CIMType::REAL64:  
                 _rep->_u._real64Value = x._rep->_u._real64Value;  
                 break;  
   
             case CIMType::CHAR16:  
                 _rep->_u._char16Value = x._rep->_u._char16Value;  
                 break;  
   
             case CIMType::STRING:  
                 _rep->_u._stringValue = new String(*(x._rep->_u._stringValue));  
                 break;  
   
             case CIMType::DATETIME:  
                 _rep->_u._dateTimeValue =  
                     new CIMDateTime(*(x._rep->_u._dateTimeValue));  
                 break;  
   
             case CIMType::REFERENCE:  
                 _rep->_u._referenceValue =  
                     new CIMReference(*(x._rep->_u._referenceValue));  
                 break;  
   
             // Should never get here. testing complete enum  
             default:  
                 throw CIMValueInvalidType();  
         }         }
   
           tmp.append(x[i].clone());
     }     }
       _rep = new CIMValueRep;
       CIMValueType<CIMInstance>::setArray(_rep, tmp);
 } }
  
 //ATTN: P1  KS Problem with Compiler when I added the defaults to clear, the compiler  
 // gets an exception very early.  Disabled the exceptions to keep compiler running for  
 // the minute. Note that the case statement is not complete. None missing.  
 void CIMValue::clear() void CIMValue::clear()
 { {
     if (_rep->_isArray)      CIMValueRep::unref(_rep);
     {      _rep = &CIMValueRep::_emptyRep;
         switch (_rep->_type)  
         {  
             case CIMType::BOOLEAN:  
                 _Dec(_rep->_u._booleanArray);  
                 break;  
   
             case CIMType::UINT8:  
                 _Dec(_rep->_u._uint8Array);  
                 break;  
   
             case CIMType::SINT8:  
                 _Dec(_rep->_u._sint8Array);  
                 break;  
   
             case CIMType::UINT16:  
                 _Dec(_rep->_u._uint16Array);  
                 break;  
   
             case CIMType::SINT16:  
                 _Dec(_rep->_u._sint16Array);  
                 break;  
   
             case CIMType::UINT32:  
                 _Dec(_rep->_u._uint32Array);  
                 break;  
   
             case CIMType::SINT32:  
                 _Dec(_rep->_u._sint32Array);  
                 break;  
   
             case CIMType::UINT64:  
                 _Dec(_rep->_u._uint64Array);  
                 break;  
   
             case CIMType::SINT64:  
                 _Dec(_rep->_u._sint64Array);  
                 break;  
   
             case CIMType::REAL32:  
                 _Dec(_rep->_u._real32Array);  
                 break;  
   
             case CIMType::REAL64:  
                 _Dec(_rep->_u._real64Array);  
                 break;  
   
             case CIMType::CHAR16:  
                 _Dec(_rep->_u._char16Array);  
                 break;  
   
             case CIMType::STRING:  
                 _Dec(_rep->_u._stringArray);  
                 break;  
   
             case CIMType::DATETIME:  
                 _Dec(_rep->_u._dateTimeArray);  
                 break;  
   
             case CIMType::REFERENCE:  
                 _Dec(_rep->_u._referenceArray);  
                 break;  
   
             //default:  
                 //throw CIMValueInvalidType();  
         }  
     }     }
     else  
   CIMValue& CIMValue::operator=(const CIMValue& x)
     {     {
         switch (_rep->_type)      if (_rep != x._rep)
         {         {
             case CIMType::BOOLEAN:          CIMValueRep::unref(_rep);
             case CIMType::UINT8:          CIMValueRep::ref(_rep = x._rep);
             case CIMType::SINT8:  
             case CIMType::UINT16:  
             case CIMType::SINT16:  
             case CIMType::UINT32:  
             case CIMType::SINT32:  
             case CIMType::UINT64:  
             case CIMType::SINT64:  
             case CIMType::REAL32:  
             case CIMType::REAL64:  
             case CIMType::CHAR16:  
                 break;  
   
             case CIMType::STRING:  
                 delete _rep->_u._stringValue;  
                 break;  
   
             case CIMType::DATETIME:  
                 delete _rep->_u._dateTimeValue;  
                 break;  
   
             case CIMType::REFERENCE:  
                 delete _rep->_u._referenceValue;  
                 break;  
             //default:  
                 //throw CIMValueInvalidType();  
         }  
     }     }
  
     _rep->reset();      return *this;
 } }
  
 Boolean CIMValue::typeCompatible(const CIMValue& x) const  void CIMValue::assign(const CIMValue& x)
 { {
     return _rep->_type == x._rep->_type && _rep->_isArray == x._rep->_isArray;      if (_rep != x._rep)
 }  
   
 Boolean CIMValue::isArray() const  
 { {
     return _rep->_isArray;          CIMValueRep::unref(_rep);
           CIMValueRep::ref(_rep = x._rep);
       }
 } }
  
 Boolean CIMValue::isNull() const  Boolean CIMValue::typeCompatible(const CIMValue& x) const
 { {
     return _rep->_isNull;      return (_rep->type == x._rep->type && _rep->isArray == x._rep->isArray);
 } }
  
 Uint32 CIMValue::getArraySize() const Uint32 CIMValue::getArraySize() const
 { {
     if (!_rep->_isArray)      if (!_rep->isArray)
         return 0;         return 0;
  
     switch (_rep->_type)      switch (_rep->type)
     {     {
         case CIMType::NONE:          case CIMTYPE_BOOLEAN:
             return 0;              return CIMValueType<Boolean>::arraySize(_rep);
             break;  
  
         case CIMType::BOOLEAN:          case CIMTYPE_UINT8:
             return _rep->_u._booleanArray->size;              return CIMValueType<Uint8>::arraySize(_rep);
             break;  
  
         case CIMType::UINT8:          case CIMTYPE_SINT8:
             return _rep->_u._uint8Array->size;              return CIMValueType<Sint8>::arraySize(_rep);
             break;  
  
         case CIMType::SINT8:          case CIMTYPE_UINT16:
             return _rep->_u._sint8Array->size;              return CIMValueType<Uint16>::arraySize(_rep);
             break;  
  
         case CIMType::UINT16:          case CIMTYPE_SINT16:
             return _rep->_u._uint16Array->size;              return CIMValueType<Sint16>::arraySize(_rep);
             break;  
  
         case CIMType::SINT16:          case CIMTYPE_UINT32:
             return _rep->_u._sint16Array->size;              return CIMValueType<Uint32>::arraySize(_rep);
             break;  
  
         case CIMType::UINT32:          case CIMTYPE_SINT32:
             return _rep->_u._uint32Array->size;              return CIMValueType<Sint32>::arraySize(_rep);
             break;  
  
         case CIMType::SINT32:          case CIMTYPE_UINT64:
             return _rep->_u._sint32Array->size;              return CIMValueType<Uint64>::arraySize(_rep);
             break;  
  
         case CIMType::UINT64:          case CIMTYPE_SINT64:
             return _rep->_u._uint64Array->size;              return CIMValueType<Sint64>::arraySize(_rep);
             break;  
  
         case CIMType::SINT64:          case CIMTYPE_REAL32:
             return _rep->_u._sint64Array->size;              return CIMValueType<Real32>::arraySize(_rep);
             break;  
  
         case CIMType::REAL32:          case CIMTYPE_REAL64:
             return _rep->_u._real32Array->size;              return CIMValueType<Real64>::arraySize(_rep);
             break;  
  
         case CIMType::REAL64:          case CIMTYPE_CHAR16:
             return _rep->_u._real64Array->size;              return CIMValueType<Char16>::arraySize(_rep);
             break;  
  
         case CIMType::CHAR16:          case CIMTYPE_STRING:
             return _rep->_u._char16Array->size;              return CIMValueType<String>::arraySize(_rep);
             break;  
  
         case CIMType::STRING:          case CIMTYPE_DATETIME:
             return _rep->_u._stringArray->size;              return CIMValueType<CIMDateTime>::arraySize(_rep);
             break;  
  
         case CIMType::DATETIME:          case CIMTYPE_REFERENCE:
             return _rep->_u._dateTimeArray->size;              return CIMValueType<CIMObjectPath>::arraySize(_rep);
             break;  
  
         case CIMType::REFERENCE:          case CIMTYPE_OBJECT:
             return _rep->_u._referenceArray->size;              return CIMValueType<CIMObject>::arraySize(_rep);
             break;          case CIMTYPE_INSTANCE:
         // Should never get here. switch on complete enum          return CIMValueType<CIMInstance>::arraySize(_rep);
         default:         default:
             throw CIMValueInvalidType();              PEGASUS_ASSERT(0);
     }     }
  
     // Unreachable!  
     PEGASUS_ASSERT(false);  
     return 0;     return 0;
 } }
  
 CIMType CIMValue::getType() const  
 {  
     return CIMType(_rep->_type);  
 }  
   
 void CIMValue::setNullValue(CIMType type, Boolean isArray, Uint32 arraySize) void CIMValue::setNullValue(CIMType type, Boolean isArray, Uint32 arraySize)
 { {
       //
       // Release any memory:
       //
  
     clear();      _release(_rep);
   
     if (isArray)  
     {  
         switch (type)  
         {  
             case CIMType::BOOLEAN:  
                 set(Array<Boolean>(arraySize));  
                 break;  
   
             case CIMType::UINT8:  
                 set(Array<Uint8>(arraySize));  
                 break;  
   
             case CIMType::SINT8:  
                 set(Array<Sint8>(arraySize));  
                 break;  
   
             case CIMType::UINT16:  
                 set(Array<Uint16>(arraySize));  
                 break;  
   
             case CIMType::SINT16:  
                 set(Array<Sint16>(arraySize));  
                 break;  
   
             case CIMType::UINT32:  
                 set(Array<Uint32>(arraySize));  
                 break;  
   
             case CIMType::SINT32:  
                 set(Array<Sint32>(arraySize));  
                 break;  
   
             case CIMType::UINT64:  
                 set(Array<Uint64>(arraySize));  
                 break;  
   
             case CIMType::SINT64:  
                 set(Array<Sint64>(arraySize));  
                 break;  
   
             case CIMType::REAL32:  
                 set(Array<Real32>(arraySize));  
                 break;  
   
             case CIMType::REAL64:  
                 set(Array<Real64>(arraySize));  
                 break;  
   
             case CIMType::CHAR16:  
                 set(Array<Char16>(arraySize));  
                 break;  
   
             case CIMType::STRING:  
                 set(Array<String>(arraySize));  
                 break;  
  
             case CIMType::DATETIME:      //
                 set(Array<CIMDateTime>(arraySize));      // Set the null value:
                 break;      //
  
             case CIMType::REFERENCE:  
                 set(Array<CIMReference>(arraySize));  
                 break;  
             default:  
                 throw CIMValueInvalidType();  
         }  
     }  
     else  
     {  
         switch (type)         switch (type)
         {         {
             case CIMType::BOOLEAN:          case CIMTYPE_BOOLEAN:
                 set(false);              CIMValueType<Boolean>::setNull(_rep, type, isArray, arraySize);
               break;
   
           case CIMTYPE_UINT8:
               CIMValueType<Uint8>::setNull(_rep, type, isArray, arraySize);
                 break;                 break;
  
             case CIMType::UINT8:          case CIMTYPE_SINT8:
                 set(Uint8(0));              CIMValueType<Sint8>::setNull(_rep, type, isArray, arraySize);
                 break;                 break;
  
             case CIMType::SINT8:          case CIMTYPE_UINT16:
                 set(Sint8(0));              CIMValueType<Uint16>::setNull(_rep, type, isArray, arraySize);
                 break;                 break;
  
             case CIMType::UINT16:          case CIMTYPE_SINT16:
                 set(Uint16(0));              CIMValueType<Sint16>::setNull(_rep, type, isArray, arraySize);
                 break;                 break;
  
             case CIMType::SINT16:          case CIMTYPE_UINT32:
                 set(Sint16(0));              CIMValueType<Uint32>::setNull(_rep, type, isArray, arraySize);
                 break;                 break;
  
             case CIMType::UINT32:          case CIMTYPE_SINT32:
                 set(Uint32(0));              CIMValueType<Sint32>::setNull(_rep, type, isArray, arraySize);
                 break;                 break;
  
             case CIMType::SINT32:          case CIMTYPE_UINT64:
                 set(Sint32(0));              CIMValueType<Uint64>::setNull(_rep, type, isArray, arraySize);
                 break;                 break;
  
             case CIMType::UINT64:          case CIMTYPE_SINT64:
                 set(Uint64(0));              CIMValueType<Sint64>::setNull(_rep, type, isArray, arraySize);
                 break;                 break;
  
             case CIMType::SINT64:          case CIMTYPE_REAL32:
                 set(Sint64(0));              CIMValueType<Real32>::setNull(_rep, type, isArray, arraySize);
                 break;                 break;
  
             case CIMType::REAL32:          case CIMTYPE_REAL64:
                 set(Real32(0.0));              CIMValueType<Real64>::setNull(_rep, type, isArray, arraySize);
                 break;                 break;
  
             case CIMType::REAL64:          case CIMTYPE_CHAR16:
                 set(Real64(0.0));              CIMValueType<Char16>::setNull(_rep, type, isArray, arraySize);
                 break;                 break;
  
             case CIMType::CHAR16:          case CIMTYPE_STRING:
                 set(Char16(0));              CIMValueType<String>::setNull(_rep, type, isArray, arraySize);
                 break;                 break;
  
             case CIMType::STRING:          case CIMTYPE_DATETIME:
                 set(String());              CIMValueType<CIMDateTime>::setNull(_rep, type, isArray, arraySize);
                 break;                 break;
  
             case CIMType::DATETIME:          case CIMTYPE_REFERENCE:
                 set(CIMDateTime());              CIMValueType<CIMObjectPath>::setNull(_rep, type, isArray,arraySize);
                 break;                 break;
  
             case CIMType::REFERENCE:          case CIMTYPE_OBJECT:
                 set(CIMReference());              CIMValueType<CIMObject>::setNull(_rep, type, isArray, arraySize);
               break;
           case CIMTYPE_INSTANCE:
               CIMValueType<CIMInstance>::setNull(_rep, type, isArray, arraySize);
                 break;                 break;
             default:             default:
                 throw CIMValueInvalidType();              PEGASUS_ASSERT(0);
         }         }
     }     }
  
     // Set the Null attribute. Note that this must be after the set  
     // because the set functions sets the _isNull.  
   
     _rep->_isNull = true;  
 }  
   
 void CIMValue::set(Boolean x) void CIMValue::set(Boolean x)
 { {
     clear();      _release(_rep);
     _rep->_u._booleanValue = (Uint8)x;      CIMValueType<Boolean>::set(_rep, x);
     _rep->_type = CIMType::BOOLEAN;  
     _rep->_isNull = false;  
 } }
  
 void CIMValue::set(Uint8 x) void CIMValue::set(Uint8 x)
 { {
     clear();      _release(_rep);
     _rep->_u._uint8Value = x;      CIMValueType<Uint8>::set(_rep, x);
     _rep->_type = CIMType::UINT8;  
     _rep->_isNull = false;  
 } }
  
 void CIMValue::set(Sint8 x) void CIMValue::set(Sint8 x)
 { {
     clear();      _release(_rep);
     _rep->_u._sint8Value = x;      CIMValueType<Sint8>::set(_rep, x);
     _rep->_type = CIMType::SINT8;  
     _rep->_isNull = false;  
 } }
  
 void CIMValue::set(Uint16 x) void CIMValue::set(Uint16 x)
 { {
     clear();      _release(_rep);
     _rep->_u._uint16Value = x;      CIMValueType<Uint16>::set(_rep, x);
     _rep->_type = CIMType::UINT16;  
     _rep->_isNull = false;  
 } }
  
 void CIMValue::set(Sint16 x) void CIMValue::set(Sint16 x)
 { {
     clear();      _release(_rep);
     _rep->_u._sint16Value = x;      CIMValueType<Sint16>::set(_rep, x);
     _rep->_type = CIMType::SINT16;  
     _rep->_isNull = false;  
 } }
  
 void CIMValue::set(Uint32 x) void CIMValue::set(Uint32 x)
 { {
     clear();      _release(_rep);
     _rep->_u._uint32Value = x;      CIMValueType<Uint32>::set(_rep, x);
     _rep->_type = CIMType::UINT32;  
     _rep->_isNull = false;  
 } }
  
 void CIMValue::set(Sint32 x) void CIMValue::set(Sint32 x)
 { {
     clear();      _release(_rep);
     _rep->_u._sint32Value = x;      CIMValueType<Sint32>::set(_rep, x);
     _rep->_type = CIMType::SINT32;  
     _rep->_isNull = false;  
 } }
  
 void CIMValue::set(Uint64 x) void CIMValue::set(Uint64 x)
 { {
     clear();      _release(_rep);
     _rep->_u._uint64Value = x;      CIMValueType<Uint64>::set(_rep, x);
     _rep->_type = CIMType::UINT64;  
     _rep->_isNull = false;  
 } }
  
 void CIMValue::set(Sint64 x) void CIMValue::set(Sint64 x)
 { {
     clear();      _release(_rep);
     _rep->_u._sint64Value = x;      CIMValueType<Sint64>::set(_rep, x);
     _rep->_type = CIMType::SINT64;  
     _rep->_isNull = false;  
 } }
  
 void CIMValue::set(Real32 x) void CIMValue::set(Real32 x)
 { {
     clear();      _release(_rep);
     _rep->_u._real32Value = x;      CIMValueType<Real32>::set(_rep, x);
     _rep->_type = CIMType::REAL32;  
     _rep->_isNull = false;  
 } }
  
 void CIMValue::set(Real64 x) void CIMValue::set(Real64 x)
 { {
     clear();      _release(_rep);
     _rep->_u._real64Value = x;      CIMValueType<Real64>::set(_rep, x);
     _rep->_type = CIMType::REAL64;  
     _rep->_isNull = false;  
 } }
  
 void CIMValue::set(const Char16& x) void CIMValue::set(const Char16& x)
 { {
     clear();      _release(_rep);
     _rep->_u._char16Value = x;      CIMValueType<Char16>::set(_rep, x);
     _rep->_type = CIMType::CHAR16;  
     _rep->_isNull = false;  
 } }
  
 void CIMValue::set(const String& x) void CIMValue::set(const String& x)
 { {
     clear();      _release(_rep);
     _rep->_u._stringValue = new String(x);      CIMValueType<String>::set(_rep, x);
     _rep->_type = CIMType::STRING;  }
     _rep->_isNull = false;  
   void CIMValue::set(const CIMDateTime& x)
   {
       _release(_rep);
       CIMValueType<CIMDateTime>::set(_rep, x);
 } }
  
 void CIMValue::set(const char* x)  void CIMValue::set(const CIMObjectPath& x)
 { {
     set(String(x));      _release(_rep);
     _rep->_isNull = false;      CIMValueType<CIMObjectPath>::set(_rep, x);
 } }
  
 void CIMValue::set(const CIMDateTime& x)  void CIMValue::set(const CIMObject& x)
 { {
     clear();      if (x.isUninitialized())
     _rep->_u._dateTimeValue = new CIMDateTime(x);      {
     _rep->_type = CIMType::DATETIME;          // Bug 3373, throw exception on uninitialized object.
     _rep->_isNull = false;          throw UninitializedObjectException();
 } }
  
 void CIMValue::set(const CIMReference& x)      _release(_rep);
 {      CIMValueType<CIMObject>::set(_rep, x.clone());
     clear();  }
     _rep->_u._referenceValue = new CIMReference(x);  void CIMValue::set(const CIMInstance& x)
     _rep->_type = CIMType::REFERENCE;  {
     _rep->_isNull = false;      if (x.isUninitialized())
       {
           // Bug 3373, throw exception on uninitialized object.
           throw UninitializedObjectException();
 } }
  
       _release(_rep);
       CIMValueType<CIMInstance>::set(_rep, x.clone());
   }
 void CIMValue::set(const Array<Boolean>& x) void CIMValue::set(const Array<Boolean>& x)
 { {
     clear();      _release(_rep);
     _Inc(_rep->_u._booleanArray = x._rep);      CIMValueType<Boolean>::setArray(_rep, x);
     _rep->_type = CIMType::BOOLEAN;  
     _rep->_isArray = true;  
     _rep->_isNull = false;  
 } }
  
 void CIMValue::set(const Array<Uint8>& x) void CIMValue::set(const Array<Uint8>& x)
 { {
     clear();      _release(_rep);
     _Inc(_rep->_u._uint8Array = x._rep);      CIMValueType<Uint8>::setArray(_rep, x);
     _rep->_type = CIMType::UINT8;  
     _rep->_isArray = true;  
     _rep->_isNull = false;  
 } }
  
 void CIMValue::set(const Array<Sint8>& x) void CIMValue::set(const Array<Sint8>& x)
 { {
     clear();      _release(_rep);
     _Inc(_rep->_u._sint8Array = x._rep);      CIMValueType<Sint8>::setArray(_rep, x);
     _rep->_type = CIMType::SINT8;  
     _rep->_isArray = true;  
     _rep->_isNull = false;  
 } }
  
 void CIMValue::set(const Array<Uint16>& x) void CIMValue::set(const Array<Uint16>& x)
 { {
     clear();      _release(_rep);
     _Inc(_rep->_u._uint16Array = x._rep);      CIMValueType<Uint16>::setArray(_rep, x);
     _rep->_type = CIMType::UINT16;  
     _rep->_isArray = true;  
     _rep->_isNull = false;  
 } }
  
 void CIMValue::set(const Array<Sint16>& x) void CIMValue::set(const Array<Sint16>& x)
 { {
     clear();      _release(_rep);
     _Inc(_rep->_u._sint16Array = x._rep);      CIMValueType<Sint16>::setArray(_rep, x);
     _rep->_type = CIMType::SINT16;  
     _rep->_isArray = true;  
     _rep->_isNull = false;  
 } }
  
 void CIMValue::set(const Array<Uint32>& x) void CIMValue::set(const Array<Uint32>& x)
 { {
     clear();      _release(_rep);
     _Inc(_rep->_u._uint32Array = x._rep);      CIMValueType<Uint32>::setArray(_rep, x);
     _rep->_type = CIMType::UINT32;  
     _rep->_isArray = true;  
     _rep->_isNull = false;  
 } }
  
 void CIMValue::set(const Array<Sint32>& x) void CIMValue::set(const Array<Sint32>& x)
 { {
     clear();      _release(_rep);
     _Inc(_rep->_u._sint32Array = x._rep);      CIMValueType<Sint32>::setArray(_rep, x);
     _rep->_type = CIMType::SINT32;  
     _rep->_isArray = true;  
     _rep->_isNull = false;  
 } }
  
 void CIMValue::set(const Array<Uint64>& x) void CIMValue::set(const Array<Uint64>& x)
 { {
     clear();      _release(_rep);
     _Inc(_rep->_u._uint64Array = x._rep);      CIMValueType<Uint64>::setArray(_rep, x);
     _rep->_type = CIMType::UINT64;  
     _rep->_isArray = true;  
     _rep->_isNull = false;  
 } }
  
 void CIMValue::set(const Array<Sint64>& x) void CIMValue::set(const Array<Sint64>& x)
 { {
     clear();      _release(_rep);
     _Inc(_rep->_u._sint64Array = x._rep);      CIMValueType<Sint64>::setArray(_rep, x);
     _rep->_type = CIMType::SINT64;  
     _rep->_isArray = true;  
     _rep->_isNull = false;  
 } }
  
 void CIMValue::set(const Array<Real32>& x) void CIMValue::set(const Array<Real32>& x)
 { {
     clear();      _release(_rep);
     _Inc(_rep->_u._real32Array = x._rep);      CIMValueType<Real32>::setArray(_rep, x);
     _rep->_type = CIMType::REAL32;  
     _rep->_isArray = true;  
     _rep->_isNull = false;  
 } }
  
 void CIMValue::set(const Array<Real64>& x) void CIMValue::set(const Array<Real64>& x)
 { {
     clear();      _release(_rep);
     _Inc(_rep->_u._real64Array = x._rep);      CIMValueType<Real64>::setArray(_rep, x);
     _rep->_type = CIMType::REAL64;  
     _rep->_isArray = true;  
     _rep->_isNull = false;  
 } }
  
 void CIMValue::set(const Array<Char16>& x) void CIMValue::set(const Array<Char16>& x)
 { {
     clear();      _release(_rep);
     _Inc(_rep->_u._char16Array = x._rep);      CIMValueType<Char16>::setArray(_rep, x);
     _rep->_type = CIMType::CHAR16;  
     _rep->_isArray = true;  
     _rep->_isNull = false;  
 } }
  
 void CIMValue::set(const Array<String>& x) void CIMValue::set(const Array<String>& x)
 { {
     clear();      _release(_rep);
     _Inc(_rep->_u._stringArray = x._rep);      CIMValueType<String>::setArray(_rep, x);
     _rep->_type = CIMType::STRING;  
     _rep->_isArray = true;  
     _rep->_isNull = false;  
 } }
  
 void CIMValue::set(const Array<CIMDateTime>& x) void CIMValue::set(const Array<CIMDateTime>& x)
 { {
     clear();      _release(_rep);
     _Inc(_rep->_u._dateTimeArray = x._rep);      CIMValueType<CIMDateTime>::setArray(_rep, x);
     _rep->_type = CIMType::DATETIME;  }
     _rep->_isArray = true;  
     _rep->_isNull = false;  void CIMValue::set(const Array<CIMObjectPath>& x)
   {
       _release(_rep);
       CIMValueType<CIMObjectPath>::setArray(_rep, x);
   }
   
   void CIMValue::set(const Array<CIMObject>& a)
   {
       Array<CIMObject> tmp;
   
       for (Uint32 i = 0, n = a.size(); i < n; i++)
       {
           if (a[i].isUninitialized())
           {
               // Bug 3373, throw exception on uninitialized object.
               throw UninitializedObjectException();
           }
   
           tmp.append(a[i].clone());
       }
   
       _release(_rep);
       CIMValueType<CIMObject>::setArray(_rep, tmp);
   }
   void CIMValue::set(const Array<CIMInstance>& a)
   {
       Array<CIMInstance> tmp;
   
       for (Uint32 i = 0, n = a.size(); i < n; i++)
       {
           if (a[i].isUninitialized())
           {
                     // Bug 3373, throw exception on uninitialized object.
                     throw UninitializedObjectException();
 } }
  
 void CIMValue::set(const Array<CIMReference>& x)          tmp.append(a[i].clone());
 {  
     clear();  
     _Inc(_rep->_u._referenceArray = x._rep);  
     _rep->_type = CIMType::REFERENCE;  
     _rep->_isArray = true;  
     _rep->_isNull = false;  
 } }
  
       _release(_rep);
       CIMValueType<CIMInstance>::setArray(_rep, tmp);
   }
 void CIMValue::get(Boolean& x) const void CIMValue::get(Boolean& x) const
 { {
     if (_rep->_type != CIMType::BOOLEAN || _rep->_isArray)      if (_rep->type != CIMTYPE_BOOLEAN || _rep->isArray)
         throw TypeMismatch();          throw TypeMismatchException();
  
     x = _rep->_u._booleanValue != 0;      if (!_rep->isNull)
           x = CIMValueType<Boolean>::ref(_rep);
 } }
  
 void CIMValue::get(Uint8& x) const void CIMValue::get(Uint8& x) const
 { {
     if (_rep->_type != CIMType::UINT8 || _rep->_isArray)      if (_rep->type != CIMTYPE_UINT8 || _rep->isArray)
         throw TypeMismatch();          throw TypeMismatchException();
  
     x = _rep->_u._uint8Value;      if (!_rep->isNull)
           x = CIMValueType<Uint8>::ref(_rep);
 } }
  
 void CIMValue::get(Sint8& x) const void CIMValue::get(Sint8& x) const
 { {
     if (_rep->_type != CIMType::SINT8 || _rep->_isArray)      if (_rep->type != CIMTYPE_SINT8 || _rep->isArray)
         throw TypeMismatch();          throw TypeMismatchException();
  
     x = _rep->_u._sint8Value;      if (!_rep->isNull)
           x = CIMValueType<Sint8>::ref(_rep);
 } }
  
 void CIMValue::get(Uint16& x) const void CIMValue::get(Uint16& x) const
 { {
     if (_rep->_type != CIMType::UINT16 || _rep->_isArray)      if (_rep->type != CIMTYPE_UINT16 || _rep->isArray)
         throw TypeMismatch();          throw TypeMismatchException();
  
     x = _rep->_u._uint16Value;      if (!_rep->isNull)
           x = CIMValueType<Uint16>::ref(_rep);
 } }
  
 void CIMValue::get(Sint16& x) const void CIMValue::get(Sint16& x) const
 { {
     if (_rep->_type != CIMType::SINT16 || _rep->_isArray)      if (_rep->type != CIMTYPE_SINT16 || _rep->isArray)
         throw TypeMismatch();          throw TypeMismatchException();
  
     x = _rep->_u._sint16Value;      if (!_rep->isNull)
           x = CIMValueType<Sint16>::ref(_rep);
 } }
  
   
 void CIMValue::get(Uint32& x) const void CIMValue::get(Uint32& x) const
 { {
     if (_rep->_type != CIMType::UINT32 || _rep->_isArray)      if (_rep->type != CIMTYPE_UINT32 || _rep->isArray)
         throw TypeMismatch();          throw TypeMismatchException();
  
     x = _rep->_u._uint32Value;      if (!_rep->isNull)
           x = CIMValueType<Uint32>::ref(_rep);
 } }
  
 void CIMValue::get(Sint32& x) const void CIMValue::get(Sint32& x) const
 { {
     if (_rep->_type != CIMType::SINT32 || _rep->_isArray)      if (_rep->type != CIMTYPE_SINT32 || _rep->isArray)
         throw TypeMismatch();          throw TypeMismatchException();
  
     x = _rep->_u._sint32Value;      if (!_rep->isNull)
           x = CIMValueType<Sint32>::ref(_rep);
 } }
  
 void CIMValue::get(Uint64& x) const void CIMValue::get(Uint64& x) const
 { {
     if (_rep->_type != CIMType::UINT64 || _rep->_isArray)      if (_rep->type != CIMTYPE_UINT64 || _rep->isArray)
         throw TypeMismatch();          throw TypeMismatchException();
  
     x = _rep->_u._uint64Value;      if (!_rep->isNull)
           x = CIMValueType<Uint64>::ref(_rep);
 } }
  
 void CIMValue::get(Sint64& x) const void CIMValue::get(Sint64& x) const
 { {
     if (_rep->_type != CIMType::SINT64 || _rep->_isArray)      if (_rep->type != CIMTYPE_SINT64 || _rep->isArray)
         throw TypeMismatch();          throw TypeMismatchException();
  
     x = _rep->_u._sint64Value;      if (!_rep->isNull)
           x = CIMValueType<Sint64>::ref(_rep);
 } }
  
 void CIMValue::get(Real32& x) const void CIMValue::get(Real32& x) const
 { {
     if (_rep->_type != CIMType::REAL32 || _rep->_isArray)      if (_rep->type != CIMTYPE_REAL32 || _rep->isArray)
         throw TypeMismatch();          throw TypeMismatchException();
  
     x = _rep->_u._real32Value;      if (!_rep->isNull)
           x = CIMValueType<Real32>::ref(_rep);
 } }
  
 void CIMValue::get(Real64& x) const void CIMValue::get(Real64& x) const
 { {
     if (_rep->_type != CIMType::REAL64 || _rep->_isArray)      if (_rep->type != CIMTYPE_REAL64 || _rep->isArray)
         throw TypeMismatch();          throw TypeMismatchException();
  
     x = _rep->_u._real64Value;      if (!_rep->isNull)
           x = CIMValueType<Real64>::ref(_rep);
 } }
  
 void CIMValue::get(Char16& x) const void CIMValue::get(Char16& x) const
 { {
     if (_rep->_type != CIMType::CHAR16 || _rep->_isArray)      if (_rep->type != CIMTYPE_CHAR16 || _rep->isArray)
         throw TypeMismatch();          throw TypeMismatchException();
  
     x = _rep->_u._char16Value;      if (!_rep->isNull)
           x = CIMValueType<Char16>::ref(_rep);
 } }
  
 void CIMValue::get(String& x) const void CIMValue::get(String& x) const
 { {
     if (_rep->_type != CIMType::STRING || _rep->_isArray)      if (_rep->type != CIMTYPE_STRING || _rep->isArray)
         throw TypeMismatch();          throw TypeMismatchException();
  
     x = *_rep->_u._stringValue;      if (!_rep->isNull)
           x = CIMValueType<String>::ref(_rep);
 } }
  
 void CIMValue::get(CIMDateTime& x) const void CIMValue::get(CIMDateTime& x) const
 { {
     if (_rep->_type != CIMType::DATETIME || _rep->_isArray)      if (_rep->type != CIMTYPE_DATETIME || _rep->isArray)
         throw TypeMismatch();          throw TypeMismatchException();
   
       if (!_rep->isNull)
           x = CIMValueType<CIMDateTime>::ref(_rep);
   }
   
   void CIMValue::get(CIMObjectPath& x) const
   {
       if (_rep->type != CIMTYPE_REFERENCE || _rep->isArray)
           throw TypeMismatchException();
  
     x = *_rep->_u._dateTimeValue;      if (!_rep->isNull)
           x = CIMValueType<CIMObjectPath>::ref(_rep);
 } }
  
 void CIMValue::get(CIMReference& x) const  void CIMValue::get(CIMObject& x) const
 { {
     if (_rep->_type != CIMType::REFERENCE || _rep->_isArray)      if (_rep->type != CIMTYPE_OBJECT || _rep->isArray)
         throw TypeMismatch();          throw TypeMismatchException();
  
     x = *_rep->_u._referenceValue;      if (!_rep->isNull)
           // We have to clone our own unique copy since we are about to
           // return an object to the caller that he can modify; thereby,
           // changing the one we refer to as well.
           x = CIMValueType<CIMObject>::ref(_rep).clone();
 } }
   void CIMValue::get(CIMInstance& x) const
   {
       if (_rep->type != CIMTYPE_INSTANCE || _rep->isArray)
           throw TypeMismatchException();
  
       if (!_rep->isNull)
       {
           // We have to clone our own unique copy since we are about to
           // return an object to the caller that he can modify; thereby,
           // changing the one we refer to as well.
           x = CIMValueType<CIMInstance>::ref(_rep).clone();
       }
   }
 void CIMValue::get(Array<Boolean>& x) const void CIMValue::get(Array<Boolean>& x) const
 { {
     if (_rep->_type != CIMType::BOOLEAN || !_rep->_isArray)      if (_rep->type != CIMTYPE_BOOLEAN || !_rep->isArray)
         throw TypeMismatch();          throw TypeMismatchException();
  
     x.set(_rep->_u._booleanArray);      if (!_rep->isNull)
           x = CIMValueType<Boolean>::aref(_rep);
 } }
  
 void CIMValue::get(Array<Uint8>& x) const void CIMValue::get(Array<Uint8>& x) const
 { {
     if (_rep->_type != CIMType::UINT8 || !_rep->_isArray)      if (_rep->type != CIMTYPE_UINT8 || !_rep->isArray)
         throw TypeMismatch();          throw TypeMismatchException();
  
     x.set(_rep->_u._uint8Array);      if (!_rep->isNull)
           x = CIMValueType<Uint8>::aref(_rep);
 } }
  
 void CIMValue::get(Array<Sint8>& x) const void CIMValue::get(Array<Sint8>& x) const
 { {
     if (_rep->_type != CIMType::SINT8 || !_rep->_isArray)      if (_rep->type != CIMTYPE_SINT8 || !_rep->isArray)
         throw TypeMismatch();          throw TypeMismatchException();
  
     x.set(_rep->_u._sint8Array);      if (!_rep->isNull)
           x = CIMValueType<Sint8>::aref(_rep);
 } }
  
 void CIMValue::get(Array<Uint16>& x) const void CIMValue::get(Array<Uint16>& x) const
 { {
     if (_rep->_type != CIMType::UINT16 || !_rep->_isArray)      if (_rep->type != CIMTYPE_UINT16 || !_rep->isArray)
         throw TypeMismatch();          throw TypeMismatchException();
  
     x.set(_rep->_u._uint16Array);      if (!_rep->isNull)
           x = CIMValueType<Uint16>::aref(_rep);
 } }
  
 void CIMValue::get(Array<Sint16>& x) const void CIMValue::get(Array<Sint16>& x) const
 { {
     if (_rep->_type != CIMType::SINT16 || !_rep->_isArray)      if (_rep->type != CIMTYPE_SINT16 || !_rep->isArray)
         throw TypeMismatch();          throw TypeMismatchException();
  
     x.set(_rep->_u._sint16Array);      if (!_rep->isNull)
           x = CIMValueType<Sint16>::aref(_rep);
 } }
  
 void CIMValue::get(Array<Uint32>& x) const void CIMValue::get(Array<Uint32>& x) const
 { {
     if (_rep->_type != CIMType::UINT32 || !_rep->_isArray)      if (_rep->type != CIMTYPE_UINT32 || !_rep->isArray)
         throw TypeMismatch();          throw TypeMismatchException();
  
     x.set(_rep->_u._uint32Array);      if (!_rep->isNull)
           x = CIMValueType<Uint32>::aref(_rep);
 } }
  
 void CIMValue::get(Array<Sint32>& x) const void CIMValue::get(Array<Sint32>& x) const
 { {
     if (_rep->_type != CIMType::SINT32 || !_rep->_isArray)      if (_rep->type != CIMTYPE_SINT32 || !_rep->isArray)
         throw TypeMismatch();          throw TypeMismatchException();
  
     x.set(_rep->_u._sint32Array);      if (!_rep->isNull)
           x = CIMValueType<Sint32>::aref(_rep);
 } }
  
 void CIMValue::get(Array<Uint64>& x) const void CIMValue::get(Array<Uint64>& x) const
 { {
     if (_rep->_type != CIMType::UINT64 || !_rep->_isArray)      if (_rep->type != CIMTYPE_UINT64 || !_rep->isArray)
         throw TypeMismatch();          throw TypeMismatchException();
  
     x.set(_rep->_u._uint64Array);      if (!_rep->isNull)
           x = CIMValueType<Uint64>::aref(_rep);
 } }
  
 void CIMValue::get(Array<Sint64>& x) const void CIMValue::get(Array<Sint64>& x) const
 { {
     if (_rep->_type != CIMType::SINT64 || !_rep->_isArray)      if (_rep->type != CIMTYPE_SINT64 || !_rep->isArray)
         throw TypeMismatch();          throw TypeMismatchException();
  
     x.set(_rep->_u._sint64Array);      if (!_rep->isNull)
           x = CIMValueType<Sint64>::aref(_rep);
 } }
  
 void CIMValue::get(Array<Real32>& x) const void CIMValue::get(Array<Real32>& x) const
 { {
     if (_rep->_type != CIMType::REAL32 || !_rep->_isArray)      if (_rep->type != CIMTYPE_REAL32 || !_rep->isArray)
         throw TypeMismatch();          throw TypeMismatchException();
  
     x.set(_rep->_u._real32Array);      if (!_rep->isNull)
           x = CIMValueType<Real32>::aref(_rep);
 } }
  
 void CIMValue::get(Array<Real64>& x) const void CIMValue::get(Array<Real64>& x) const
 { {
     if (_rep->_type != CIMType::REAL64 || !_rep->_isArray)      if (_rep->type != CIMTYPE_REAL64 || !_rep->isArray)
         throw TypeMismatch();          throw TypeMismatchException();
  
     x.set(_rep->_u._real64Array);      if (!_rep->isNull)
           x = CIMValueType<Real64>::aref(_rep);
 } }
  
 void CIMValue::get(Array<Char16>& x) const void CIMValue::get(Array<Char16>& x) const
 { {
     if (_rep->_type != CIMType::CHAR16 || !_rep->_isArray)      if (_rep->type != CIMTYPE_CHAR16 || !_rep->isArray)
         throw TypeMismatch();          throw TypeMismatchException();
  
     x.set(_rep->_u._char16Array);      if (!_rep->isNull)
           x = CIMValueType<Char16>::aref(_rep);
 } }
  
 void CIMValue::get(Array<String>& x) const void CIMValue::get(Array<String>& x) const
 { {
     if (_rep->_type != CIMType::STRING || !_rep->_isArray)      if (_rep->type != CIMTYPE_STRING || !_rep->isArray)
         throw TypeMismatch();          throw TypeMismatchException();
  
     x.set(_rep->_u._stringArray);      if (!_rep->isNull)
           x = CIMValueType<String>::aref(_rep);
 } }
  
 void CIMValue::get(Array<CIMDateTime>& x) const void CIMValue::get(Array<CIMDateTime>& x) const
 { {
 #ifdef CIMValueisNullexception      if (_rep->type != CIMTYPE_DATETIME || !_rep->isArray)
     if (_rep->_isNull)          throw TypeMismatchException();
         throw CIMValueIsNull();  
 #endif  
   
     if (_rep->_type != CIMType::DATETIME || !_rep->_isArray)  
         throw TypeMismatch();  
  
     x.set(_rep->_u._dateTimeArray);      if (!_rep->isNull)
           x = CIMValueType<CIMDateTime>::aref(_rep);
 } }
  
 void CIMValue::get(Array<CIMReference>& x) const  void CIMValue::get(Array<CIMObjectPath>& x) const
 { {
     if (_rep->_type != CIMType::REFERENCE || !_rep->_isArray)      if (_rep->type != CIMTYPE_REFERENCE || !_rep->isArray)
         throw TypeMismatch();          throw TypeMismatchException();
  
     x.set(_rep->_u._referenceArray);      if (!_rep->isNull)
           x = CIMValueType<CIMObjectPath>::aref(_rep);
 } }
  
 void CIMValue::toXml(Array<Sint8>& out) const  void CIMValue::get(Array<CIMObject>& x) const
 { {
     /* If the CIMValue is Null, no element is returned.      if (_rep->type != CIMTYPE_OBJECT || !_rep->isArray)
      Note that it output absolutely nothing. This works for          throw TypeMismatchException();
      everything except qualifiers where the value tag is required in  
      any case per the XML specification  
   
      The DMTF has approved a change to the XML Specification  
      that extends the XML Definition to allow the  
      specification of NULL qualifier values. (CR812)  
   
      The definition of the ELEMENT QUALIFIER is now  
      defined as ...  
  
      <!ELEMENT QUALIFIER ((VALUE|VALUE.ARRAY)?)>      if (!_rep->isNull)
   
     */  
   
     if (_rep->_isNull)  
     {  
         return;  
     }  
     if (_rep->_isArray)  
     {     {
         switch (_rep->_type)          x.clear();
         {  
             case CIMType::BOOLEAN:  
             {  
                 _toXml(out, _rep->_u._booleanArray->data(),  
                             _rep->_u._booleanArray->size);  
                 // ATTN-RK-P3-20020220: Is there a reason to do it this way?  
                 //out << "<VALUE.ARRAY>\n";  
                 //for (Uint32 i=0, n = _rep->_u._booleanArray->size; i<n; i++)  
                 //{  
                 //    out << "<VALUE>";  
                 //    _toXml(out, Boolean(_rep->_u._booleanArray->data()[i]));  
                 //    out << "</VALUE>\n";  
                 //}  
                 //out << "</VALUE.ARRAY>\n";  
                 break;  
             }  
  
             case CIMType::UINT8:          // We have to clone our own unique copy since we are about to
                 _toXml(out, _rep->_u._uint8Array->data(),          // return an object to the caller that he can modify; thereby,
                             _rep->_u._uint8Array->size);          // changing the one we refer to as well.
                 break;          for (Uint32 i = 0, n = CIMValueType<CIMObject>::arraySize(_rep);
                i < n; i++)
             case CIMType::SINT8:          {
                 _toXml(out, _rep->_u._sint8Array->data(),              x.append(CIMValueType<CIMObject>::aref(_rep)[i].clone());
                             _rep->_u._sint8Array->size);  
                 break;  
   
             case CIMType::UINT16:  
                 _toXml(out, _rep->_u._uint16Array->data(),  
                             _rep->_u._uint16Array->size);  
                 break;  
   
             case CIMType::SINT16:  
                 _toXml(out, _rep->_u._sint16Array->data(),  
                             _rep->_u._sint16Array->size);  
                 break;  
   
             case CIMType::UINT32:  
                 _toXml(out, _rep->_u._uint32Array->data(),  
                             _rep->_u._uint32Array->size);  
                 break;  
   
             case CIMType::SINT32:  
                 _toXml(out, _rep->_u._sint32Array->data(),  
                             _rep->_u._sint32Array->size);  
                 break;  
   
             case CIMType::UINT64:  
                 _toXml(out, _rep->_u._uint64Array->data(),  
                             _rep->_u._uint64Array->size);  
                 break;  
   
             case CIMType::SINT64:  
                 _toXml(out, _rep->_u._sint64Array->data(),  
                             _rep->_u._sint64Array->size);  
                 break;  
   
             case CIMType::REAL32:  
                 _toXml(out, _rep->_u._real32Array->data(),  
                             _rep->_u._real32Array->size);  
                 break;  
   
             case CIMType::REAL64:  
                 _toXml(out, _rep->_u._real64Array->data(),  
                             _rep->_u._real64Array->size);  
                 break;  
   
             case CIMType::CHAR16:  
                 _toXml(out, _rep->_u._char16Array->data(),  
                             _rep->_u._char16Array->size);  
                 break;  
   
             case CIMType::STRING:  
                 _toXml(out, _rep->_u._stringArray->data(),  
                             _rep->_u._stringArray->size);  
                 break;  
   
             case CIMType::DATETIME:  
                 _toXml(out, _rep->_u._dateTimeArray->data(),  
                             _rep->_u._dateTimeArray->size);  
                 break;  
   
             case CIMType::REFERENCE:  
                 _toXml(out, _rep->_u._referenceArray->data(),  
                             _rep->_u._referenceArray->size);  
                 break;  
   
             default:  
                 throw CIMValueInvalidType();  
         }         }
     }     }
     else if (_rep->_type == CIMType::REFERENCE)  
     {  
         // Has to be separate because it uses VALUE.REFERENCE tag  
         _toXml(out, *_rep->_u._referenceValue);  
     }     }
     else  
     {  
         out << "<VALUE>";  
  
         switch (_rep->_type)  void CIMValue::get(Array<CIMInstance>& x) const
         {         {
             case CIMType::BOOLEAN:      if (_rep->type != CIMTYPE_INSTANCE || !_rep->isArray)
                 _toXml(out, Boolean(_rep->_u._booleanValue != 0));          throw TypeMismatchException();
                 break;  
   
             case CIMType::UINT8:  
                 _toXml(out, _rep->_u._uint8Value);  
                 break;  
   
             case CIMType::SINT8:  
                 _toXml(out, _rep->_u._sint8Value);  
                 break;  
   
             case CIMType::UINT16:  
                 _toXml(out, _rep->_u._uint16Value);  
                 break;  
   
             case CIMType::SINT16:  
                 _toXml(out, _rep->_u._sint16Value);  
                 break;  
   
             case CIMType::UINT32:  
                 _toXml(out, _rep->_u._uint32Value);  
                 break;  
   
             case CIMType::SINT32:  
                 _toXml(out, _rep->_u._sint32Value);  
                 break;  
   
             case CIMType::UINT64:  
                 _toXml(out, _rep->_u._uint64Value);  
                 break;  
  
             case CIMType::SINT64:      if (!_rep->isNull)
                 _toXml(out, _rep->_u._sint64Value);      {
                 break;          x.clear();
   
             case CIMType::REAL32:  
                 _toXml(out, _rep->_u._real32Value);  
                 break;  
   
             case CIMType::REAL64:  
                 _toXml(out, _rep->_u._real64Value);  
                 break;  
   
             case CIMType::CHAR16:  
                 _toXml(out, Char16(_rep->_u._char16Value));  
                 break;  
   
             case CIMType::STRING:  
                 _toXml(out, *_rep->_u._stringValue);  
                 break;  
   
             case CIMType::DATETIME:  
                 _toXml(out, *_rep->_u._dateTimeValue);  
                 break;  
             default:  
                 throw CIMValueInvalidType();  
         }  
  
         out << "</VALUE>\n";          // We have to clone our own unique copy since we are about to
           // return an object to the caller that he can modify; thereby,
           // changing the one we refer to as well.
           for (Uint32 i = 0, n = CIMValueType<CIMInstance>::arraySize(_rep);
                i < n; i++)
           {
               x.append(CIMValueType<CIMInstance>::aref(_rep)[i].clone());
     }     }
 } }
   
 String CIMValue::toXml() const  
 {  
     Array<Sint8> out;  
     toXml(out);  
     out.append('\0');  
     return String(out.getData());  
 } }
  
 void CIMValue::print(PEGASUS_STD(ostream) &os) const  Boolean CIMValue::equal(const CIMValue& x) const
 { {
     Array<Sint8> tmp;      if (!typeCompatible(x))
     toXml(tmp);          return false;
     tmp.append('\0');  
     os << tmp.getData() << PEGASUS_STD(endl);  
 }  
  
 void CIMValue::toMof(Array<Sint8>& out) const      if (_rep->isNull != x._rep->isNull)
 {          return false;
     // if the CIMValue is Null we return nothing.  
     // The alternative is to return the Null indicator.  
     if (_rep->_isNull)  
     {  
         out << "null";  
         return ;  
     }  
  
       if (_rep->isNull)
           return true;
  
     if (_rep->_isArray)      if (_rep->isArray)
     {  
         switch (_rep->_type)  
         {         {
             case CIMType::BOOLEAN:          switch (_rep->type)
             {             {
                 _toMof(out, _rep->_u._booleanArray->data(),              case CIMTYPE_BOOLEAN:
                             _rep->_u._booleanArray->size);                  return CIMValueType<Boolean>::equalArray(_rep, x._rep);
                 break;  
             }  
             case CIMType::UINT8:  
                 _toMof(out, _rep->_u._uint8Array->data(),  
                             _rep->_u._uint8Array->size);  
                 break;  
  
             case CIMType::SINT8:              case CIMTYPE_UINT8:
                 _toMof(out, _rep->_u._sint8Array->data(),                  return CIMValueType<Uint8>::equalArray(_rep, x._rep);
                             _rep->_u._sint8Array->size);  
                 break;  
  
             case CIMType::UINT16:              case CIMTYPE_SINT8:
                 _toMof(out, _rep->_u._uint16Array->data(),                  return CIMValueType<Sint8>::equalArray(_rep, x._rep);
                             _rep->_u._uint16Array->size);  
                 break;  
  
             case CIMType::SINT16:              case CIMTYPE_UINT16:
                 _toMof(out, _rep->_u._sint16Array->data(),                  return CIMValueType<Uint16>::equalArray(_rep, x._rep);
                             _rep->_u._sint16Array->size);  
                 break;  
  
             case CIMType::UINT32:              case CIMTYPE_SINT16:
                 _toMof(out, _rep->_u._uint32Array->data(),                  return CIMValueType<Sint16>::equalArray(_rep, x._rep);
                             _rep->_u._uint32Array->size);  
                 break;  
  
             case CIMType::SINT32:              case CIMTYPE_UINT32:
                 _toMof(out, _rep->_u._sint32Array->data(),                  return CIMValueType<Uint32>::equalArray(_rep, x._rep);
                             _rep->_u._sint32Array->size);  
                 break;  
  
             case CIMType::UINT64:              case CIMTYPE_SINT32:
                 _toMof(out, _rep->_u._uint64Array->data(),                  return CIMValueType<Sint32>::equalArray(_rep, x._rep);
                             _rep->_u._uint64Array->size);  
                 break;  
  
             case CIMType::SINT64:              case CIMTYPE_UINT64:
                 _toMof(out, _rep->_u._sint64Array->data(),                  return CIMValueType<Uint64>::equalArray(_rep, x._rep);
                             _rep->_u._sint64Array->size);  
                 break;  
  
             case CIMType::REAL32:              case CIMTYPE_SINT64:
                 _toMof(out, _rep->_u._real32Array->data(),                  return CIMValueType<Sint64>::equalArray(_rep, x._rep);
                             _rep->_u._real32Array->size);  
                 break;  
  
             case CIMType::REAL64:              case CIMTYPE_REAL32:
                 _toMof(out, _rep->_u._real64Array->data(),                  return CIMValueType<Real32>::equalArray(_rep, x._rep);
                             _rep->_u._real64Array->size);  
                 break;  
  
             case CIMType::CHAR16:              case CIMTYPE_REAL64:
                 _toMof(out, _rep->_u._char16Array->data(),                  return CIMValueType<Real64>::equalArray(_rep, x._rep);
                             _rep->_u._char16Array->size);  
                 break;  
  
             case CIMType::STRING:              case CIMTYPE_CHAR16:
                 _toMof(out, _rep->_u._stringArray->data(),                  return CIMValueType<Char16>::equalArray(_rep, x._rep);
                             _rep->_u._stringArray->size);  
                 break;  
  
             case CIMType::DATETIME:              case CIMTYPE_STRING:
                 _toMof(out, _rep->_u._dateTimeArray->data(),                  return CIMValueType<String>::equalArray(_rep, x._rep);
                             _rep->_u._dateTimeArray->size);  
                 break;  
  
             case CIMType::REFERENCE:              case CIMTYPE_DATETIME:
                 _toMof(out, _rep->_u._referenceArray->data(),                  return CIMValueType<CIMDateTime>::equalArray(_rep, x._rep);
                             _rep->_u._referenceArray->size);  
                 break;  
  
               case CIMTYPE_REFERENCE:
                   return CIMValueType<CIMObjectPath>::equalArray(_rep, x._rep);
   
               case CIMTYPE_OBJECT:
                   return CIMValueType<CIMObject>::equalArray(_rep, x._rep);
               case CIMTYPE_INSTANCE:
                   return CIMValueType<CIMInstance>::equalArray(_rep, x._rep);
             default:             default:
                 throw CIMValueInvalidType();                  PEGASUS_ASSERT(0);
         }         }
     }     }
     else     else
     {     {
         switch (_rep->_type)          switch (_rep->type)
         {         {
             case CIMType::BOOLEAN:              case CIMTYPE_BOOLEAN:
                 _toMof(out, Boolean(_rep->_u._booleanValue != 0));                  return CIMValueType<Boolean>::equal(_rep, x._rep);
                 break;  
  
             case CIMType::UINT8:              case CIMTYPE_UINT8:
                 _toMof(out, _rep->_u._uint8Value);                  return CIMValueType<Uint8>::equal(_rep, x._rep);
                 break;  
  
             case CIMType::SINT8:              case CIMTYPE_SINT8:
                 _toMof(out, _rep->_u._sint8Value);                  return CIMValueType<Sint8>::equal(_rep, x._rep);
                 break;  
  
             case CIMType::UINT16:              case CIMTYPE_UINT16:
                 _toMof(out, _rep->_u._uint16Value);                  return CIMValueType<Uint16>::equal(_rep, x._rep);
                 break;  
  
             case CIMType::SINT16:              case CIMTYPE_SINT16:
                 _toMof(out, _rep->_u._sint16Value);                  return CIMValueType<Sint16>::equal(_rep, x._rep);
                 break;  
  
             case CIMType::UINT32:              case CIMTYPE_UINT32:
                 _toMof(out, _rep->_u._uint32Value);                  return CIMValueType<Uint32>::equal(_rep, x._rep);
                 break;  
  
             case CIMType::SINT32:              case CIMTYPE_SINT32:
                 _toMof(out, _rep->_u._sint32Value);                  return CIMValueType<Sint32>::equal(_rep, x._rep);
                 break;  
  
             case CIMType::UINT64:              case CIMTYPE_UINT64:
                 _toMof(out, _rep->_u._uint64Value);                  return CIMValueType<Uint64>::equal(_rep, x._rep);
                 break;  
  
             case CIMType::SINT64:              case CIMTYPE_SINT64:
                 _toMof(out, _rep->_u._sint64Value);                  return CIMValueType<Sint64>::equal(_rep, x._rep);
                 break;  
  
             case CIMType::REAL32:              case CIMTYPE_REAL32:
                 _toMof(out, _rep->_u._real32Value);                  return CIMValueType<Real32>::equal(_rep, x._rep);
                 break;  
  
             case CIMType::REAL64:              case CIMTYPE_REAL64:
                 _toMof(out, _rep->_u._real64Value);                  return CIMValueType<Real64>::equal(_rep, x._rep);
                 break;  
  
             case CIMType::CHAR16:              case CIMTYPE_CHAR16:
                 _toMof(out, Char16(_rep->_u._char16Value));                  return CIMValueType<Char16>::equal(_rep, x._rep);
                 break;  
  
             case CIMType::STRING:              case CIMTYPE_STRING:
                 _toMof(out, *_rep->_u._stringValue);                  return CIMValueType<String>::equal(_rep, x._rep);
                 break;  
  
             case CIMType::DATETIME:              case CIMTYPE_DATETIME:
                 _toMof(out, *_rep->_u._dateTimeValue);                  return CIMValueType<CIMDateTime>::equal(_rep, x._rep);
                 break;  
  
             case CIMType::REFERENCE:              case CIMTYPE_REFERENCE:
                 _toMof(out, *_rep->_u._referenceValue);                  return CIMValueType<CIMObjectPath>::equal(_rep, x._rep);
                 break;  
  
               case CIMTYPE_OBJECT:
                   return CIMValueType<CIMObject>::ref(_rep).identical(
                       CIMValueType<CIMObject>::ref(x._rep));
               case CIMTYPE_INSTANCE:
                   return CIMValueType<CIMInstance>::ref(_rep).identical(
                       CIMValueType<CIMInstance>::ref(x._rep));
             default:             default:
                 throw CIMValueInvalidType();                  PEGASUS_ASSERT(0);
         }         }
     }     }
   
       return false;
 } }
  
 String CIMValue::toString() const String CIMValue::toString() const
 { {
     Array<Sint8> out;      Buffer out;
  
     //ATTN: Not sure what we should do with getstring for Null CIMValues     //ATTN: Not sure what we should do with getstring for Null CIMValues
     //Choice return empty string or exception out.     //Choice return empty string or exception out.
     if (_rep->_isNull)  
       if (_rep->isNull)
         return String();         return String();
  
     if (_rep->_isArray)      if (_rep->isArray)
     {     {
         switch (_rep->_type)          switch (_rep->type)
         {         {
             case CIMType::BOOLEAN:              case CIMTYPE_BOOLEAN:
             {             {
                 Uint32 size = _rep->_u._booleanArray->size;                  const Array<Boolean>& a = CIMValueType<Boolean>::aref(_rep);
                   Uint32 size = a.size();
   
                 for (Uint32 i = 0; i < size; i++)                 for (Uint32 i = 0; i < size; i++)
                 {                 {
                     _toString(out, Boolean(_rep->_u._booleanArray->data()[i]));                      _toString(out, a[i]);
                     out << " ";                      out.append(' ');
                 }                 }
                 break;                 break;
             }             }
  
             case CIMType::UINT8:              case CIMTYPE_UINT8:
                 _toString(out, _rep->_u._uint8Array->data(),              {
                                _rep->_u._uint8Array->size);                  const Array<Uint8>& a = CIMValueType<Uint8>::aref(_rep);
                   _toString(out, a.getData(), a.size());
                 break;                 break;
               }
  
             case CIMType::SINT8:              case CIMTYPE_SINT8:
                 _toString(out, _rep->_u._sint8Array->data(),              {
                                _rep->_u._sint8Array->size);                  const Array<Sint8>& a = CIMValueType<Sint8>::aref(_rep);
                   _toString(out, a.getData(), a.size());
                 break;                 break;
               }
  
             case CIMType::UINT16:              case CIMTYPE_UINT16:
                 _toString(out, _rep->_u._uint16Array->data(),              {
                                _rep->_u._uint16Array->size);                  const Array<Uint16>& a = CIMValueType<Uint16>::aref(_rep);
                   _toString(out, a.getData(), a.size());
                 break;                 break;
               }
  
             case CIMType::SINT16:              case CIMTYPE_SINT16:
                 _toString(out, _rep->_u._sint16Array->data(),              {
                                _rep->_u._sint16Array->size);                  const Array<Sint16>& a = CIMValueType<Sint16>::aref(_rep);
                   _toString(out, a.getData(), a.size());
                 break;                 break;
               }
  
             case CIMType::UINT32:              case CIMTYPE_UINT32:
                 _toString(out, _rep->_u._uint32Array->data(),              {
                                _rep->_u._uint32Array->size);                  const Array<Uint32>& a = CIMValueType<Uint32>::aref(_rep);
                   _toString(out, a.getData(), a.size());
                 break;                 break;
               }
  
             case CIMType::SINT32:              case CIMTYPE_SINT32:
                 _toString(out, _rep->_u._sint32Array->data(),              {
                                _rep->_u._sint32Array->size);                  const Array<Sint32>& a = CIMValueType<Sint32>::aref(_rep);
                   _toString(out, a.getData(), a.size());
                 break;                 break;
               }
  
             case CIMType::UINT64:              case CIMTYPE_UINT64:
                 _toString(out, _rep->_u._uint64Array->data(),              {
                                _rep->_u._uint64Array->size);                  const Array<Uint64>& a = CIMValueType<Uint64>::aref(_rep);
                   _toString(out, a.getData(), a.size());
                 break;                 break;
               }
  
             case CIMType::SINT64:              case CIMTYPE_SINT64:
                 _toString(out, _rep->_u._sint64Array->data(),              {
                                _rep->_u._sint64Array->size);                  const Array<Sint64>& a = CIMValueType<Sint64>::aref(_rep);
                   _toString(out, a.getData(), a.size());
                 break;                 break;
               }
  
             case CIMType::REAL32:              case CIMTYPE_REAL32:
                 _toString(out, _rep->_u._real32Array->data(),              {
                                _rep->_u._real32Array->size);                  const Array<Real32>& a = CIMValueType<Real32>::aref(_rep);
                   _toString(out, a.getData(), a.size());
                 break;                 break;
               }
  
             case CIMType::REAL64:              case CIMTYPE_REAL64:
                 _toString(out, _rep->_u._real64Array->data(),              {
                                _rep->_u._real64Array->size);                  const Array<Real64>& a = CIMValueType<Real64>::aref(_rep);
                   _toString(out, a.getData(), a.size());
                 break;                 break;
               }
  
             case CIMType::CHAR16:              case CIMTYPE_CHAR16:
                 _toString(out, _rep->_u._char16Array->data(),              {
                                _rep->_u._char16Array->size);                  const Array<Char16>& a = CIMValueType<Char16>::aref(_rep);
                   _toString(out, a.getData(), a.size());
                 break;                 break;
               }
  
             case CIMType::STRING:              case CIMTYPE_STRING:
                 _toString(out, _rep->_u._stringArray->data(),              {
                                _rep->_u._stringArray->size);                  const Array<String>& a = CIMValueType<String>::aref(_rep);
                   _toString(out, a.getData(), a.size());
                 break;                 break;
               }
  
             case CIMType::DATETIME:              case CIMTYPE_DATETIME:
                 _toString(out, _rep->_u._dateTimeArray->data(),              {
                                _rep->_u._dateTimeArray->size);                  const Array<CIMDateTime>& a =
                       CIMValueType<CIMDateTime>::aref(_rep);
                   _toString(out, a.getData(), a.size());
                 break;                 break;
               }
  
             case CIMType::REFERENCE:              case CIMTYPE_REFERENCE:
                 _toString(out, _rep->_u._referenceArray->data(),              {
                                _rep->_u._referenceArray->size);                  const Array<CIMObjectPath>& a =
                       CIMValueType<CIMObjectPath>::aref(_rep);
                   _toString(out, a.getData(), a.size());
                 break;                 break;
               }
  
               case CIMTYPE_OBJECT:
               {
                   const Array<CIMObject>& a = CIMValueType<CIMObject>::aref(_rep);
                   _toString(out, a.getData(), a.size());
                   break;
               }
               case CIMTYPE_INSTANCE:
               {
                   const Array<CIMInstance>& a =
                       CIMValueType<CIMInstance>::aref(_rep);
                   _toString(out, a.getData(), a.size());
                   break;
               }
             default:             default:
                 throw CIMValueInvalidType();                  PEGASUS_ASSERT(0);
         }         }
     }     }
     else     else
     {     {
         switch (_rep->_type)          switch (_rep->type)
         {         {
             case CIMType::BOOLEAN:              case CIMTYPE_BOOLEAN:
                 _toString(out, Boolean(_rep->_u._booleanValue != 0));                  _toString(out, CIMValueType<Boolean>::ref(_rep));
                 break;                 break;
  
             case CIMType::UINT8:              case CIMTYPE_UINT8:
                 _toString(out, _rep->_u._uint8Value);                  _toString(out, CIMValueType<Uint8>::ref(_rep));
                 break;                 break;
  
             case CIMType::SINT8:              case CIMTYPE_SINT8:
                 _toString(out, _rep->_u._sint8Value);                  _toString(out, CIMValueType<Sint8>::ref(_rep));
                 break;                 break;
  
             case CIMType::UINT16:              case CIMTYPE_UINT16:
                 _toString(out, _rep->_u._uint16Value);                  _toString(out, CIMValueType<Uint16>::ref(_rep));
                 break;                 break;
  
             case CIMType::SINT16:              case CIMTYPE_SINT16:
                 _toString(out, _rep->_u._sint16Value);                  _toString(out, CIMValueType<Sint16>::ref(_rep));
                 break;                 break;
  
             case CIMType::UINT32:              case CIMTYPE_UINT32:
                 _toString(out, _rep->_u._uint32Value);                  _toString(out, CIMValueType<Uint32>::ref(_rep));
                 break;                 break;
  
             case CIMType::SINT32:              case CIMTYPE_SINT32:
                 _toString(out, _rep->_u._sint32Value);                  _toString(out, CIMValueType<Sint32>::ref(_rep));
                 break;                 break;
  
             case CIMType::UINT64:              case CIMTYPE_UINT64:
                 _toString(out, _rep->_u._uint64Value);                  _toString(out, CIMValueType<Uint64>::ref(_rep));
                 break;                 break;
  
             case CIMType::SINT64:              case CIMTYPE_SINT64:
                 _toString(out, _rep->_u._sint64Value);                  _toString(out, CIMValueType<Sint64>::ref(_rep));
                 break;                 break;
  
             case CIMType::REAL32:              case CIMTYPE_REAL32:
                 _toString(out, _rep->_u._real32Value);                  _toString(out, CIMValueType<Real32>::ref(_rep));
                 break;                 break;
  
             case CIMType::REAL64:              case CIMTYPE_REAL64:
                 _toString(out, _rep->_u._real64Value);                  _toString(out, CIMValueType<Real64>::ref(_rep));
                 break;                 break;
  
             case CIMType::CHAR16:              case CIMTYPE_CHAR16:
                 _toString(out, Char16(_rep->_u._char16Value));                  _toString(out, CIMValueType<Char16>::ref(_rep));
                 break;                 break;
  
             case CIMType::STRING:              case CIMTYPE_STRING:
                 _toString(out, *_rep->_u._stringValue);                  _toString(out, CIMValueType<String>::ref(_rep));
                 break;                 break;
  
             case CIMType::DATETIME:              case CIMTYPE_DATETIME:
                 _toString(out, *_rep->_u._dateTimeValue);                  _toString(out, CIMValueType<CIMDateTime>::ref(_rep));
                 break;                 break;
  
             case CIMType::REFERENCE:              case CIMTYPE_REFERENCE:
                 _toString(out, *_rep->_u._referenceValue);                  _toString(out, CIMValueType<CIMObjectPath>::ref(_rep));
                 break;                 break;
  
               case CIMTYPE_OBJECT:
                   _toString(out, CIMValueType<CIMObject>::ref(_rep));
                   break;
               case CIMTYPE_INSTANCE:
                   _toString(out, CIMValueType<CIMInstance>::ref(_rep));
                   break;
             default:             default:
                 throw CIMValueInvalidType();                  PEGASUS_ASSERT(0);
         }         }
     }     }
  
     out.append('\0');  
     return out.getData();     return out.getData();
 } }
  
   #ifdef PEGASUS_USE_DEPRECATED_INTERFACES
  
 Boolean operator==(const CIMValue& x, const CIMValue& y)  CIMValue::CIMValue(char x)
 { {
     if (!x.typeCompatible(y))      _rep = new CIMValueRep;
         return false;      CIMValueType<Sint8>::set(_rep, (Sint8)x);
   }
     if (x._rep->_isNull != y._rep->_isNull)  
         return false;  
  
     if (x._rep->_isArray)  CIMValue::CIMValue(const Array<char>& x)
     {  
         switch (x._rep->_type)  
         {         {
             case CIMType::BOOLEAN:      _rep = new CIMValueRep;
                 return Array<Boolean>(x._rep->_u._booleanArray) ==      Array<Sint8> tmp((Sint8*)x.getData(), x.size());
                     Array<Boolean>(y._rep->_u._booleanArray);      CIMValueType<Sint8>::setArray(_rep, tmp);
   
             case CIMType::UINT8:  
                 return Array<Uint8>(x._rep->_u._uint8Array) ==  
                     Array<Uint8>(y._rep->_u._uint8Array);  
   
             case CIMType::SINT8:  
                 return Array<Sint8>(x._rep->_u._sint8Array) ==  
                     Array<Sint8>(y._rep->_u._sint8Array);  
   
             case CIMType::UINT16:  
                 return Array<Uint16>(x._rep->_u._uint16Array) ==  
                     Array<Uint16>(y._rep->_u._uint16Array);  
   
             case CIMType::SINT16:  
                 return Array<Sint16>(x._rep->_u._sint16Array) ==  
                     Array<Sint16>(y._rep->_u._sint16Array);  
   
             case CIMType::UINT32:  
                 return Array<Uint32>(x._rep->_u._uint32Array) ==  
                     Array<Uint32>(y._rep->_u._uint32Array);  
   
             case CIMType::SINT32:  
                 return Array<Sint32>(x._rep->_u._sint32Array) ==  
                     Array<Sint32>(y._rep->_u._sint32Array);  
   
             case CIMType::UINT64:  
                 return Array<Uint64>(x._rep->_u._uint64Array) ==  
                     Array<Uint64>(y._rep->_u._uint64Array);  
   
             case CIMType::SINT64:  
                 return Array<Sint64>(x._rep->_u._sint64Array) ==  
                     Array<Sint64>(y._rep->_u._sint64Array);  
   
             case CIMType::REAL32:  
                 return Array<Real32>(x._rep->_u._real32Array) ==  
                     Array<Real32>(y._rep->_u._real32Array);  
   
             case CIMType::REAL64:  
                 return Array<Real64>(x._rep->_u._real64Array) ==  
                     Array<Real64>(y._rep->_u._real64Array);  
   
             case CIMType::CHAR16:  
                 return Array<Char16>(x._rep->_u._char16Array) ==  
                     Array<Char16>(y._rep->_u._char16Array);  
   
             case CIMType::STRING:  
                 return Array<String>(x._rep->_u._stringArray) ==  
                     Array<String>(y._rep->_u._stringArray);  
   
             case CIMType::DATETIME:  
                 return Array<CIMDateTime>(x._rep->_u._dateTimeArray) ==  
                     Array<CIMDateTime>(y._rep->_u._dateTimeArray);  
   
             case CIMType::REFERENCE:  
                 return Array<CIMReference>(x._rep->_u._referenceArray) ==  
                     Array<CIMReference>(y._rep->_u._referenceArray);  
             default:  
                 throw CIMValueInvalidType();  
         }  
     }     }
     else  
     {  
         switch (x._rep->_type)  
         {  
             case CIMType::BOOLEAN:  
                 return x._rep->_u._booleanValue == y._rep->_u._booleanValue;  
   
             case CIMType::UINT8:  
                 return x._rep->_u._uint8Value == y._rep->_u._uint8Value;  
   
             case CIMType::SINT8:  
                 return x._rep->_u._sint8Value == y._rep->_u._sint8Value;  
   
             case CIMType::UINT16:  
                 return x._rep->_u._uint16Value == y._rep->_u._uint16Value;  
   
             case CIMType::SINT16:  
                 return x._rep->_u._sint16Value == y._rep->_u._sint16Value;  
   
             case CIMType::UINT32:  
                 return x._rep->_u._uint32Value == y._rep->_u._uint32Value;  
   
             case CIMType::SINT32:  
                 return x._rep->_u._sint32Value == y._rep->_u._sint32Value;  
   
             case CIMType::UINT64:  
                 return x._rep->_u._uint64Value == y._rep->_u._uint64Value;  
  
             case CIMType::SINT64:  void CIMValue::set(char x)
                 return x._rep->_u._sint64Value == y._rep->_u._sint64Value;  {
       set(static_cast<Sint8>(x));
             case CIMType::REAL32:  }
                 return x._rep->_u._real32Value == y._rep->_u._real32Value;  
   
             case CIMType::REAL64:  
                 return x._rep->_u._real64Value == y._rep->_u._real64Value;  
  
             case CIMType::CHAR16:  void CIMValue::set(const Array<char>& x)
                 return x._rep->_u._char16Value == y._rep->_u._char16Value;  {
       set(*reinterpret_cast<const Array<Sint8>*>(&x));
   }
  
             case CIMType::STRING:  void CIMValue::get(char& x) const
                 return String::equal(*x._rep->_u._stringValue,  {
                                      *y._rep->_u._stringValue);      get(*reinterpret_cast<Sint8*>(&x));
   }
  
             case CIMType::DATETIME:  void CIMValue::get(Array<char>& x) const
                 return *x._rep->_u._dateTimeValue == *y._rep->_u._dateTimeValue;  {
       get(*reinterpret_cast<Array<Sint8>*>(&x));
   }
  
             case CIMType::REFERENCE:  #endif /* PEGASUS_USE_DEPRECATED_INTERFACES */
                 return *x._rep->_u._referenceValue ==  
                     *y._rep->_u._referenceValue;  
  
             default:  void CIMValue::_get(const String*& data, Uint32& size) const
                 throw CIMValueInvalidType();  {
         }      const Array<String>& a = CIMValueType<String>::aref(_rep);
       data = a.getData();
       size = a.size();
     }     }
  
     // Unreachable!  Boolean operator==(const CIMValue& x, const CIMValue& y)
     return false;  {
       return x.equal(y);
 } }
  
 Boolean operator!=(const CIMValue& x, const CIMValue& y) Boolean operator!=(const CIMValue& x, const CIMValue& y)
 { {
     return !operator==(x, y);      return !x.equal(y);
 } }
  
 PEGASUS_NAMESPACE_END PEGASUS_NAMESPACE_END


Legend:
Removed from v.1.27  
changed lines
  Added in v.1.75

No CVS admin address has been configured
Powered by
ViewCVS 0.9.2