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

Diff for /pegasus/src/Pegasus/Common/XmlWriter.cpp between version 1.24 and 1.95

version 1.24, 2001/12/13 14:54:05 version 1.95, 2003/08/26 20:46:28
Line 1 
Line 1 
 //%///////////////////////////////////////////////////////////////////////////// //%/////////////////////////////////////////////////////////////////////////////
 // //
 // Copyright (c) 2000, 2001 BMC Software, Hewlett-Packard Company, IBM,  // Copyright (c) 2000, 2001, 2002 BMC Software, Hewlett-Packard Company, IBM,
 // The Open Group, Tivoli Systems // The Open Group, Tivoli Systems
 // //
 // Permission is hereby granted, free of charge, to any person obtaining a copy // Permission is hereby granted, free of charge, to any person obtaining a copy
Line 26 
Line 26 
 // Modified By: Nitin Upasani, Hewlett-Packard Company (Nitin_Upasani@hp.com) // Modified By: Nitin Upasani, Hewlett-Packard Company (Nitin_Upasani@hp.com)
 //              Nag Boranna, Hewlett-Packard Company (nagaraja_boranna@hp.com) //              Nag Boranna, Hewlett-Packard Company (nagaraja_boranna@hp.com)
 //              Roger Kumpf, Hewlett-Packard Company (roger_kumpf@hp.com) //              Roger Kumpf, Hewlett-Packard Company (roger_kumpf@hp.com)
   //              Carol Ann Krug Graves, Hewlett-Packard Company
   //                  (carolann_graves@hp.com)
 // //
 //%///////////////////////////////////////////////////////////////////////////// //%/////////////////////////////////////////////////////////////////////////////
  
   #include <Pegasus/Common/Config.h>
 #include <cstdlib> #include <cstdlib>
 #include <cstdio> #include <cstdio>
   #include "Constants.h"
   #include "Destroyer.h"
 #include "CIMClass.h" #include "CIMClass.h"
   #include "CIMClassRep.h"
 #include "CIMInstance.h" #include "CIMInstance.h"
   #include "CIMInstanceRep.h"
   #include "CIMProperty.h"
   #include "CIMPropertyRep.h"
   #include "CIMMethod.h"
   #include "CIMMethodRep.h"
   #include "CIMParameter.h"
   #include "CIMParameterRep.h"
   #include "CIMParamValue.h"
   #include "CIMParamValueRep.h"
   #include "CIMQualifier.h"
   #include "CIMQualifierRep.h"
 #include "CIMQualifierDecl.h" #include "CIMQualifierDecl.h"
   #include "CIMQualifierDeclRep.h"
   #include "CIMValue.h"
 #include "XmlWriter.h" #include "XmlWriter.h"
 #include "XmlParser.h" #include "XmlParser.h"
   #include "Tracer.h"
   #include <Pegasus/Common/StatisticalData.h>
   #include "CommonUTF.h"
  
 PEGASUS_NAMESPACE_BEGIN PEGASUS_NAMESPACE_BEGIN
  
 inline void AppendChar(Array<Sint8>& out, Char16 c)  Array<Sint8>& operator<<(Array<Sint8>& out, const char* x)
 { {
     out.append(Sint8(c));      XmlWriter::append(out, x);
       return out;
 } }
  
 inline void AppendSpecialChar(Array<Sint8>& out, Char16 c)  Array<Sint8>& operator<<(Array<Sint8>& out, char x)
 { {
     // ATTN-B: Only UTF-8 handled for now.      XmlWriter::append(out, x);
       return out;
   }
  
     switch (c)  Array<Sint8>& operator<<(Array<Sint8>& out, const Char16& x)
     {     {
         case '&':      XmlWriter::append(out, x);
             out.append("&amp;", 5);      return out;
             break;  }
   
         case '<':  
             out.append("&lt;", 4);  
             break;  
   
         case '>':  
             out.append("&gt;", 4);  
             break;  
   
         case '"':  
             out.append("&quot;", 6);  
             break;  
   
         case '\'':  
             out.append("&apos;", 6);  
             break;  
  
         default:  Array<Sint8>& operator<<(Array<Sint8>& out, const String& x)
             out.append(Sint8(c));  {
       XmlWriter::append(out, x);
       return out;
     }     }
   
   Array<Sint8>& operator<<(Array<Sint8>& out, const Indentor& x)
   {
       XmlWriter::append(out, x);
       return out;
 } }
  
 void XmlWriter::append(Array<Sint8>& out, Char16 x)  Array<Sint8>& operator<<(Array<Sint8>& out, const Array<Sint8>& x)
 { {
     AppendChar(out, x);      out.appendArray(x);
       return out;
 } }
  
 void XmlWriter::append(Array<Sint8>& out, Uint32 x)  Array<Sint8>& operator<<(Array<Sint8>& out, Uint32 x)
 { {
     char buffer[32];      XmlWriter::append(out, x);
     sprintf(buffer, "%d", x);      return out;
     append(out, buffer);  
 } }
  
 void XmlWriter::append(Array<Sint8>& out, const char* str)  Array<Sint8>& operator<<(Array<Sint8>& out, const CIMName& name)
 { {
     while (*str)      XmlWriter::append(out, name.getString ());
         AppendChar(out, *str++);      return out;
 } }
  
 void XmlWriter::appendSpecial(Array<Sint8>& out, Char16 x)  
   // l10n
   Array<Sint8>& operator<<(Array<Sint8>& out, const AcceptLanguages& al)
 { {
     AppendSpecialChar(out, x);      XmlWriter::append(out, al.toString ());
       return out;
 } }
  
 void XmlWriter::appendSpecial(Array<Sint8>& out, char x)  // l10n
   Array<Sint8>& operator<<(Array<Sint8>& out, const ContentLanguages& cl)
 { {
     AppendSpecialChar(out, Char16(x));      XmlWriter::append(out, cl.toString ());
       return out;
 } }
  
 void XmlWriter::appendSpecial(Array<Sint8>& out, const char* str)  
   PEGASUS_STD(ostream)& operator<<(PEGASUS_STD(ostream)& os, const CIMDateTime& x)
 { {
     while (*str)      return os << x.toString();
         AppendSpecialChar(out, *str++);  
 } }
  
 void XmlWriter::appendSpecial(Array<Sint8>& out, const String& str)  PEGASUS_STD(ostream)& operator<<(PEGASUS_STD(ostream)& os, const CIMName& name)
 { {
     const Char16* tmp = str.getData();      os << name.getString();
       return os;
   }
  
     while (*tmp)  PEGASUS_STD(ostream)& operator<<(PEGASUS_STD(ostream)& os,
         AppendSpecialChar(out, *tmp++);      const CIMNamespaceName& name)
   {
       os << name.getString();
       return os;
 } }
  
 void XmlWriter::append(Array<Sint8>& out, const String& str)  inline void _appendChar(Array<Sint8>& out, const Char16& c)
 { {
     const Char16* tmp = str.getData();      // We need to convert the Char16 to UTF8 then append the UTF8
       // character into the array.
       // NOTE: The UTF8 character could be several bytes long.
       // WARNING: This function will put in replacement character for
       // all characters that have surogate pairs.
       Uint8 str[6];
       memset(str,0x00,sizeof(str));
       Uint8* charIN = (Uint8 *)&c;
   
       const Uint16 *strsrc = (Uint16 *)charIN;
       Uint16 *endsrc = (Uint16 *)&charIN[1];
   
       Uint8 *strtgt = (Uint8 *)str;
       Uint8 *endtgt = (Uint8 *)&str[5];
  
     while (*tmp)      UTF16toUTF8(&strsrc,
         AppendChar(out, *tmp++);                  endsrc,
                   &strtgt,
                   endtgt);
   
       out.append((Sint8 *)str,trailingBytesForUTF8[Uint32(str[0])]+1);
 } }
  
 void XmlWriter::append(Array<Sint8>& out, const Indentor& x)  inline void _appendSpecialChar(Array<Sint8>& out, const Char16& c)
 { {
     for (Uint32 i = 0; i < 4 * x.getLevel(); i++)      if ( ((c < Char16(0x20)) && (c >= Char16(0x00))) || (c == Char16(0x7f)) )
         out.append(' ');      {
           char charref[7];
           sprintf(charref, "&#%u;", (Uint16)c);
           out.append(charref, strlen(charref));
 } }
       else
       {
           switch (c)
           {
               case '&':
                   out.append("&amp;", 5);
                   break;
  
 void XmlWriter::appendLocalNameSpaceElement(              case '<':
     Array<Sint8>& out,                  out.append("&lt;", 4);
     const String& nameSpace)                  break;
   
               case '>':
                   out.append("&gt;", 4);
                   break;
   
               case '"':
                   out.append("&quot;", 6);
                   break;
   
               case '\'':
                   out.append("&apos;", 6);
                   break;
   
               default:
 { {
     out << "<LOCALNAMESPACEPATH>\n";                      // We need to convert the Char16 to UTF8 then append the UTF8
                       // character into the array.
                       // NOTE: The UTF8 character could be several bytes long.
                       // WARNING: This function will put in replacement character for
                       // all characters that have surogate pairs.
                       Uint8 str[6];
                       memset(str,0x00,sizeof(str));
                       Uint8* charIN = (Uint8 *)&c;
   
                       const Uint16 *strsrc = (Uint16 *)charIN;
                       Uint16 *endsrc = (Uint16 *)&charIN[1];
  
     char* tmp = nameSpace.allocateCString();                      Uint8 *strtgt = (Uint8 *)str;
                       Uint8 *endtgt = (Uint8 *)&str[5];
   
                       UTF16toUTF8(&strsrc,
                                   endsrc,
                                   &strtgt,
                                   endtgt);
   
                       Uint32 number1 = trailingBytesForUTF8[Uint32(str[0])]+1;
   
                       out.append((Sint8 *)str,number1);
                   }
           }
       }
   }
  
     for (char* p = strtok(tmp, "/"); p; p = strtok(NULL, "/"))  inline void _appendSpecialChar(Array<Sint8>& out, char c)
     {     {
         out << "<NAMESPACE NAME=\"" << p << "\"/>\n";      if ( ((c < Char16(0x20)) && (c >= Char16(0x00))) || (c == Char16(0x7f)) )
       {
           char charref[7];
           sprintf(charref, "&#%u;", (Uint8)c);
           out.append(charref, strlen(charref));
     }     }
       else
       {
           switch (c)
           {
               case '&':
                   out.append("&amp;", 5);
                   break;
  
     delete [] tmp;              case '<':
                   out.append("&lt;", 4);
                   break;
  
     out << "</LOCALNAMESPACEPATH>\n";              case '>':
                   out.append("&gt;", 4);
                   break;
   
               case '"':
                   out.append("&quot;", 6);
                   break;
   
               case '\'':
                   out.append("&apos;", 6);
                   break;
   
               default:
                   out.append(Sint8(c));
           }
 } }
   }
   
  
 static inline void AppendSpecialChar(PEGASUS_STD(ostream)& os, char c)  static inline void _appendSpecialChar(PEGASUS_STD(ostream)& os, char c)
   {
       if ( (c < Char16(0x20)) || (c == Char16(0x7f)) )
       {
           char charref[7];
           sprintf(charref, "&#%u;", (Uint8)c);
           os << charref;
       }
       else
 { {
     switch (c)     switch (c)
     {     {
Line 177 
Line 305 
             os << c;             os << c;
     }     }
 } }
   }
  
 static inline void AppendSpecial(PEGASUS_STD(ostream)& os, const char* str)  void _appendSurrogatePair(Array<Sint8>& out, Uint16 high, Uint16 low)
 { {
     while (*str)      Uint8 str[6];
         AppendSpecialChar(os, *str++);      Uint8 charIN[5];
 }      memset(str,0x00,sizeof(str));
       memcpy(&charIN,&high,2);
       memcpy(&charIN[2],&low,2);
       const Uint16 *strsrc = (Uint16 *)charIN;
       Uint16 *endsrc = (Uint16 *)&charIN[3];
  
 //------------------------------------------------------------------------------      Uint8 *strtgt = (Uint8 *)str;
 //      Uint8 *endtgt = (Uint8 *)&str[5];
 // formatGetHeader()  
 //  
 //------------------------------------------------------------------------------  
  
 Array<Sint8> XmlWriter::formatGetHeader(      UTF16toUTF8(&strsrc,
     const char* documentPath)                  endsrc,
 {                  &strtgt,
     Array<Sint8> out;                  endtgt);
     return out << "GET " << documentPath << "HTTP/1.0\r\n\r\n";  
 }  
  
 //------------------------------------------------------------------------------      Uint32 number1 = trailingBytesForUTF8[Uint32(str[0])]+1;
 //      out.append((Sint8 *)str,number1);
 // formatMPostHeader()  }
 //  
 //     Build HTTP request header.  
 //  
 //------------------------------------------------------------------------------  
  
 Array<Sint8> XmlWriter::formatMPostHeader(  static inline void _appendSpecial(PEGASUS_STD(ostream)& os, const char* str)
     const char* host,  
     const char* cimOperation,  
     const char* cimMethod,  
     const String& cimObject,  
     const String& authenticationHeader,  
     const Array<Sint8>& content)  
 { {
     Array<Sint8> out;      while (*str)
     out.reserve(1024);          _appendSpecialChar(os, *str++);
     char nn[] = { '0' + (rand() % 10), '0' + (rand() % 10), '\0' };  }
  
     out << "M-POST /cimom HTTP/1.1\r\n";  void XmlWriter::append(Array<Sint8>& out, const Char16& x)
     out << "HOST: " << host << "\r\n";  
     out << "Content-CIMType: application/xml; charset=\"utf-8\"\r\n";  
     out << "Content-Length: " << content.size() << "\r\n";  
     out << "Man: http://www.dmtf.org/cim/mapping/http/v1.0; ns=";  
     out << nn <<"\r\n";  
     out << nn << "-CIMOperation: " << cimOperation << "\r\n";  
     out << nn << "-CIMMethod: " << cimMethod << "\r\n";  
     out << nn << "-CIMObject: " << cimObject << "\r\n";  
     if (authenticationHeader.size())  
     {     {
         out << authenticationHeader << "\r\n";      _appendChar(out, x);
     }     }
     out << "\r\n";  
     out << content;  void XmlWriter::append(Array<Sint8>& out, Boolean x)
     return out;  {
       append(out, (x ? "TRUE" : "FALSE"));
 } }
  
 //------------------------------------------------------------------------------  void XmlWriter::append(Array<Sint8>& out, Uint32 x)
 //  {
 // formatMethodResponseHeader()      char buffer[32];
 //      sprintf(buffer, "%u", x);
 //     Build HTTP response header.      append(out, buffer);
 //  }
 //------------------------------------------------------------------------------  
  
 Array<Sint8> XmlWriter::formatMethodResponseHeader(  void XmlWriter::append(Array<Sint8>& out, Sint32 x)
     const Array<Sint8>& content)  
 { {
     Array<Sint8> out;      char buffer[32];
     out.reserve(1024);      sprintf(buffer, "%d", x);
     char nn[] = { '0' + (rand() % 10), '0' + (rand() % 10), '\0' };      append(out, buffer);
   }
  
     out << "HTTP/1.1 200 OK\r\n";  void XmlWriter::append(Array<Sint8>& out, Uint64 x)
     out << "Content-CIMType: application/xml; charset=\"utf-8\"\r\n";  {
     out << "Content-Length: " << content.size() << "\r\n";      char buffer[32];  // Should need 21 chars max
     out << "Ext:\r\n";      sprintf(buffer, "%" PEGASUS_64BIT_CONVERSION_WIDTH "u", x);
     out << "Cache-Control: no-cache\r\n";      append(out, buffer);
     out << "Man: http://www.dmtf.org/cim/mapping/http/v1.0; ns=";  
     out << nn <<"\r\n";  
     out << nn << "-CIMOperation: MethodResponse\r\n\r\n";  
     out << content;  
     return out;  
 } }
  
 //------------------------------------------------------------------------------  void XmlWriter::append(Array<Sint8>& out, Sint64 x)
 //  {
 // formatMessageElement()      char buffer[32];  // Should need 21 chars max
 //      sprintf(buffer, "%" PEGASUS_64BIT_CONVERSION_WIDTH "d", x);
 //     <!ELEMENT MESSAGE (SIMPLEREQ|MULTIREQ|SIMPLERSP|MULTIRSP)>      append(out, buffer);
 //     <!ATTLIST MESSAGE  }
 //         ID CDATA #REQUIRED  
 //         PROTOCOLVERSION CDATA #REQUIRED>  
 //  
 //------------------------------------------------------------------------------  
  
 Array<Sint8> XmlWriter::formatMessageElement(  void XmlWriter::append(Array<Sint8>& out, Real64 x)
     const String& messageId,  
     const Array<Sint8>& body)  
 { {
     Array<Sint8> out;      char buffer[128];
     out.reserve(1024);      // %e gives '[-]m.dddddde+/-xx', which seems compatible with CIM/XML spec
       sprintf(buffer, "%e", x);
       append(out, buffer);
   }
  
     out << "<?xml version=\"1.0\" encoding=\"utf-8\" ?>\n";  void XmlWriter::append(Array<Sint8>& out, const char* str)
     out << "<CIM CIMVERSION=\"2.0\" DTDVERSION=\"2.0\">\n";  {
     out << "<MESSAGE ID=\"" << messageId << "\" PROTOCOLVERSION=\"1.0\">\n";      while (*str)
     out << body;          _appendChar(out, *str++);
     out << "</MESSAGE>\n";  
     out << "</CIM>\n";  
     return out;  
 } }
  
 //------------------------------------------------------------------------------  void XmlWriter::append(Array<Sint8>& out, const String& str)
 //  {
 // formatSimpleReqElement()      for (Uint32 i = 0; i < str.size(); i++)
 //      {
 //     <!ELEMENT SIMPLEREQ (IMETHODCALL|METHODCALL)>          Uint16 c = str[i];
 //          if(((c >= FIRST_HIGH_SURROGATE) && (c <= LAST_HIGH_SURROGATE)) ||
 //------------------------------------------------------------------------------             ((c >= FIRST_LOW_SURROGATE) && (c <= LAST_LOW_SURROGATE)))
           {
               Char16 highSurrogate = str[i];
               Char16 lowSurrogate = str[++i];
  
 Array<Sint8> XmlWriter::formatSimpleReqElement(              _appendSurrogatePair(out, Uint16(highSurrogate),Uint16(lowSurrogate));
     const Array<Sint8>& body)          }
           else
 { {
     Array<Sint8> out;              _appendChar(out, str[i]);
     return out << "<SIMPLEREQ>\n" << body << "</SIMPLEREQ>\n";          }
       }
 } }
  
 //------------------------------------------------------------------------------  void XmlWriter::append(Array<Sint8>& out, const Indentor& x)
 //  {
 // formatSimpleRspElement()      for (Uint32 i = 0; i < 4 * x.getLevel(); i++)
 //          out.append(' ');
 //     <!ELEMENT SIMPLERSP (METHODRESPONSE|IMETHODRESPONSE)>  }
 //  
 //------------------------------------------------------------------------------  
  
 Array<Sint8> XmlWriter::formatSimpleRspElement(  void XmlWriter::appendSpecial(Array<Sint8>& out, const Char16& x)
     const Array<Sint8>& body)  
 { {
     Array<Sint8> out;      _appendSpecialChar(out, x);
     return out << "<SIMPLERSP>\n" << body << "</SIMPLERSP>\n";  
 } }
  
 //------------------------------------------------------------------------------  void XmlWriter::appendSpecial(Array<Sint8>& out, char x)
 //  {
 // formatIMethodCallElement()      _appendSpecialChar(out, x);
 //  }
 //     <!ELEMENT IMETHODCALL (LOCALNAMESPACEPATH,IPARAMVALUE*)>  
 //     <!ATTLIST IMETHODCALL %CIMName;>  
 //  
 //------------------------------------------------------------------------------  
  
 Array<Sint8> XmlWriter::formatIMethodCallElement(  void XmlWriter::appendSpecial(Array<Sint8>& out, const char* str)
     const char* name,  
     const String& nameSpace,  
     const Array<Sint8>& iParamValues)  
 { {
     Array<Sint8> out;      while (*str)
     out << "<IMETHODCALL NAME=\"" << name << "\">\n";          _appendSpecialChar(out, *str++);
     XmlWriter::appendLocalNameSpaceElement(out, nameSpace);  
     out << iParamValues;  
     out << "</IMETHODCALL>\n";  
     return out;  
 } }
  
 //------------------------------------------------------------------------------  void XmlWriter::appendSpecial(Array<Sint8>& out, const String& str)
 //  {
 // formatIMethodResponseElement()      for (Uint32 i = 0; i < str.size(); i++)
 //      {
 //     <!ELEMENT IMETHODRESPONSE (ERROR|IRETURNVALUE?)>          Uint16 c = str[i];
 //     <!ATTLIST IMETHODRESPONSE %CIMName;>  
 //  
 //------------------------------------------------------------------------------  
  
 Array<Sint8> XmlWriter::formatIMethodResponseElement(          if(((c >= FIRST_HIGH_SURROGATE) && (c <= LAST_HIGH_SURROGATE)) ||
     const char* name,             ((c >= FIRST_LOW_SURROGATE) && (c <= LAST_LOW_SURROGATE)))
     const Array<Sint8>& body)  
 { {
     Array<Sint8> out;              Char16 highSurrogate = str[i];
     out << "<IMETHODRESPONSE NAME=\"" << name << "\">\n";              Char16 lowSurrogate = str[++i];
     out << body;  
     out << "</IMETHODRESPONSE>\n";              _appendSurrogatePair(out, Uint16(highSurrogate),Uint16(lowSurrogate));
     return out;          }
           else
           {
               _appendSpecialChar(out, str[i]);
           }
       }
 } }
  
 //------------------------------------------------------------------------------  // chuck start
 //  
 // formatIReturnValueElement()  // See http://www.ietf.org/rfc/rfc2396.txt section 2
 //  // Reserved characters = ';' '/' '?' ':' '@' '&' '=' '+' '$' ','
 //      <!ELEMENT IRETURNVALUE (CLASSNAME*|INSTANCENAME*|VALUE*|  // Excluded characters:
 //          VALUE.OBJECTWITHPATH*|VALUE.OBJECTWITHLOCALPATH*|VALUE.OBJECT*|  //   Control characters = 0x00-0x1f, 0x7f
 //          OBJECTPATH*|QUALIFIER.DECLARATION*|VALUE.ARRAY?|VALUE.REFERENCE?|  //   Space character = 0x20
 //          CLASS*|INSTANCE*|VALUE.NAMEDINSTANCE*)>  //   Delimiters = '<' '>' '#' '%' '"'
   //   Unwise = '{' '}' '|' '\\' '^' '[' ']' '`'
 // //
 //------------------------------------------------------------------------------  
  
 Array<Sint8> XmlWriter::formatIReturnValueElement(  inline void _encodeURIChar(String& outString, Sint8 char8)
     const Array<Sint8>& body)  
 { {
     Array<Sint8> out;      Uint8 c = (Uint8)char8;
     return out << "<IRETURNVALUE>\n" << body << "</IRETURNVALUE>\n";  
   #ifndef PEGASUS_DO_NOT_IMPLEMENT_URI_ENCODING
       if ( ((c <= 0x20) && (c >= 0x00)) ||    // Control characters + space char
            ( (c >= 0x22) && (c <= 0x26) ) ||  // '"' '#' '$' '%' '&'
            (c == 0x2b) ||                     // '+'
            (c == 0x2c) ||                     // ','
            (c == 0x2f) ||                     // '/'
            ( (c >= 0x3a) && (c <= 0x40) ) ||  // ':' ';' '<' '=' '>' '?' '@'
            ( (c >= 0x5b) && (c <= 0x5e) ) ||  // '[' '\\' ']' '^'
            (c == 0x60) ||                     // '`'
            ( (c >= 0x7b) && (c <= 0x7d) ) ||  // '{' '|' '}'
   //       (c == 0x7f) )                      // Control character
            (c >= 0x7f) )                      // Control character or non US-ASCII (UTF-8)
       {
           char hexencoding[4];
   
           sprintf(hexencoding, "%%%X%X", c/16, c%16);
           outString.append(hexencoding);
       }
       else
   #endif
       {
           outString.append((Uint16)c);
       }
 } }
  
 //------------------------------------------------------------------------------  String XmlWriter::encodeURICharacters(Array<Sint8> uriString)
 //  {
 // formatIParamValueElement()      String encodedString;
 //  
 //     <!ELEMENT IPARAMVALUE (VALUE|VALUE.ARRAY|VALUE.REFERENCE  
 //         |INSTANCENAME|CLASSNAME|QUALIFIER.DECLARATION  
 //         |CLASS|INSTANCE|VALUE.NAMEDINSTANCE)?>  
 //     <!ATTLIST IPARAMVALUE %CIMName;>  
 //  
 //------------------------------------------------------------------------------  
  
 Array<Sint8>& XmlWriter::formatIParamValueElement(      for (Uint32 i=0; i<uriString.size(); i++)
     Array<Sint8>& out,  
     const char* name,  
     const Array<Sint8>& body)  
 { {
     out << "<IPARAMVALUE NAME=\"" << name << "\">\n";          _encodeURIChar(encodedString, uriString[i]);
     out << body;  
     out << "</IPARAMVALUE>\n";  
     return out;  
 } }
  
 //------------------------------------------------------------------------------      return encodedString;
 //  }
 // formatErrorElement()  
 //  
 //------------------------------------------------------------------------------  
  
 Array<Sint8> XmlWriter::formatErrorElement(  String XmlWriter::encodeURICharacters(String uriString)
     CIMStatusCode code,  
     const char* description)  
 { {
     Array<Sint8> out;      String encodedString;
     out << "<ERROR";  
     out << " CODE=\"" << Uint32(code) << "\"";  /* i18n remove - did not handle surrogate pairs
     out << " DESCRIPTION=\"";      for (Uint32 i=0; i<uriString.size(); i++)
     appendSpecial(out, description);      {
     out << "\"/>";          _encodeURIChar(encodedString, uriString[i]);
     return out;      }
   */
   
       // See the "CIM Operations over HTTP" spec, section 3.3.2 and
       // 3.3.3, for the treatment of non US-ASCII (UTF-8) chars
   
       // First, convert to UTF-8 (include handling of surrogate pairs)
       Array<Sint8> utf8;
       for (Uint32 i = 0; i < uriString.size(); i++)
       {
           Uint16 c = uriString[i];
   
           if(((c >= FIRST_HIGH_SURROGATE) && (c <= LAST_HIGH_SURROGATE)) ||
              ((c >= FIRST_LOW_SURROGATE) && (c <= LAST_LOW_SURROGATE)))
           {
               Char16 highSurrogate = uriString[i];
               Char16 lowSurrogate = uriString[++i];
   
               _appendSurrogatePair(utf8, Uint16(highSurrogate),Uint16(lowSurrogate));
           }
           else
           {
               _appendChar(utf8, uriString[i]);
           }
       }
   
       // Second, escape the non HTTP-safe chars
       for (Uint32 i=0; i<utf8.size(); i++)
       {
           _encodeURIChar(encodedString, utf8[i]);
       }
   
       return encodedString;
 } }
  
 //------------------------------------------------------------------------------ //------------------------------------------------------------------------------
 // //
 // appendBooleanParameter()  // appendLocalNameSpacePathElement()
   //
   //     <!ELEMENT LOCALNAMESPACEPATH (NAMESPACE+)>
 // //
 //------------------------------------------------------------------------------ //------------------------------------------------------------------------------
  
 Array<Sint8>& XmlWriter::appendBooleanParameter(  void XmlWriter::appendLocalNameSpacePathElement(
     Array<Sint8>& out,     Array<Sint8>& out,
     const char* name,      const CIMNamespaceName& nameSpace)
     Boolean flag)  
 { {
     Array<Sint8> tmp;      out << "<LOCALNAMESPACEPATH>\n";
     tmp << "<VALUE>" << (flag ? "TRUE" : "FALSE") << "</VALUE>\n";  
     return formatIParamValueElement(out, name, tmp);      char* nameSpaceCopy = strdup(nameSpace.getString().getCStringUTF8());
   #if defined(PEGASUS_PLATFORM_SOLARIS_SPARC_CC) || \
       defined(PEGASUS_OS_HPUX) || \
       defined(PEGASUS_OS_LINUX)
       char *last;
       for (const char* p = strtok_r(nameSpaceCopy, "/", &last); p;
            p = strtok_r(NULL, "/", &last))
   #else
       for (const char* p = strtok(nameSpaceCopy, "/"); p; p = strtok(NULL, "/"))
   #endif
       {
           out << "<NAMESPACE NAME=\"" << p << "\"/>\n";
       }
       delete nameSpaceCopy;
   
       out << "</LOCALNAMESPACEPATH>\n";
 } }
  
 //------------------------------------------------------------------------------ //------------------------------------------------------------------------------
 // //
 // appendStringIParameter()  // appendNameSpacePathElement()
   //
   //     <!ELEMENT NAMESPACEPATH (HOST,LOCALNAMESPACEPATH)>
 // //
 //------------------------------------------------------------------------------ //------------------------------------------------------------------------------
  
 Array<Sint8>& XmlWriter::appendStringIParameter(  void XmlWriter::appendNameSpacePathElement(
     Array<Sint8>& out,     Array<Sint8>& out,
     const char* name,      const String& host,
     const String& str)      const CIMNamespaceName& nameSpace)
 { {
     Array<Sint8> tmp;      out << "<NAMESPACEPATH>\n";
     tmp << "<VALUE>";      out << "<HOST>" << host << "</HOST>\n";
     appendSpecial(tmp, str);      appendLocalNameSpacePathElement(out, nameSpace);
     tmp << "</VALUE>\n";      out << "</NAMESPACEPATH>\n";
     return formatIParamValueElement(out, name, tmp);  
 } }
  
 //------------------------------------------------------------------------------ //------------------------------------------------------------------------------
 // //
 // appendClassNameParameter()  // appendClassNameElement()
   //
   //     <!ELEMENT CLASSNAME EMPTY>
   //     <!ATTLIST CLASSNAME
   //              %CIMName;>
 // //
 //------------------------------------------------------------------------------ //------------------------------------------------------------------------------
  
 Array<Sint8>& XmlWriter::appendClassNameParameter(  void XmlWriter::appendClassNameElement(
     Array<Sint8>& out,     Array<Sint8>& out,
     const char* name,      const CIMName& className)
     const String& className)  
 { {
     Array<Sint8> tmp;      out << "<CLASSNAME NAME=\"" << className << "\"/>\n";
     appendClassNameElement(tmp, className);  
     return formatIParamValueElement(out, name, tmp);  
 } }
  
 //------------------------------------------------------------------------------ //------------------------------------------------------------------------------
 // //
 // appendQualifierNameParameter()  // appendInstanceNameElement()
   //
   //    <!ELEMENT INSTANCENAME (KEYBINDING*|KEYVALUE?|VALUE.REFERENCE?)>
   //    <!ATTLIST INSTANCENAME
   //              %ClassName;>
 // //
 //------------------------------------------------------------------------------ //------------------------------------------------------------------------------
  
 Array<Sint8>& XmlWriter::appendQualifierNameParameter(  void XmlWriter::appendInstanceNameElement(
     Array<Sint8>& out,     Array<Sint8>& out,
     const char* name,      const CIMObjectPath& instanceName)
     const String& qualifierName)  
 { {
     // <!ELEMENT IPARAMVALUE (VALUE|VALUE.ARRAY|VALUE.REFERENCE      out << "<INSTANCENAME CLASSNAME=\"" << instanceName.getClassName() << "\">\n";
     //     |INSTANCENAME|CLASSNAME|QUALIFIER.DECLARATION  
     //     |CLASS|INSTANCE|VALUE.NAMEDINSTANCE)?>  
     //  
     // ATTN: notice that there is really no way to pass a qualifier name  
     // as an IPARAMVALUE element according to the spec (look above). So we  
     // just pass it as a class name. An answer must be obtained later.  
  
     Array<Sint8> tmp;      Array<CIMKeyBinding> keyBindings = instanceName.getKeyBindings();
     appendClassNameElement(tmp, qualifierName);      for (Uint32 i = 0, n = keyBindings.size(); i < n; i++)
     return formatIParamValueElement(out, name, tmp);      {
           out << "<KEYBINDING NAME=\"" << keyBindings[i].getName() << "\">\n";
   
           if (keyBindings[i].getType() == CIMKeyBinding::REFERENCE)
           {
               CIMObjectPath ref = keyBindings[i].getValue();
               appendValueReferenceElement(out, ref, true);
           }
           else {
               out << "<KEYVALUE VALUETYPE=\"";
               out << keyBindingTypeToString(keyBindings[i].getType());
               out << "\">";
   
               // fixed the special character problem - Markus
   
               appendSpecial(out, keyBindings[i].getValue());
               out << "</KEYVALUE>\n";
           }
           out << "</KEYBINDING>\n";
       }
       out << "</INSTANCENAME>\n";
 } }
  
 //------------------------------------------------------------------------------ //------------------------------------------------------------------------------
 // //
 // appendClassParameter()  // appendClassPathElement()
   //
   //     <!ELEMENT CLASSPATH (NAMESPACEPATH,CLASSNAME)>
 // //
 //------------------------------------------------------------------------------ //------------------------------------------------------------------------------
  
 Array<Sint8>& XmlWriter::appendClassParameter(  void XmlWriter::appendClassPathElement(
     Array<Sint8>& out,     Array<Sint8>& out,
     const char* parameterName,      const CIMObjectPath& classPath)
     const CIMConstClass& cimClass)  
 { {
     Array<Sint8> tmp;      out << "<CLASSPATH>\n";
     cimClass.toXml(tmp);      appendNameSpacePathElement(out,
     return formatIParamValueElement(out, parameterName, tmp);                                 classPath.getHost(),
                                  classPath.getNameSpace());
       appendClassNameElement(out, classPath.getClassName());
       out << "</CLASSPATH>\n";
 } }
  
 //------------------------------------------------------------------------------ //------------------------------------------------------------------------------
 // //
 // appendInstanceNameParameter()  // appendInstancePathElement()
   //
   //     <!ELEMENT INSTANCEPATH (NAMESPACEPATH,INSTANCENAME)>
 // //
 //------------------------------------------------------------------------------ //------------------------------------------------------------------------------
  
 Array<Sint8>& XmlWriter::appendInstanceNameParameter(  void XmlWriter::appendInstancePathElement(
     Array<Sint8>& out,     Array<Sint8>& out,
     const char* parameterName,      const CIMObjectPath& instancePath)
     const CIMReference& instanceName)  
 { {
     Array<Sint8> tmp;      out << "<INSTANCEPATH>\n";
     instanceName.instanceNameToXml(tmp);      appendNameSpacePathElement(out,
     return formatIParamValueElement(out, parameterName, tmp);                                 instancePath.getHost(),
                                  instancePath.getNameSpace());
       appendInstanceNameElement(out, instancePath);
       out << "</INSTANCEPATH>\n";
 } }
  
 //------------------------------------------------------------------------------ //------------------------------------------------------------------------------
 // //
 // appendInstanceParameter()  // appendLocalClassPathElement()
   //
   //     <!ELEMENT LOCALCLASSPATH (LOCALNAMESPACEPATH, CLASSNAME)>
 // //
 //------------------------------------------------------------------------------ //------------------------------------------------------------------------------
  
 Array<Sint8>& XmlWriter::appendInstanceParameter(  void XmlWriter::appendLocalClassPathElement(
     Array<Sint8>& out,     Array<Sint8>& out,
     const char* parameterName,      const CIMObjectPath& classPath)
     const CIMConstInstance& instance)  
 { {
     Array<Sint8> tmp;      out << "<LOCALCLASSPATH>\n";
     instance.toXml(tmp);      appendLocalNameSpacePathElement(out, classPath.getNameSpace());
     return formatIParamValueElement(out, parameterName, tmp);      appendClassNameElement(out, classPath.getClassName());
       out << "</LOCALCLASSPATH>\n";
 } }
  
 //------------------------------------------------------------------------------ //------------------------------------------------------------------------------
 // //
 // appendNamedInstanceParameter()  // appendLocalInstancePathElement()
   //
   //     <!ELEMENT LOCALINSTANCEPATH (LOCALNAMESPACEPATH, INSTANCENAME)>
 // //
 //------------------------------------------------------------------------------ //------------------------------------------------------------------------------
  
 Array<Sint8>& XmlWriter::appendNamedInstanceParameter(  void XmlWriter::appendLocalInstancePathElement(
     Array<Sint8>& out,     Array<Sint8>& out,
     const char* parameterName,      const CIMObjectPath& instancePath)
     const CIMNamedInstance& namedInstance)  
 { {
     Array<Sint8> tmp;      out << "<LOCALINSTANCEPATH>\n";
     namedInstance.toXml(tmp);      appendLocalNameSpacePathElement(out, instancePath.getNameSpace());
     return formatIParamValueElement(out, parameterName, tmp);      appendInstanceNameElement(out, instancePath);
       out << "</LOCALINSTANCEPATH>\n";
 } }
  
 //----------------------------------------------------------  //------------------------------------------------------------------------------
 // //
 //  appendPropertyNameParameter()  // appendLocalObjectPathElement()
 // //
 //     </IPARAMVALUE>  //     If the reference refers to an instance, write a LOCALINSTANCEPATH;
 //     <IPARAMVALUE NAME="PropertyName"><VALUE>FreeSpace</VALUE></IPARAMVALUE>  //     otherwise write a LOCALCLASSPATH.
 // //
 //     USE: Create parameter for getProperty operation  //------------------------------------------------------------------------------
 //==========================================================  
 Array<Sint8>& XmlWriter::appendPropertyNameParameter(  void XmlWriter::appendLocalObjectPathElement(
     Array<Sint8>& out,     Array<Sint8>& out,
     const String& propertyName)      const CIMObjectPath& objectPath)
 { {
     Array<Sint8> tmp;  
     tmp << "<VALUE>" << propertyName << "</VALUE>\n";  
     return formatIParamValueElement(out,"PropertyName", tmp);}  
   
 //------------------------------------------------------------------------------  
 // //
 // appendPropertyValueParameter()      //  ATTN-CAKG-P2-20020726:  The following condition does not correctly
       //  distinguish instanceNames from classNames in every case
       //  The instanceName of a singleton instance of a keyless class has no
       //  key bindings
 // //
 //------------------------------------------------------------------------------      if (objectPath.getKeyBindings ().size () != 0)
   
 Array<Sint8>& XmlWriter::appendPropertyValueParameter(  
     Array<Sint8>& out,  
     const char* parameterName,  
     const CIMValue& value)  
 { {
     Array<Sint8> tmp;          appendLocalInstancePathElement(out, objectPath);
     value.toXml(tmp);      }
     return formatIParamValueElement(out, parameterName, tmp);      else
       {
           appendLocalClassPathElement(out, objectPath);
       }
 } }
  
 //------------------------------------------------------------------------------ //------------------------------------------------------------------------------
 // //
 // appendPropertyListParameter()  // Helper functions for appendValueElement()
 // //
 //------------------------------------------------------------------------------ //------------------------------------------------------------------------------
  
 Array<Sint8>& XmlWriter::appendPropertyListParameter(  inline void _appendValue(Array<Sint8>& out, Boolean x)
     Array<Sint8>& out,  
     const CIMPropertyList& propertyList)  
 { {
     Array<Sint8> tmp;      XmlWriter::append(out, x);
   }
  
     tmp << "<VALUE.ARRAY>\n";  inline void _appendValue(Array<Sint8>& out, Uint8 x)
     for (Uint32 i = 0; i < propertyList.getNumProperties(); i++)  
     {     {
         tmp << "<VALUE>" << propertyList.getPropertyName(i) << "</VALUE>\n";      XmlWriter::append(out, Uint32(x));
     }     }
     tmp << "</VALUE.ARRAY>\n";  
     return formatIParamValueElement(out, "PropertyList", tmp);  inline void _appendValue(Array<Sint8>& out, Sint8 x)
   {
       XmlWriter::append(out, Sint32(x));
 } }
  
 //------------------------------------------------------------------------------  inline void _appendValue(Array<Sint8>& out, Uint16 x)
 //  {
 // appendQualifierDeclarationParameter()      XmlWriter::append(out, Uint32(x));
 //  }
 //------------------------------------------------------------------------------  
  
 Array<Sint8>& XmlWriter::appendQualifierDeclarationParameter(  inline void _appendValue(Array<Sint8>& out, Sint16 x)
     Array<Sint8>& out,  
     const char* parameterName,  
     const CIMConstQualifierDecl& qualifierDecl)  
 { {
     Array<Sint8> tmp;      XmlWriter::append(out, Sint32(x));
     qualifierDecl.toXml(tmp);  
     return formatIParamValueElement(out, parameterName, tmp);  
 } }
  
 //------------------------------------------------------------------------------  inline void _appendValue(Array<Sint8>& out, Uint32 x)
 //  {
 // appendClassNameElement()      XmlWriter::append(out, x);
 //  }
 //------------------------------------------------------------------------------  
  
 Array<Sint8>& XmlWriter::appendClassNameElement(  inline void _appendValue(Array<Sint8>& out, Sint32 x)
     Array<Sint8>& out,  
     const String& className)  
 { {
     return out << "<CLASSNAME NAME=\"" << className << "\"/>\n";      XmlWriter::append(out, x);
 } }
  
 //------------------------------------------------------------------------------  inline void _appendValue(Array<Sint8>& out, Uint64 x)
 //  {
 // appendInstanceNameElement()      XmlWriter::append(out, x);
 //  }
 //------------------------------------------------------------------------------  
  
 Array<Sint8>& XmlWriter::appendInstanceNameElement(  inline void _appendValue(Array<Sint8>& out, Sint64 x)
     Array<Sint8>& out,  
     const CIMReference& instanceName)  
 { {
     instanceName.instanceNameToXml(out);      XmlWriter::append(out, x);
     return out;  
 } }
  
 //------------------------------------------------------------------------------  inline void _appendValue(Array<Sint8>& out, Real32 x)
 //  {
 // _printAttributes()      XmlWriter::append(out, Real64(x));
 //  }
 //------------------------------------------------------------------------------  
  
 static void _printAttributes(  inline void _appendValue(Array<Sint8>& out, Real64 x)
     PEGASUS_STD(ostream)& os,  
     const XmlAttribute* attributes,  
     Uint32 attributeCount)  
 { {
     for (Uint32 i = 0; i < attributeCount; i++)      XmlWriter::append(out, x);
   }
   
   inline void _appendValue(Array<Sint8>& out, const Char16& x)
     {     {
         os << attributes[i].name << "=";      XmlWriter::appendSpecial(out, x);
   }
  
         os << '"';  inline void _appendValue(Array<Sint8>& out, const String& x)
         AppendSpecial(os, attributes[i].value);  {
         os << '"';      XmlWriter::appendSpecial(out, x);
   }
  
         if (i + 1 != attributeCount)  inline void _appendValue(Array<Sint8>& out, const CIMDateTime& x)
             os << ' ';  {
       out << x.toString();  //ATTN: append() method?
     }     }
   
   inline void _appendValue(Array<Sint8>& out, const CIMObjectPath& x)
   {
       XmlWriter::appendValueReferenceElement(out, x, true);
 } }
  
 //------------------------------------------------------------------------------  void _appendValueArray(Array<Sint8>& out, const CIMObjectPath* p, Uint32 size)
 //  {
 // _indent()      out << "<VALUE.REFARRAY>\n";
 //      while (size--)
 //------------------------------------------------------------------------------      {
           _appendValue(out, *p++);
       }
       out << "</VALUE.REFARRAY>\n";
   }
  
 static void _indent(PEGASUS_STD(ostream)& os, Uint32 level, Uint32 indentChars)  template<class T>
   void _appendValueArray(Array<Sint8>& out, const T* p, Uint32 size)
 { {
     Uint32 n = level * indentChars;      out << "<VALUE.ARRAY>\n";
  
     for (Uint32 i = 0; i < n; i++)      while (size--)
         os << ' ';      {
           out << "<VALUE>";
           _appendValue(out, *p++);
           out << "</VALUE>\n";
       }
   
       out << "</VALUE.ARRAY>\n";
 } }
  
 //------------------------------------------------------------------------------ //------------------------------------------------------------------------------
 // //
 // indentedPrint()  // appendValueElement()
   //
   //    <!ELEMENT VALUE (#PCDATA)>
   //    <!ELEMENT VALUE.ARRAY (VALUE*)>
   //    <!ELEMENT VALUE.REFERENCE
   //        (CLASSPATH|LOCALCLASSPATH|CLASSNAME|INSTANCEPATH|LOCALINSTANCEPATH|
   //         INSTANCENAME)>
   //    <!ELEMENT VALUE.REFARRAY (VALUE.REFERENCE*)>
 // //
 //------------------------------------------------------------------------------ //------------------------------------------------------------------------------
  
 void XmlWriter::indentedPrint(  void XmlWriter::appendValueElement(
     PEGASUS_STD(ostream)& os,      Array<Sint8>& out,
     const char* text,      const CIMValue& value)
     Uint32 indentChars)  
 { {
     char* tmp = strcpy(new char[strlen(text) + 1], text);      if (value.isNull())
   
     XmlParser parser(tmp);  
     XmlEntry entry;  
     Stack<const char*> stack;  
   
     while (parser.next(entry))  
     {     {
         switch (entry.type)          return;
       }
       if (value.isArray())
         {         {
             case XmlEntry::XML_DECLARATION:          switch (value.getType())
             {             {
                 _indent(os, stack.size(), indentChars);              case CIMTYPE_BOOLEAN:
               {
                 os << "<?" << entry.text << " ";                  Array<Boolean> a;
                 _printAttributes(os, entry.attributes, entry.attributeCount);                  value.get(a);
                 os << "?>";                  _appendValueArray(out, a.getData(), a.size());
                 break;                 break;
             }             }
  
             case XmlEntry::START_TAG:              case CIMTYPE_UINT8:
             {             {
                 _indent(os, stack.size(), indentChars);                  Array<Uint8> a;
                   value.get(a);
                 os << "<" << entry.text;                  _appendValueArray(out, a.getData(), a.size());
   
                 if (entry.attributeCount)  
                     os << ' ';  
   
                 _printAttributes(os, entry.attributes, entry.attributeCount);  
                 os << ">";  
                 stack.push(entry.text);  
                 break;                 break;
             }             }
  
             case XmlEntry::EMPTY_TAG:              case CIMTYPE_SINT8:
             {             {
                 _indent(os, stack.size(), indentChars);                  Array<Sint8> a;
                   value.get(a);
                 os << "<" << entry.text << " ";                  _appendValueArray(out, a.getData(), a.size());
                 _printAttributes(os, entry.attributes, entry.attributeCount);  
                 os << "/>";  
                 break;                 break;
             }             }
  
             case XmlEntry::END_TAG:              case CIMTYPE_UINT16:
             {             {
                 if (!stack.isEmpty() && strcmp(stack.top(), entry.text) == 0)                  Array<Uint16> a;
                     stack.pop();                  value.get(a);
                   _appendValueArray(out, a.getData(), a.size());
                 _indent(os, stack.size(), indentChars);  
   
                 os << "</" << entry.text << ">";  
                 break;                 break;
             }             }
  
             case XmlEntry::COMMENT:              case CIMTYPE_SINT16:
             {             {
                   Array<Sint16> a;
                 _indent(os, stack.size(), indentChars);                  value.get(a);
                 os << "<!--";                  _appendValueArray(out, a.getData(), a.size());
                 AppendSpecial(os, entry.text);  
                 os << "-->";  
                 break;                 break;
             }             }
  
             case XmlEntry::CONTENT:              case CIMTYPE_UINT32:
             {             {
                 _indent(os, stack.size(), indentChars);                  Array<Uint32> a;
                 AppendSpecial(os, entry.text);                  value.get(a);
                   _appendValueArray(out, a.getData(), a.size());
                 break;                 break;
             }             }
  
             case XmlEntry::CDATA:              case CIMTYPE_SINT32:
             {             {
                 _indent(os, stack.size(), indentChars);                  Array<Sint32> a;
                 os << "<![CDATA[...]]>";                  value.get(a);
                   _appendValueArray(out, a.getData(), a.size());
                 break;                 break;
             }             }
  
             case XmlEntry::DOCTYPE:              case CIMTYPE_UINT64:
             {             {
                 _indent(os, stack.size(), indentChars);                  Array<Uint64> a;
                 os << "<!DOCTYPE...>";                  value.get(a);
                   _appendValueArray(out, a.getData(), a.size());
                 break;                 break;
             }             }
         }  
  
         os << PEGASUS_STD(endl);              case CIMTYPE_SINT64:
               {
                   Array<Sint64> a;
                   value.get(a);
                   _appendValueArray(out, a.getData(), a.size());
                   break;
     }     }
  
     delete [] tmp;              case CIMTYPE_REAL32:
               {
                   Array<Real32> a;
                   value.get(a);
                   _appendValueArray(out, a.getData(), a.size());
                   break;
 } }
  
 //------------------------------------------------------------------------------              case CIMTYPE_REAL64:
 //  
 // XmlWriter::getNextMessageId()  
 //  
 //------------------------------------------------------------------------------  
   
 String XmlWriter::getNextMessageId()  
 { {
     // ATTN: make thread-safe:                  Array<Real64> a;
     static Uint32 messageId = 1000;                  value.get(a);
                   _appendValueArray(out, a.getData(), a.size());
     messageId++;                  break;
               }
     if (messageId < 1000)  
         messageId = 1001;  
  
     char buffer[16];              case CIMTYPE_CHAR16:
     sprintf(buffer, "%d", messageId);              {
     return buffer;                  Array<Char16> a;
                   value.get(a);
                   _appendValueArray(out, a.getData(), a.size());
                   break;
 } }
  
 //------------------------------------------------------------------------------              case CIMTYPE_STRING:
 //              {
 // XmlWriter::formatSimpleIMethodReqMessage()                  Array<String> a;
 //                  value.get(a);
 //------------------------------------------------------------------------------                  _appendValueArray(out, a.getData(), a.size());
                   break;
               }
  
 Array<Sint8> XmlWriter::formatSimpleIMethodReqMessage(              case CIMTYPE_DATETIME:
     const char* host,  
     const String& nameSpace,  
     const char* iMethodName,  
     const String& messageId,  
     const String& authenticationHeader,  
     const Array<Sint8>& body)  
 { {
     return XmlWriter::formatMPostHeader(                  Array<CIMDateTime> a;
         host,                  value.get(a);
         "MethodCall",                  _appendValueArray(out, a.getData(), a.size());
         iMethodName,                  break;
         nameSpace,  
         authenticationHeader,  
         XmlWriter::formatMessageElement(  
             messageId,  
             XmlWriter::formatSimpleReqElement(  
                 XmlWriter::formatIMethodCallElement(  
                     iMethodName,  
                     nameSpace,  
                     body))));  
 } }
  
 Array<Sint8> XmlWriter::formatSimpleRspMessage(              case CIMTYPE_REFERENCE:
     const char* iMethodName,  
     const String& messageId,  
     const Array<Sint8>& body)  
 { {
     return XmlWriter::formatMethodResponseHeader(                  Array<CIMObjectPath> a;
         XmlWriter::formatMessageElement(                  value.get(a);
             messageId,                  _appendValueArray(out, a.getData(), a.size());
             XmlWriter::formatSimpleRspElement(                  break;
                 XmlWriter::formatIMethodResponseElement(  
                     iMethodName,  
                     XmlWriter::formatIReturnValueElement(body)))));  
 } }
  
 Array<Sint8>& operator<<(Array<Sint8>& out, const char* x)              default:
                   PEGASUS_ASSERT(false);
           }
       }
       else if (value.getType() == CIMTYPE_REFERENCE)
 { {
     XmlWriter::append(out, x);          // Has to be separate because it uses VALUE.REFERENCE tag
     return out;          CIMObjectPath v;
           value.get(v);
           _appendValue(out, v);
 } }
       else
       {
           out << "<VALUE>";
  
 Array<Sint8>& operator<<(Array<Sint8>& out, char x)          switch (value.getType())
 { {
     XmlWriter::append(out, x);              case CIMTYPE_BOOLEAN:
     return out;              {
                   Boolean v;
                   value.get(v);
                   _appendValue(out, v);
                   break;
 } }
  
 Array<Sint8>& operator<<(Array<Sint8>& out, Char16 x)              case CIMTYPE_UINT8:
 { {
     XmlWriter::append(out, x);                  Uint8 v;
     return out;                  value.get(v);
                   _appendValue(out, v);
                   break;
 } }
  
 Array<Sint8>& operator<<(Array<Sint8>& out, const String& x)              case CIMTYPE_SINT8:
 { {
     XmlWriter::append(out, x);                  Sint8 v;
     return out;                  value.get(v);
                   _appendValue(out, v);
                   break;
 } }
  
 Array<Sint8>& operator<<(Array<Sint8>& out, const Indentor& x)              case CIMTYPE_UINT16:
 { {
     XmlWriter::append(out, x);                  Uint16 v;
     return out;                  value.get(v);
                   _appendValue(out, v);
                   break;
 } }
  
 Array<Sint8>& operator<<(Array<Sint8>& out, const Array<Sint8>& x)              case CIMTYPE_SINT16:
 { {
     out.appendArray(x);                  Sint16 v;
     return out;                  value.get(v);
                   _appendValue(out, v);
                   break;
 } }
  
 Array<Sint8>& operator<<(Array<Sint8>& out, Uint32 x)              case CIMTYPE_UINT32:
 { {
     XmlWriter::append(out, x);                  Uint32 v;
     return out;                  value.get(v);
                   _appendValue(out, v);
                   break;
 } }
  
 Array<Sint8>& XmlWriter::appendObjectNameParameter(              case CIMTYPE_SINT32:
     Array<Sint8>& out,  
     const char* name,  
     const CIMReference& objectName)  
 { {
     if (objectName.isClassName())                  Sint32 v;
                   value.get(v);
                   _appendValue(out, v);
                   break;
               }
   
               case CIMTYPE_UINT64:
     {     {
         XmlWriter::appendClassNameParameter(                  Uint64 v;
             out, name, objectName.getClassName());                  value.get(v);
                   _appendValue(out, v);
                   break;
     }     }
     else  
               case CIMTYPE_SINT64:
     {     {
         XmlWriter::appendInstanceNameParameter(                  Sint64 v;
             out, name, objectName);                  value.get(v);
                   _appendValue(out, v);
                   break;
     }     }
  
     return out;              case CIMTYPE_REAL32:
               {
                   Real32 v;
                   value.get(v);
                   _appendValue(out, v);
                   break;
 } }
  
 Array<Sint8> XmlWriter::formatEMethodCallElement(              case CIMTYPE_REAL64:
     const char* name,  
     const Array<Sint8>& iParamValues)  
 { {
     Array<Sint8> out;                  Real64 v;
     out << "<EXPMETHODCALL NAME=\"" << name << "\">\n";                  value.get(v);
     out << iParamValues;                  _appendValue(out, v);
     out << "</EXPMETHODCALL>\n";                  break;
     return out;  
 } }
  
 Array<Sint8> XmlWriter::formatSimpleIndicationReqMessage(              case CIMTYPE_CHAR16:
     const char* host,  
     const char* iMethodName,  
     const String& messageId,  
     const String& authenticationHeader,  
     const Array<Sint8>& body)  
 { {
     return XmlWriter::formatMPostIndicationHeader(                  Char16 v;
         host,                  value.get(v);
         "MethodRequest",                  _appendValue(out, v);
         iMethodName,                  break;
         authenticationHeader,  
         XmlWriter::formatMessageElement(  
             messageId,  
             XmlWriter::formatSimpleExportReqElement(  
                 XmlWriter::formatEMethodCallElement(  
                     iMethodName,  
                     body))));  
 } }
  
 Array<Sint8> XmlWriter::formatMPostIndicationHeader(              case CIMTYPE_STRING:
     const char* host,  
     const char* cimOperation,  
     const char* cimMethod,  
     const String& authenticationHeader,  
     const Array<Sint8>& content)  
 { {
     Array<Sint8> out;                  String v;
     out.reserve(1024);                  value.get(v);
     char nn[] = { '0' + (rand() % 10), '0' + (rand() % 10), '\0' };                  _appendValue(out, v);
                   break;
               }
  
     out << "M-POST /cimom HTTP/1.1\r\n";              case CIMTYPE_DATETIME:
     out << "HOST: " << host << "\r\n";  
     out << "Content-CIMType: application/xml; charset=\"utf-8\"\r\n";  
     out << "Content-Length: " << content.size() << "\r\n";  
     out << "Man: http://www.hp.com; ns=";  
     out << nn <<"\r\n";  
     out << nn << "-CIMExport: " << cimOperation << "\r\n";  
     out << nn << "-CIMExportMethod: " << cimMethod << "\r\n";  
     if (authenticationHeader.size())  
     {     {
         out << authenticationHeader << "\r\n";                  CIMDateTime v;
                   value.get(v);
                   _appendValue(out, v);
                   break;
     }     }
     out << "\r\n";  
     out << content;              default:
     return out;                  PEGASUS_ASSERT(false);
 } }
  
 Array<Sint8> XmlWriter::formatSimpleExportReqElement(          out << "</VALUE>\n";
     const Array<Sint8>& body)      }
 {  
     Array<Sint8> out;  
     return out << "<SIMPLEEXPREQ>\n" << body << "</SIMPLEEXPREQ>\n";  
 } }
  
 Array<Sint8> XmlWriter::formatSimpleIndicationRspMessage(  void XmlWriter::printValueElement(
     const char* iMethodName,      const CIMValue& value,
     const String& messageId,      PEGASUS_STD(ostream)& os)
     const Array<Sint8>& body)  
 { {
     return XmlWriter::formatEMethodResponseHeader(      Array<Sint8> tmp;
         XmlWriter::formatMessageElement(      appendValueElement(tmp, value);
             messageId,      tmp.append('\0');
             XmlWriter::formatSimpleExportRspElement(      os << tmp.getData() << PEGASUS_STD(endl);
                 XmlWriter::formatEMethodResponseElement(  
                     iMethodName,  
                     XmlWriter::formatIReturnValueElement(body)))));  
 } }
  
 //------------------------------------------------------------------------------ //------------------------------------------------------------------------------
 // //
 // formatSimpleExportRspElement()  // appendValueObjectWithPathElement()
 // //
 //     <!ELEMENT SIMPLEEXPRSP (METHODRESPONSE|EXPMETHODRESPONSE)>  //     <!ELEMENT VALUE.OBJECTWITHPATH
   //         ((CLASSPATH,CLASS)|(INSTANCEPATH,INSTANCE))>
 // //
 //------------------------------------------------------------------------------ //------------------------------------------------------------------------------
  
 Array<Sint8> XmlWriter::formatSimpleExportRspElement(  void XmlWriter::appendValueObjectWithPathElement(
     const Array<Sint8>& body)      Array<Sint8>& out,
       const CIMObject& objectWithPath)
 { {
     Array<Sint8> out;      out << "<VALUE.OBJECTWITHPATH>\n";
     return out << "<SIMPLEEXPRSP>\n" << body << "</SIMPLEEXPRSP>\n";  
       appendValueReferenceElement(out, objectWithPath.getPath (), false);
       appendObjectElement(out, objectWithPath);
   
       out << "</VALUE.OBJECTWITHPATH>\n";
 } }
  
 //------------------------------------------------------------------------------ //------------------------------------------------------------------------------
 // //
 // formatIMethodResponseElement()  // appendValueReferenceElement()
 // //
 //     <!ELEMENT EXPMETHODRESPONSE (ERROR|IRETURNVALUE?)>  //    <!ELEMENT VALUE.REFERENCE
 //     <!ATTLIST EXPMETHODRESPONSE %CIMName;>  //        (CLASSPATH|LOCALCLASSPATH|CLASSNAME|INSTANCEPATH|LOCALINSTANCEPATH|
   //         INSTANCENAME)>
 // //
 //------------------------------------------------------------------------------ //------------------------------------------------------------------------------
  
 Array<Sint8> XmlWriter::formatEMethodResponseElement(  void XmlWriter::appendValueReferenceElement(
     const char* name,      Array<Sint8>& out,
     const Array<Sint8>& body)      const CIMObjectPath& reference,
       Boolean putValueWrapper)
 { {
     Array<Sint8> out;      if (putValueWrapper)
     out << "<EXPMETHODRESPONSE NAME=\"" << name << "\">\n";          out << "<VALUE.REFERENCE>\n";
     out << body;  
     out << "</EXPMETHODRESPONSE>\n";      // See if it is a class or instance reference (instance references have
     return out;      // key-bindings; class references do not).
       //
       //  ATTN-CAKG-P2-20020726:  The following condition does not correctly
       //  distinguish instanceNames from classNames in every case
       //  The instanceName of a singleton instance of a keyless class has no
       //  key bindings
       //
   
       Array<CIMKeyBinding> kbs = reference.getKeyBindings();
   
       if (kbs.size())
       {
           if (reference.getHost().size())
           {
               appendInstancePathElement(out, reference);
           }
           else if (!reference.getNameSpace().isNull())
           {
               appendLocalInstancePathElement(out, reference);
           }
           else
           {
               appendInstanceNameElement(out, reference);
           }
       }
       else
       {
           if (reference.getHost().size())
           {
               appendClassPathElement(out, reference);
           }
           else if (!reference.getNameSpace().isNull())
           {
               appendLocalClassPathElement(out, reference);
           }
           else
           {
               appendClassNameElement(out, reference.getClassName());
           }
       }
   
       if (putValueWrapper)
           out << "</VALUE.REFERENCE>\n";
   }
   
   void XmlWriter::printValueReferenceElement(
       const CIMObjectPath& reference,
       PEGASUS_STD(ostream)& os)
   {
       Array<Sint8> tmp;
       appendValueReferenceElement(tmp, reference, true);
       tmp.append('\0');
       indentedPrint(os, tmp.getData());
 } }
  
 //------------------------------------------------------------------------------ //------------------------------------------------------------------------------
 // //
 // formatMethodResponseHeader()  // appendValueNamedInstanceElement()
 // //
 //     Build HTTP response header.  //     <!ELEMENT VALUE.NAMEDINSTANCE (INSTANCENAME,INSTANCE)>
 // //
 //------------------------------------------------------------------------------ //------------------------------------------------------------------------------
  
 Array<Sint8> XmlWriter::formatEMethodResponseHeader(  void XmlWriter::appendValueNamedInstanceElement(
     const Array<Sint8>& content)      Array<Sint8>& out,
       const CIMInstance& namedInstance)
 { {
     Array<Sint8> out;      out << "<VALUE.NAMEDINSTANCE>\n";
     out.reserve(1024);  
     char nn[] = { '0' + (rand() % 10), '0' + (rand() % 10), '\0' };  
  
     out << "HTTP/1.1 200 OK\r\n";      appendInstanceNameElement(out, namedInstance.getPath ());
     out << "Content-CIMType: application/xml; charset=\"utf-8\"\r\n";      appendInstanceElement(out, namedInstance);
     out << "Content-Length: " << content.size() << "\r\n";  
     out << "Ext:\r\n";      out << "</VALUE.NAMEDINSTANCE>\n";
     out << "Cache-Control: no-cache\r\n";  
     out << "Man:  http://www.dmtf.org/cim/mapping/http/v1.0; ns=";  
     out << nn <<"\r\n";  
     out << nn << "-CIMExport: MethodResponse\r\n\r\n";  
     out << content;  
     return out;  
 } }
  
 //------------------------------------------------------------------------------ //------------------------------------------------------------------------------
 // //
 // XmlWriter::formatSimpleMethodReqMessage()  // appendClassElement()
   //
   //     <!ELEMENT CLASS
   //         (QUALIFIER*,(PROPERTY|PROPERTY.ARRAY|PROPERTY.REFERENCE)*,METHOD*)>
   //     <!ATTLIST CLASS
   //         %CIMName;
   //         %SuperClass;>
 // //
 //------------------------------------------------------------------------------ //------------------------------------------------------------------------------
  
 Array<Sint8> XmlWriter::formatSimpleMethodReqMessage(  void XmlWriter::appendClassElement(
     const char* host,      Array<Sint8>& out,
     const String& nameSpace,      const CIMConstClass& cimclass)
     const char* iMethodName,  
     const String& messageId,  
    const String& authenticationHeader,  
     const Array<Sint8>& body)  
 { {
     return XmlWriter::formatMPostHeader(      cimclass._checkRep();
         host,      cimclass._rep->toXml(out);
         "MethodCall",  }
         iMethodName,  
         nameSpace,  void XmlWriter::printClassElement(
         authenticationHeader,      const CIMConstClass& cimclass,
         XmlWriter::formatMessageElement(      PEGASUS_STD(ostream)& os)
             messageId,  {
             XmlWriter::formatSimpleReqElement(      Array<Sint8> tmp;
                 XmlWriter::formatMethodCallElement(      appendClassElement(tmp, cimclass);
                     iMethodName,      tmp.append('\0');
                     nameSpace,      indentedPrint(os, tmp.getData(), 4);
                     body))));  
 } }
  
 //------------------------------------------------------------------------------ //------------------------------------------------------------------------------
 // //
 // formatMethodCallElement()  // appendInstanceElement()
 // //
 //     <!ELEMENT METHODCALL (LOCALNAMESPACEPATH,IPARAMVALUE*)>  //     <!ELEMENT INSTANCE
 //     <!ATTLIST METHODCALL %CIMName;>  //         (QUALIFIER*,(PROPERTY|PROPERTY.ARRAY|PROPERTY.REFERENCE)*)>
   //     <!ATTLIST INSTANCE
   //         %ClassName;>
 // //
 //------------------------------------------------------------------------------ //------------------------------------------------------------------------------
  
 Array<Sint8> XmlWriter::formatMethodCallElement(  void XmlWriter::appendInstanceElement(
     const char* name,      Array<Sint8>& out,
     const String& nameSpace,      const CIMConstInstance& instance)
     const Array<Sint8>& iParamValues)  
 { {
     Array<Sint8> out;      instance._checkRep();
     out << "<METHODCALL NAME=\"" << name << "\">\n";      instance._rep->toXml(out);
     out << iParamValues;  
     out << "</METHODCALL>\n";  
     return out;  
 } }
  
 Array<Sint8> XmlWriter::formatSimpleMethodRspMessage(  void XmlWriter::printInstanceElement(
     const char* iMethodName,      const CIMConstInstance& instance,
     const String& messageId,      PEGASUS_STD(ostream)& os)
     const Array<Sint8>& body)  
 { {
     /*return XmlWriter::formatMethodResponseHeader(      Array<Sint8> tmp;
         XmlWriter::formatMessageElement(      appendInstanceElement(tmp, instance);
             messageId,      tmp.append('\0');
             XmlWriter::formatSimpleRspElement(      os << tmp.getData() << PEGASUS_STD(endl);
                 XmlWriter::formatMethodResponseElement(  
                     iMethodName,  
                     XmlWriter::formatReturnValueElement(body)))));*/  
     return XmlWriter::formatMethodResponseHeader(  
         XmlWriter::formatMessageElement(  
             messageId,  
             XmlWriter::formatSimpleRspElement(  
                 XmlWriter::formatMethodResponseElement(  
                     iMethodName,  
                     body))));  
 } }
  
 //------------------------------------------------------------------------------ //------------------------------------------------------------------------------
 // //
 // formatMethodResponseElement()  // appendObjectElement()
 // //
 //     <!ELEMENT METHODRESPONSE (ERROR|IRETURNVALUE?)>  // May refer to a CLASS or an INSTANCE
 //     <!ATTLIST METHODRESPONSE %CIMName;>  
 // //
 //------------------------------------------------------------------------------ //------------------------------------------------------------------------------
  
 Array<Sint8> XmlWriter::formatMethodResponseElement(  void XmlWriter::appendObjectElement(
     const char* name,      Array<Sint8>& out,
     const Array<Sint8>& body)      const CIMConstObject& object)
 { {
     Array<Sint8> out;      if (object.isClass())
     out << "<METHODRESPONSE NAME=\"" << name << "\">\n";      {
     out << body;          CIMConstClass c(object);
     out << "</METHODRESPONSE>\n";          appendClassElement(out, c);
     return out;      }
       else if (object.isInstance())
       {
           CIMConstInstance i(object);
           appendInstanceElement(out, i);
       }
       // else PEGASUS_ASSERT(0);
 } }
  
 //------------------------------------------------------------------------------ //------------------------------------------------------------------------------
 // //
 // appendStringParameter()  // appendPropertyElement()
   //
   //     <!ELEMENT PROPERTY (QUALIFIER*,VALUE?)>
   //     <!ATTLIST PROPERTY
   //              %CIMName;
   //              %CIMType;           #REQUIRED
   //              %ClassOrigin;
   //              %Propagated;>
   //
   //     <!ELEMENT PROPERTY.ARRAY (QUALIFIER*,VALUE.ARRAY?)>
   //     <!ATTLIST PROPERTY.ARRAY
   //              %CIMName;
   //              %CIMType;           #REQUIRED
   //              %ArraySize;
   //              %ClassOrigin;
   //              %Propagated;>
   //
   //     <!ELEMENT PROPERTY.REFERENCE (QUALIFIER*,VALUE.REFERENCE?)>
   //     <!ATTLIST PROPERTY.REFERENCE
   //              %CIMName;
   //              %ReferenceClass;
   //              %ClassOrigin;
   //              %Propagated;>
 // //
 //------------------------------------------------------------------------------ //------------------------------------------------------------------------------
  
 Array<Sint8>& XmlWriter::appendStringParameter(  void XmlWriter::appendPropertyElement(
     Array<Sint8>& out,     Array<Sint8>& out,
     const char* name,      const CIMConstProperty& property)
     const String& str)  {
       property._checkRep();
       property._rep->toXml(out);
   }
   
   void XmlWriter::printPropertyElement(
       const CIMConstProperty& property,
       PEGASUS_STD(ostream)& os)
 { {
     Array<Sint8> tmp;     Array<Sint8> tmp;
     tmp << "<VALUE>";      appendPropertyElement(tmp, property);
     appendSpecial(tmp, str);      tmp.append('\0');
     tmp << "</VALUE>\n";      os << tmp.getData() << PEGASUS_STD(endl);
     return formatParamValueElement(out, name, tmp);  
 } }
  
 //------------------------------------------------------------------------------ //------------------------------------------------------------------------------
 // //
 // formatParamValueElement()  // appendMethodElement()
 // //
 //     <!ELEMENT PARAMVALUE (VALUE|VALUE.ARRAY|VALUE.REFERENCE  //     <!ELEMENT METHOD (QUALIFIER*,
 //         |INSTANCENAME|CLASSNAME|QUALIFIER.DECLARATION  //         (PARAMETER|PARAMETER.REFERENCE|PARAMETER.ARRAY|PARAMETER.REFARRAY)*)>
 //         |CLASS|INSTANCE|VALUE.NAMEDINSTANCE)?>  //     <!ATTLIST METHOD
 //     <!ATTLIST PARAMVALUE %CIMName;>  //              %CIMName;
   //              %CIMType;          #IMPLIED
   //              %ClassOrigin;
   //              %Propagated;>
 // //
 //------------------------------------------------------------------------------ //------------------------------------------------------------------------------
  
 Array<Sint8>& XmlWriter::formatParamValueElement(  void XmlWriter::appendMethodElement(
     Array<Sint8>& out,     Array<Sint8>& out,
     const char* name,      const CIMConstMethod& method)
     const Array<Sint8>& body)  
 { {
     out << "<PARAMVALUE NAME=\"" << name << "\">\n";      method._checkRep();
     out << body;      method._rep->toXml(out);
     out << "</PARAMVALUE>\n";  }
     return out;  
   void XmlWriter::printMethodElement(
       const CIMConstMethod& method,
       PEGASUS_STD(ostream)& os)
   {
       Array<Sint8> tmp;
       appendMethodElement(tmp, method);
       tmp.append('\0');
       os << tmp.getData() << PEGASUS_STD(endl);
 } }
  
 //------------------------------------------------------------------------------ //------------------------------------------------------------------------------
 // //
 // formatReturnValueElement()  // appendParameterElement()
 // //
 //      <!ELEMENT RETURNVALUE (CLASSNAME*|INSTANCENAME*|VALUE*|  //     <!ELEMENT PARAMETER (QUALIFIER*)>
 //          VALUE.OBJECTWITHPATH*|VALUE.OBJECTWITHLOCALPATH*|VALUE.OBJECT*|  //     <!ATTLIST PARAMETER
 //          OBJECTPATH*|QUALIFIER.DECLARATION*|VALUE.ARRAY?|VALUE.REFERENCE?|  //              %CIMName;
 //          CLASS*|INSTANCE*|VALUE.NAMEDINSTANCE*)>  //              %CIMType;      #REQUIRED>
   //
   //     <!ELEMENT PARAMETER.REFERENCE (QUALIFIER*)>
   //     <!ATTLIST PARAMETER.REFERENCE
   //              %CIMName;
   //              %ReferenceClass;>
   //
   //     <!ELEMENT PARAMETER.ARRAY (QUALIFIER*)>
   //     <!ATTLIST PARAMETER.ARRAY
   //              %CIMName;
   //              %CIMType;           #REQUIRED
   //              %ArraySize;>
   //
   //     <!ELEMENT PARAMETER.REFARRAY (QUALIFIER*)>
   //     <!ATTLIST PARAMETER.REFARRAY
   //              %CIMName;
   //              %ReferenceClass;
   //              %ArraySize;>
 // //
 //------------------------------------------------------------------------------ //------------------------------------------------------------------------------
  
 Array<Sint8> XmlWriter::formatReturnValueElement(  void XmlWriter::appendParameterElement(
     const Array<Sint8>& body)      Array<Sint8>& out,
       const CIMConstParameter& parameter)
 { {
     Array<Sint8> out;      parameter._checkRep();
     return out << "<RETURNVALUE>\n" << body << "</RETURNVALUE>\n";      parameter._rep->toXml(out);
   }
   
   void XmlWriter::printParameterElement(
       const CIMConstParameter& parameter,
       PEGASUS_STD(ostream)& os)
   {
       Array<Sint8> tmp;
       appendParameterElement(tmp, parameter);
       tmp.append('\0');
       os << tmp.getData() << PEGASUS_STD(endl);
   }
   
   //------------------------------------------------------------------------------
   //
   // appendParamValueElement()
   //
   //     <!ELEMENT PARAMVALUE (VALUE|VALUE.REFERENCE|VALUE.ARRAY|VALUE.REFARRAY)?>
   //     <!ATTLIST PARAMVALUE
   //              %CIMName;>
   //
   //------------------------------------------------------------------------------
   
   void XmlWriter::appendParamValueElement(
       Array<Sint8>& out,
       const CIMParamValue& paramValue)
   {
       paramValue._checkRep();
       paramValue._rep->toXml(out);
   }
   
   void XmlWriter::printParamValueElement(
       const CIMParamValue& paramValue,
       PEGASUS_STD(ostream)& os)
   {
       Array<Sint8> tmp;
       appendParamValueElement(tmp, paramValue);
       tmp.append('\0');
       os << tmp.getData() << PEGASUS_STD(endl);
   }
   
   //------------------------------------------------------------------------------
   //
   // appendQualifierElement()
   //
   //     <!ELEMENT QUALIFIER (VALUE|VALUE.ARRAY)>
   //     <!ATTLIST QUALIFIER
   //              %CIMName;
   //              %CIMType;               #REQUIRED
   //              %Propagated;
   //              %QualifierFlavor;>
   //
   //------------------------------------------------------------------------------
   
   void XmlWriter::appendQualifierElement(
       Array<Sint8>& out,
       const CIMConstQualifier& qualifier)
   {
       qualifier._checkRep();
       qualifier._rep->toXml(out);
   }
   
   void XmlWriter::printQualifierElement(
       const CIMConstQualifier& qualifier,
       PEGASUS_STD(ostream)& os)
   {
       Array<Sint8> tmp;
       appendQualifierElement(tmp, qualifier);
       tmp.append('\0');
       os << tmp.getData() << PEGASUS_STD(endl);
   }
   
   //------------------------------------------------------------------------------
   //
   // appendQualifierDeclElement()
   //
   //     <!ELEMENT QUALIFIER.DECLARATION (SCOPE?,(VALUE|VALUE.ARRAY)?)>
   //     <!ATTLIST QUALIFIER.DECLARATION
   //              %CIMName;
   //              %CIMType;                       #REQUIRED
   //              ISARRAY        (true|false)     #IMPLIED
   //              %ArraySize;
   //              %QualifierFlavor;>
   //
   //------------------------------------------------------------------------------
   
   void XmlWriter::appendQualifierDeclElement(
       Array<Sint8>& out,
       const CIMConstQualifierDecl& qualifierDecl)
   {
       qualifierDecl._checkRep();
       qualifierDecl._rep->toXml(out);
   }
   
   void XmlWriter::printQualifierDeclElement(
       const CIMConstQualifierDecl& qualifierDecl,
       PEGASUS_STD(ostream)& os)
   {
       Array<Sint8> tmp;
       appendQualifierDeclElement(tmp, qualifierDecl);
       tmp.append('\0');
       os << tmp.getData() << PEGASUS_STD(endl);
   }
   
   //------------------------------------------------------------------------------
   //
   // appendQualifierFlavorEntity()
   //
   //     <!ENTITY % QualifierFlavor "OVERRIDABLE  (true|false)   'true'
   //                                 TOSUBCLASS   (true|false)   'true'
   //                                 TOINSTANCE   (true|false)   'false'
   //                                 TRANSLATABLE (true|false)   'false'">
   //
   //------------------------------------------------------------------------------
   
   void XmlWriter::appendQualifierFlavorEntity(
       Array<Sint8>& out,
       const CIMFlavor & flavor)
   {
       if (!(flavor.hasFlavor (CIMFlavor::OVERRIDABLE)))
           out << " OVERRIDABLE=\"false\"";
   
       if (!(flavor.hasFlavor (CIMFlavor::TOSUBCLASS)))
           out << " TOSUBCLASS=\"false\"";
   
       if (flavor.hasFlavor (CIMFlavor::TOINSTANCE))
           out << " TOINSTANCE=\"true\"";
   
       if (flavor.hasFlavor (CIMFlavor::TRANSLATABLE))
           out << " TRANSLATABLE=\"true\"";
   }
   
   //------------------------------------------------------------------------------
   //
   // appendScopeElement()
   //
   //     <!ELEMENT SCOPE EMPTY>
   //     <!ATTLIST SCOPE
   //              CLASS        (true|false)      'false'
   //              ASSOCIATION  (true|false)      'false'
   //              REFERENCE    (true|false)      'false'
   //              PROPERTY     (true|false)      'false'
   //              METHOD       (true|false)      'false'
   //              PARAMETER    (true|false)      'false'
   //              INDICATION   (true|false)      'false'>
   //
   //------------------------------------------------------------------------------
   
   void XmlWriter::appendScopeElement(
       Array<Sint8>& out,
       const CIMScope & scope)
   {
       if (!(scope.equal (CIMScope ())))
       {
           out << "<SCOPE";
   
           if (scope.hasScope (CIMScope::CLASS))
               out << " CLASS=\"true\"";
   
           if (scope.hasScope (CIMScope::ASSOCIATION))
               out << " ASSOCIATION=\"true\"";
   
           if (scope.hasScope (CIMScope::REFERENCE))
               out << " REFERENCE=\"true\"";
   
           if (scope.hasScope (CIMScope::PROPERTY))
               out << " PROPERTY=\"true\"";
   
           if (scope.hasScope (CIMScope::METHOD))
               out << " METHOD=\"true\"";
   
           if (scope.hasScope (CIMScope::PARAMETER))
               out << " PARAMETER=\"true\"";
   
           if (scope.hasScope (CIMScope::INDICATION))
               out << " INDICATION=\"true\"";
   
           out << "/>";
       }
   }
   
   // l10n - added content language and accept language support to
   // the header methods below
   
   //------------------------------------------------------------------------------
   //
   // appendMethodCallHeader()
   //
   //     Build HTTP method call request header.
   //
   //------------------------------------------------------------------------------
   
   void XmlWriter::appendMethodCallHeader(
       Array<Sint8>& out,
       const char* host,
       const CIMName& cimMethod,
       const String& cimObject,
       const String& authenticationHeader,
       HttpMethod httpMethod,
       const AcceptLanguages & acceptLanguages,
       const ContentLanguages & contentLanguages,
       Uint32 contentLength)
   {
       char nn[] = { '0' + (rand() % 10), '0' + (rand() % 10), '\0' };
   
       // ATTN: KS 20020926 - Temporary change to issue only POST. This may
       // be changed in the DMTF CIM Operations standard in the future.
       // If we kept M-Post we would have to retry with Post. Does not
       // do that in client today. Permanent change is to retry until spec
       // updated. This change is temp to finish tests or until the retry
       // installed.  Required because of change to wbemservices cimom
   #if defined PEGASUS_SNIA_INTEROP_TEST || defined PEGASUS_FORCE_POST_METHOD
       out << "POST /cimom HTTP/1.1\r\n";
   #else
       if (httpMethod == HTTP_METHOD_M_POST)
       {
           out << "M-POST /cimom HTTP/1.1\r\n";
       }
       else
       {
           out << "POST /cimom HTTP/1.1\r\n";
       }
   #endif
       out << "HOST: " << host << "\r\n";
       out << "Content-Type: application/xml; charset=\"utf-8\"\r\n";
       out << "Content-Length: " << contentLength << "\r\n";
       if (acceptLanguages.size() > 0)
       {
           out << "Accept-Language: " << acceptLanguages << "\r\n";
       }
       if (contentLanguages.size() > 0)
       {
           out << "Content-Language: " << contentLanguages << "\r\n";
       }
       if (httpMethod == HTTP_METHOD_M_POST)
       {
           out << "Man: http://www.dmtf.org/cim/mapping/http/v1.0; ns=";
           out << nn <<"\r\n";
           out << nn << "-CIMOperation: MethodCall\r\n";
           out << nn << "-CIMMethod: "
               << encodeURICharacters(cimMethod.getString()) << "\r\n";
           out << nn << "-CIMObject: " << encodeURICharacters(cimObject) << "\r\n";
       }
       else
       {
           out << "CIMOperation: MethodCall\r\n";
           out << "CIMMethod: " << encodeURICharacters(cimMethod.getString())
               << "\r\n";
           out << "CIMObject: " << encodeURICharacters(cimObject) << "\r\n";
       }
   
       if (authenticationHeader.size())
       {
           out << authenticationHeader << "\r\n";
       }
       out << "\r\n";
   }
   
   
   //------------------------------------------------------------------------------
   //
   // appendMethodResponseHeader()
   //
   //     Build HTTP response header.
   //
   //------------------------------------------------------------------------------
   
   void XmlWriter::appendMethodResponseHeader(
       Array<Sint8>& out,
       HttpMethod httpMethod,
       const ContentLanguages & contentLanguages,
       Uint32 contentLength)
   {
       char nn[] = { '0' + (rand() % 10), '0' + (rand() % 10), '\0' };
   
       out << "HTTP/1.1 " HTTP_STATUS_OK "\r\n";
       STAT_SERVERTIME
       out << "Content-Type: application/xml; charset=\"utf-8\"\r\n";
       out << "Content-Length: " << contentLength << "\r\n";
       if (contentLanguages.size() > 0)
       {
           out << "Content-Language: " << contentLanguages << "\r\n";
       }
       if (httpMethod == HTTP_METHOD_M_POST)
       {
           out << "Ext:\r\n";
           out << "Cache-Control: no-cache\r\n";
           out << "Man: http://www.dmtf.org/cim/mapping/http/v1.0; ns=";
           out << nn <<"\r\n";
           out << nn << "-CIMOperation: MethodResponse\r\n\r\n";
       }
       else
       {
           out << "CIMOperation: MethodResponse\r\n\r\n";
       }
   }
   
   //------------------------------------------------------------------------------
   //
   // appendHttpErrorResponseHeader()
   //
   //     Build HTTP error response header.
   //
   //     Returns error response message in the following format:
   //
   //        HTTP/1.1 400 Bad Request       (using specified status code)
   //        CIMError: <error type>         (if specified by caller)
   //        PGErrorDetail: <error text>    (if specified by caller)
   //
   //------------------------------------------------------------------------------
   
   void XmlWriter::appendHttpErrorResponseHeader(
       Array<Sint8>& out,
       const String& status,
       const String& cimError,
       const String& errorDetail)
   {
       out << "HTTP/1.1 " << status << "\r\n";
       if (cimError != String::EMPTY)
       {
           out << "CIMError: " << cimError << "\r\n";
       }
       if (errorDetail != String::EMPTY)
       {
           // ATTN-RK-P3-20020404: It is critical that this text not contain '\n'
           // ATTN-RK-P3-20020404: Need to encode this value properly.  (See
           // CIM/HTTP Specification section 3.3.2
           out << PEGASUS_HTTPHEADERTAG_ERRORDETAIL ": "
               << encodeURICharacters(errorDetail) << "\r\n";
       }
       out << "\r\n";
 } }
  
 //------------------------------------------------------------------------------ //------------------------------------------------------------------------------
 // //
 // formatUnauthorizedResponseHeader()  // appendUnauthorizedResponseHeader()
 // //
 //     Build HTTP authentication response header for unauthorized requests. //     Build HTTP authentication response header for unauthorized requests.
 // //
Line 1233 
Line 1819 
 // //
 //------------------------------------------------------------------------------ //------------------------------------------------------------------------------
  
 Array<Sint8> XmlWriter::formatUnauthorizedResponseHeader(  void XmlWriter::appendUnauthorizedResponseHeader(
       Array<Sint8>& out,
     const String& content)     const String& content)
 { {
     Array<Sint8> out;      out << "HTTP/1.1 " HTTP_STATUS_UNAUTHORIZED "\r\n";
     out.reserve(1024);  
   
     out << "HTTP/1.1 401 Unauthorized\r\n";  
     out << content << "\r\n";     out << content << "\r\n";
     out << "\r\n";     out << "\r\n";
  
Line 1251 
Line 1835 
 //    out << "<H2>TEST" << "401 Unauthorized" << "</H2>\r\n"; //    out << "<H2>TEST" << "401 Unauthorized" << "</H2>\r\n";
 //    out << "<HR>\r\n"; //    out << "<HR>\r\n";
 //    out << "</BODY></HTML>\r\n"; //    out << "</BODY></HTML>\r\n";
   }
  
     return out;  #ifdef PEGASUS_KERBEROS_AUTHENTICATION
   //------------------------------------------------------------------------------
   //
   // appendOKResponseHeader()
   //
   //     Build HTTP authentication response header for unauthorized requests.
   //
   //     Returns OK message in the following format:
   //
   //        HTTP/1.1 200 OK
   //        WWW-Authenticate: Negotiate "token"
   //        <HTML><HEAD>
   //        <TITLE>200 OK</TITLE>
   //        </HEAD><BODY BGCOLOR="#99cc99">
   //        <H2>TEST200 OK</H2>
   //        <HR>
   //        </BODY></HTML>
   //
   //------------------------------------------------------------------------------
   
   void XmlWriter::appendOKResponseHeader(
       Array<Sint8>& out,
       const String& content)
   {
       out << "HTTP/1.1 " HTTP_STATUS_OK "\r\n";
       out << content << "\r\n";
       out << "\r\n";
   
   //ATTN: We may need to include the following line, so that the browsers
   //      can display the error message.
   //    out << "<HTML><HEAD>\r\n";
   //    out << "<TITLE>" << "200 OK" <<  "</TITLE>\r\n";
   //    out << "</HEAD><BODY BGCOLOR=\"#99cc99\">\r\n";
   //    out << "<H2>TEST" << "200 OK" << "</H2>\r\n";
   //    out << "<HR>\r\n";
   //    out << "</BODY></HTML>\r\n";
   }
   #endif
   
   //------------------------------------------------------------------------------
   //
   // _appendMessageElementBegin()
   // _appendMessageElementEnd()
   //
   //     <!ELEMENT MESSAGE (SIMPLEREQ|MULTIREQ|SIMPLERSP|MULTIRSP)>
   //     <!ATTLIST MESSAGE
   //         ID CDATA #REQUIRED
   //         PROTOCOLVERSION CDATA #REQUIRED>
   //
   //------------------------------------------------------------------------------
   
   void XmlWriter::_appendMessageElementBegin(
       Array<Sint8>& out,
       const String& messageId)
   {
       out << "<?xml version=\"1.0\" encoding=\"utf-8\" ?>\n";
       out << "<CIM CIMVERSION=\"2.0\" DTDVERSION=\"2.0\">\n";
       out << "<MESSAGE ID=\"" << messageId << "\" PROTOCOLVERSION=\"1.0\">\n";
   }
   
   void XmlWriter::_appendMessageElementEnd(
       Array<Sint8>& out)
   {
       out << "</MESSAGE>\n";
       out << "</CIM>\n";
   }
   
   //------------------------------------------------------------------------------
   //
   // _appendSimpleReqElementBegin()
   // _appendSimpleReqElementEnd()
   //
   //     <!ELEMENT SIMPLEREQ (IMETHODCALL|METHODCALL)>
   //
   //------------------------------------------------------------------------------
   
   void XmlWriter::_appendSimpleReqElementBegin(
       Array<Sint8>& out)
   {
       out << "<SIMPLEREQ>\n";
   }
   
   void XmlWriter::_appendSimpleReqElementEnd(
       Array<Sint8>& out)
   {
       out << "</SIMPLEREQ>\n";
   }
   
   //------------------------------------------------------------------------------
   //
   // _appendMethodCallElementBegin()
   // _appendMethodCallElementEnd()
   //
   //     <!ELEMENT METHODCALL ((LOCALCLASSPATH|LOCALINSTANCEPATH),PARAMVALUE*)>
   //     <!ATTLIST METHODCALL %CIMName;>
   //
   //------------------------------------------------------------------------------
   
   void XmlWriter::_appendMethodCallElementBegin(
       Array<Sint8>& out,
       const CIMName& name)
   {
       out << "<METHODCALL NAME=\"" << name << "\">\n";
   }
   
   void XmlWriter::_appendMethodCallElementEnd(
       Array<Sint8>& out)
   {
       out << "</METHODCALL>\n";
   }
   
   //------------------------------------------------------------------------------
   //
   // _appendIMethodCallElementBegin()
   // _appendIMethodCallElementEnd()
   //
   //     <!ELEMENT IMETHODCALL (LOCALNAMESPACEPATH,IPARAMVALUE*)>
   //     <!ATTLIST IMETHODCALL %CIMName;>
   //
   //------------------------------------------------------------------------------
   
   void XmlWriter::_appendIMethodCallElementBegin(
       Array<Sint8>& out,
       const CIMName& name)
   {
       out << "<IMETHODCALL NAME=\"" << name << "\">\n";
   }
   
   void XmlWriter::_appendIMethodCallElementEnd(
       Array<Sint8>& out)
   {
       out << "</IMETHODCALL>\n";
   }
   
   //------------------------------------------------------------------------------
   //
   // _appendIParamValueElementBegin()
   // _appendIParamValueElementEnd()
   //
   //     <!ELEMENT IPARAMVALUE (VALUE|VALUE.ARRAY|VALUE.REFERENCE
   //         |INSTANCENAME|CLASSNAME|QUALIFIER.DECLARATION
   //         |CLASS|INSTANCE|VALUE.NAMEDINSTANCE)?>
   //     <!ATTLIST IPARAMVALUE %CIMName;>
   //
   //------------------------------------------------------------------------------
   
   void XmlWriter::_appendIParamValueElementBegin(
       Array<Sint8>& out,
       const char* name)
   {
       out << "<IPARAMVALUE NAME=\"" << name << "\">\n";
   }
   
   void XmlWriter::_appendIParamValueElementEnd(
       Array<Sint8>& out)
   {
       out << "</IPARAMVALUE>\n";
   }
   
   //------------------------------------------------------------------------------
   //
   // _appendSimpleRspElementBegin()
   // _appendSimpleRspElementEnd()
   //
   //     <!ELEMENT SIMPLERSP (METHODRESPONSE|IMETHODRESPONSE)>
   //
   //------------------------------------------------------------------------------
   
   void XmlWriter::_appendSimpleRspElementBegin(
       Array<Sint8>& out)
   {
       out << "<SIMPLERSP>\n";
   }
   
   void XmlWriter::_appendSimpleRspElementEnd(
       Array<Sint8>& out)
   {
       out << "</SIMPLERSP>\n";
   }
   
   //------------------------------------------------------------------------------
   //
   // _appendMethodResponseElementBegin()
   // _appendMethodResponseElementEnd()
   //
   //     <!ELEMENT METHODRESPONSE (ERROR|IRETURNVALUE?)>
   //     <!ATTLIST METHODRESPONSE %CIMName;>
   //
   //------------------------------------------------------------------------------
   
   void XmlWriter::_appendMethodResponseElementBegin(
       Array<Sint8>& out,
       const CIMName& name)
   {
       out << "<METHODRESPONSE NAME=\"" << name << "\">\n";
   }
   
   void XmlWriter::_appendMethodResponseElementEnd(
       Array<Sint8>& out)
   {
       out << "</METHODRESPONSE>\n";
   }
   
   //------------------------------------------------------------------------------
   //
   // _appendIMethodResponseElementBegin()
   // _appendIMethodResponseElementEnd()
   //
   //     <!ELEMENT IMETHODRESPONSE (ERROR|IRETURNVALUE?)>
   //     <!ATTLIST IMETHODRESPONSE %CIMName;>
   //
   //------------------------------------------------------------------------------
   
   void XmlWriter::_appendIMethodResponseElementBegin(
       Array<Sint8>& out,
       const CIMName& name)
   {
       out << "<IMETHODRESPONSE NAME=\"" << name << "\">\n";
   }
   
   void XmlWriter::_appendIMethodResponseElementEnd(
       Array<Sint8>& out)
   {
       out << "</IMETHODRESPONSE>\n";
   }
   
   //------------------------------------------------------------------------------
   //
   // _appendErrorElement()
   //
   //------------------------------------------------------------------------------
   
   void XmlWriter::_appendErrorElement(
       Array<Sint8>& out,
       const CIMException& cimException)
   {
       Tracer::traceCIMException(TRC_XML_WRITER, Tracer::LEVEL2, cimException);
   
       out << "<ERROR";
       out << " CODE=\"" << Uint32(cimException.getCode()) << "\"";
       String description = TraceableCIMException(cimException).getDescription();
       if (description != String::EMPTY)
       {
           out << " DESCRIPTION=\"";
           appendSpecial(out, description);
           out << "\"";
       }
       out << "/>";
   }
   
   //------------------------------------------------------------------------------
   //
   // appendReturnValueElement()
   //
   // <!ELEMENT RETURNVALUE (VALUE|VALUE.REFERENCE)>
   // <!ATTLIST RETURNVALUE
   //     %ParamType;>
   //
   //------------------------------------------------------------------------------
   
   void XmlWriter::appendReturnValueElement(
       Array<Sint8>& out,
       const CIMValue& value)
   {
       out << "<RETURNVALUE";
   
       CIMType type = value.getType();
       out << " PARAMTYPE=\"" << cimTypeToString (type) << "\"";
   
       out << ">\n";
   
       // Add value.
       appendValueElement(out, value);
       out << "</RETURNVALUE>\n";
   }
   
   //------------------------------------------------------------------------------
   //
   // _appendIReturnValueElementBegin()
   // _appendIReturnValueElementEnd()
   //
   //      <!ELEMENT IRETURNVALUE (CLASSNAME*|INSTANCENAME*|VALUE*|
   //          VALUE.OBJECTWITHPATH*|VALUE.OBJECTWITHLOCALPATH*|VALUE.OBJECT*|
   //          OBJECTPATH*|QUALIFIER.DECLARATION*|VALUE.ARRAY?|VALUE.REFERENCE?|
   //          CLASS*|INSTANCE*|VALUE.NAMEDINSTANCE*)>
   //
   //------------------------------------------------------------------------------
   
   void XmlWriter::_appendIReturnValueElementBegin(
       Array<Sint8>& out)
   {
       out << "<IRETURNVALUE>\n";
   }
   
   void XmlWriter::_appendIReturnValueElementEnd(
       Array<Sint8>& out)
   {
       out << "</IRETURNVALUE>\n";
   }
   
   //------------------------------------------------------------------------------
   //
   // appendBooleanIParameter()
   //
   //------------------------------------------------------------------------------
   
   void XmlWriter::appendBooleanIParameter(
       Array<Sint8>& out,
       const char* name,
       Boolean flag)
   {
       _appendIParamValueElementBegin(out, name);
       out << "<VALUE>";
       append(out, flag);
       out << "</VALUE>\n";
       _appendIParamValueElementEnd(out);
   }
   
   //------------------------------------------------------------------------------
   //
   // appendStringIParameter()
   //
   //------------------------------------------------------------------------------
   
   void XmlWriter::appendStringIParameter(
       Array<Sint8>& out,
       const char* name,
       const String& str)
   {
       _appendIParamValueElementBegin(out, name);
       out << "<VALUE>";
       appendSpecial(out, str);
       out << "</VALUE>\n";
       _appendIParamValueElementEnd(out);
   }
   
   //------------------------------------------------------------------------------
   //
   // appendQualifierNameIParameter()
   //
   //------------------------------------------------------------------------------
   
   void XmlWriter::appendQualifierNameIParameter(
       Array<Sint8>& out,
       const char* name,
       const String& qualifierName)
   {
       // <!ELEMENT IPARAMVALUE (VALUE|VALUE.ARRAY|VALUE.REFERENCE
       //     |INSTANCENAME|CLASSNAME|QUALIFIER.DECLARATION
       //     |CLASS|INSTANCE|VALUE.NAMEDINSTANCE)?>
       //
       // ATTN: notice that there is really no way to pass a qualifier name
       // as an IPARAMVALUE element according to the spec (look above). So we
       // just pass it as a class name. An answer must be obtained later.
   
       _appendIParamValueElementBegin(out, name);
       appendClassNameElement(out, qualifierName);
       _appendIParamValueElementEnd(out);
   }
   
   //------------------------------------------------------------------------------
   //
   // appendClassNameIParameter()
   //
   //------------------------------------------------------------------------------
   
   void XmlWriter::appendClassNameIParameter(
       Array<Sint8>& out,
       const char* name,
       const CIMName& className)
   {
       _appendIParamValueElementBegin(out, name);
   
       //
       //  A NULL (unassigned) value for a parameter is specified by an
       //  <IPARAMVALUE> element with no subelement
       //
       if (!className.isNull ())
       {
           appendClassNameElement(out, className);
       }
   
       _appendIParamValueElementEnd(out);
   }
   
   //------------------------------------------------------------------------------
   //
   // appendInstanceNameIParameter()
   //
   //------------------------------------------------------------------------------
   
   void XmlWriter::appendInstanceNameIParameter(
       Array<Sint8>& out,
       const char* name,
       const CIMObjectPath& instanceName)
   {
       _appendIParamValueElementBegin(out, name);
       appendInstanceNameElement(out, instanceName);
       _appendIParamValueElementEnd(out);
   }
   
   void XmlWriter::appendObjectNameIParameter(
       Array<Sint8>& out,
       const char* name,
       const CIMObjectPath& objectName)
   {
       //
       //  ATTN-CAKG-P2-20020726:  The following condition does not correctly
       //  distinguish instanceNames from classNames in every case
       //  The instanceName of a singleton instance of a keyless class also
       //  has no key bindings
       //
       if (objectName.getKeyBindings ().size () == 0)
       {
           XmlWriter::appendClassNameIParameter(
               out, name, objectName.getClassName());
       }
       else
       {
           XmlWriter::appendInstanceNameIParameter(
               out, name, objectName);
       }
   }
   
   //------------------------------------------------------------------------------
   //
   // appendClassIParameter()
   //
   //------------------------------------------------------------------------------
   
   void XmlWriter::appendClassIParameter(
       Array<Sint8>& out,
       const char* name,
       const CIMConstClass& cimClass)
   {
       _appendIParamValueElementBegin(out, name);
       appendClassElement(out, cimClass);
       _appendIParamValueElementEnd(out);
   }
   
   //------------------------------------------------------------------------------
   //
   // appendInstanceIParameter()
   //
   //------------------------------------------------------------------------------
   
   void XmlWriter::appendInstanceIParameter(
       Array<Sint8>& out,
       const char* name,
       const CIMConstInstance& instance)
   {
       _appendIParamValueElementBegin(out, name);
       appendInstanceElement(out, instance);
       _appendIParamValueElementEnd(out);
   }
   
   //------------------------------------------------------------------------------
   //
   // appendNamedInstanceIParameter()
   //
   //------------------------------------------------------------------------------
   
   void XmlWriter::appendNamedInstanceIParameter(
       Array<Sint8>& out,
       const char* name,
       const CIMInstance& namedInstance)
   {
       _appendIParamValueElementBegin(out, name);
       appendValueNamedInstanceElement(out, namedInstance);
       _appendIParamValueElementEnd(out);
   }
   
   //----------------------------------------------------------
   //
   //  appendPropertyNameIParameter()
   //
   //     </IPARAMVALUE>
   //     <IPARAMVALUE NAME="PropertyName"><VALUE>FreeSpace</VALUE></IPARAMVALUE>
   //
   //     USE: Create parameter for getProperty operation
   //==========================================================
   void XmlWriter::appendPropertyNameIParameter(
       Array<Sint8>& out,
       const CIMName& propertyName)
   {
       _appendIParamValueElementBegin(out, "PropertyName");
       out << "<VALUE>" << propertyName << "</VALUE>\n";
       _appendIParamValueElementEnd(out);
   }
   
   //------------------------------------------------------------------------------
   //
   // appendPropertyValueIParameter()
   //
   //------------------------------------------------------------------------------
   
   void XmlWriter::appendPropertyValueIParameter(
       Array<Sint8>& out,
       const char* name,
       const CIMValue& value)
   {
       _appendIParamValueElementBegin(out, name);
       appendValueElement(out, value);
       _appendIParamValueElementEnd(out);
   }
   
   //------------------------------------------------------------------------------
   //
   // appendPropertyListIParameter()
   //
   //------------------------------------------------------------------------------
   
   void XmlWriter::appendPropertyListIParameter(
       Array<Sint8>& out,
       const CIMPropertyList& propertyList)
   {
       _appendIParamValueElementBegin(out, "PropertyList");
   
       //
       //  A NULL (unassigned) value for a parameter is specified by an
       //  <IPARAMVALUE> element with no subelement
       //
       if (!propertyList.isNull ())
       {
           out << "<VALUE.ARRAY>\n";
           for (Uint32 i = 0; i < propertyList.size(); i++)
           {
               out << "<VALUE>" << propertyList[i] << "</VALUE>\n";
           }
           out << "</VALUE.ARRAY>\n";
       }
   
       _appendIParamValueElementEnd(out);
   }
   
   //------------------------------------------------------------------------------
   //
   // appendQualifierDeclarationIParameter()
   //
   //------------------------------------------------------------------------------
   
   void XmlWriter::appendQualifierDeclarationIParameter(
       Array<Sint8>& out,
       const char* name,
       const CIMConstQualifierDecl& qualifierDecl)
   {
       _appendIParamValueElementBegin(out, name);
       appendQualifierDeclElement(out, qualifierDecl);
       _appendIParamValueElementEnd(out);
   }
   
   //------------------------------------------------------------------------------
   //
   // XmlWriter::formatHttpErrorRspMessage()
   //
   //------------------------------------------------------------------------------
   
   Array<Sint8> XmlWriter::formatHttpErrorRspMessage(
       const String& status,
       const String& cimError,
       const String& errorDetail)
   {
       Array<Sint8> out;
   
       appendHttpErrorResponseHeader(out, status, cimError, errorDetail);
   
       return out;
   }
   
   // l10n - add content language support to the format methods below
   
   //------------------------------------------------------------------------------
   //
   // XmlWriter::formatSimpleMethodReqMessage()
   //
   //------------------------------------------------------------------------------
   
   // ATTN-RK-P1-20020228: Need to complete copy elimination optimization
   Array<Sint8> XmlWriter::formatSimpleMethodReqMessage(
       const char* host,
       const CIMNamespaceName& nameSpace,
       const CIMObjectPath& path,
       const CIMName& methodName,
       const Array<CIMParamValue>& parameters,
       const String& messageId,
       HttpMethod httpMethod,
       const String& authenticationHeader,
       const AcceptLanguages& httpAcceptLanguages,
       const ContentLanguages& httpContentLanguages)
   {
       Array<Sint8> out;
       Array<Sint8> tmp;
       CIMObjectPath localObjectPath = path;
       localObjectPath.setNameSpace(nameSpace.getString());
       localObjectPath.setHost(String::EMPTY);
   
       _appendMessageElementBegin(out, messageId);
       _appendSimpleReqElementBegin(out);
       _appendMethodCallElementBegin(out, methodName);
       appendLocalObjectPathElement(out, localObjectPath);
       for (Uint32 i=0; i < parameters.size(); i++)
       {
           appendParamValueElement(out, parameters[i]);
       }
       _appendMethodCallElementEnd(out);
       _appendSimpleReqElementEnd(out);
       _appendMessageElementEnd(out);
   
       appendMethodCallHeader(
           tmp,
           host,
           methodName,
           localObjectPath.toString(),
           authenticationHeader,
           httpMethod,
           httpAcceptLanguages,
           httpContentLanguages,
           out.size());
       tmp << out;
   
       return tmp;
   }
   
   Array<Sint8> XmlWriter::formatSimpleMethodRspMessage(
       const CIMName& methodName,
       const String& messageId,
       HttpMethod httpMethod,
       const ContentLanguages & httpContentLanguages,
       const Array<Sint8>& body)
   {
       Array<Sint8> out;
       Array<Sint8> tmp;
   
       _appendMessageElementBegin(out, messageId);
       _appendSimpleRspElementBegin(out);
       _appendMethodResponseElementBegin(out, methodName);
       out << body;
       _appendMethodResponseElementEnd(out);
       _appendSimpleRspElementEnd(out);
       _appendMessageElementEnd(out);
   
       appendMethodResponseHeader(tmp,
           httpMethod,
           httpContentLanguages,
           out.size());
       tmp << out;
   
       return tmp;
   }
   
   //------------------------------------------------------------------------------
   //
   // XmlWriter::formatSimpleMethodErrorRspMessage()
   //
   //------------------------------------------------------------------------------
   
   Array<Sint8> XmlWriter::formatSimpleMethodErrorRspMessage(
       const CIMName& methodName,
       const String& messageId,
       HttpMethod httpMethod,
       const CIMException& cimException)
   {
       Array<Sint8> out;
       Array<Sint8> tmp;
   
       _appendMessageElementBegin(out, messageId);
       _appendSimpleRspElementBegin(out);
       _appendMethodResponseElementBegin(out, methodName);
       _appendErrorElement(out, cimException);
       _appendMethodResponseElementEnd(out);
       _appendSimpleRspElementEnd(out);
       _appendMessageElementEnd(out);
   
   // l10n
       appendMethodResponseHeader(tmp,
           httpMethod,
           cimException.getContentLanguages(),
           out.size());
       tmp << out;
   
       return tmp;
   }
   
   //------------------------------------------------------------------------------
   //
   // XmlWriter::formatSimpleIMethodReqMessage()
   //
   //------------------------------------------------------------------------------
   
   Array<Sint8> XmlWriter::formatSimpleIMethodReqMessage(
       const char* host,
       const CIMNamespaceName& nameSpace,
       const CIMName& iMethodName,
       const String& messageId,
       HttpMethod httpMethod,
       const String& authenticationHeader,
       const AcceptLanguages& httpAcceptLanguages,
       const ContentLanguages& httpContentLanguages,
       const Array<Sint8>& body)
   {
       Array<Sint8> out;
       Array<Sint8> tmp;
   
       _appendMessageElementBegin(out, messageId);
       _appendSimpleReqElementBegin(out);
       _appendIMethodCallElementBegin(out, iMethodName);
       appendLocalNameSpacePathElement(out, nameSpace.getString());
       out << body;
       _appendIMethodCallElementEnd(out);
       _appendSimpleReqElementEnd(out);
       _appendMessageElementEnd(out);
   
       appendMethodCallHeader(
           tmp,
           host,
           iMethodName,
           nameSpace.getString(),
           authenticationHeader,
           httpMethod,
           httpAcceptLanguages,
           httpContentLanguages,
           out.size());
       tmp << out;
   
       return tmp;
   }
   
   //------------------------------------------------------------------------------
   //
   // XmlWriter::formatSimpleIMethodRspMessage()
   //
   //------------------------------------------------------------------------------
   
   Array<Sint8> XmlWriter::formatSimpleIMethodRspMessage(
       const CIMName& iMethodName,
       const String& messageId,
       HttpMethod httpMethod,
       const ContentLanguages & httpContentLanguages,
       const Array<Sint8>& body)
   {
       Array<Sint8> out;
       Array<Sint8> tmp;
   
       _appendMessageElementBegin(out, messageId);
       _appendSimpleRspElementBegin(out);
       _appendIMethodResponseElementBegin(out, iMethodName);
       if (body.size() != 0)
       {
           _appendIReturnValueElementBegin(out);
           out << body;
           _appendIReturnValueElementEnd(out);
       }
       _appendIMethodResponseElementEnd(out);
       _appendSimpleRspElementEnd(out);
       _appendMessageElementEnd(out);
   
       appendMethodResponseHeader(tmp,
                    httpMethod,
                    httpContentLanguages,
            out.size());
       tmp << out;
   
       return tmp;
   }
   
   //------------------------------------------------------------------------------
   //
   // XmlWriter::formatSimpleIMethodErrorRspMessage()
   //
   //------------------------------------------------------------------------------
   
   Array<Sint8> XmlWriter::formatSimpleIMethodErrorRspMessage(
       const CIMName& iMethodName,
       const String& messageId,
       HttpMethod httpMethod,
       const CIMException& cimException)
   {
       Array<Sint8> out;
       Array<Sint8> tmp;
   
       _appendMessageElementBegin(out, messageId);
       _appendSimpleRspElementBegin(out);
       _appendIMethodResponseElementBegin(out, iMethodName);
       _appendErrorElement(out, cimException);
       _appendIMethodResponseElementEnd(out);
       _appendSimpleRspElementEnd(out);
       _appendMessageElementEnd(out);
   
   // l10n
       appendMethodResponseHeader(tmp,
            httpMethod,
            cimException.getContentLanguages(),
            out.size());
       tmp << out;
   
       return tmp;
   }
   
   //******************************************************************************
   //
   // Export Messages (used for indications)
   //
   //******************************************************************************
   
   //------------------------------------------------------------------------------
   //
   // appendEMethodRequestHeader()
   //
   //     Build HTTP request header for export operation.
   //
   //------------------------------------------------------------------------------
   
   void XmlWriter::appendEMethodRequestHeader(
       Array<Sint8>& out,
       const char* requestUri,
       const char* host,
       const CIMName& cimMethod,
       HttpMethod httpMethod,
       const String& authenticationHeader,
       const AcceptLanguages& acceptLanguages,
       const ContentLanguages& contentLanguages,
       Uint32 contentLength)
   {
       char nn[] = { '0' + (rand() % 10), '0' + (rand() % 10), '\0' };
   
       if (httpMethod == HTTP_METHOD_M_POST)
       {
           out << "M-POST " << requestUri << " HTTP/1.1\r\n";
       }
       else
       {
           out << "POST " << requestUri << " HTTP/1.1\r\n";
       }
       out << "HOST: " << host << "\r\n";
       out << "Content-Type: application/xml; charset=\"utf-8\"\r\n";
       out << "Content-Length: " << contentLength << "\r\n";
       if (acceptLanguages.size() > 0)
       {
           out << "Accept-Language: " << acceptLanguages << "\r\n";
       }
       if (contentLanguages.size() > 0)
       {
           out << "Content-Language: " << contentLanguages << "\r\n";
       }
       if (httpMethod == HTTP_METHOD_M_POST)
       {
           out << "Man: http://www.hp.com; ns=";
           out << nn <<"\r\n";
           out << nn << "-CIMExport: MethodRequest\r\n";
           out << nn << "-CIMExportMethod: " << cimMethod << "\r\n";
       }
       else
       {
           out << "CIMExport: MethodRequest\r\n";
           out << "CIMExportMethod: " << cimMethod << "\r\n";
       }
   
       if (authenticationHeader.size())
       {
           out << authenticationHeader << "\r\n";
       }
       out << "\r\n";
   }
   
   //------------------------------------------------------------------------------
   //
   // appendEMethodResponseHeader()
   //
   //     Build HTTP response header for export operation.
   //
   //------------------------------------------------------------------------------
   
   void XmlWriter::appendEMethodResponseHeader(
       Array<Sint8>& out,
       HttpMethod httpMethod,
       const ContentLanguages& contentLanguages,
       Uint32 contentLength)
   {
       char nn[] = { '0' + (rand() % 10), '0' + (rand() % 10), '\0' };
   
       out << "HTTP/1.1 " HTTP_STATUS_OK "\r\n";
       out << "Content-Type: application/xml; charset=\"utf-8\"\r\n";
       out << "Content-Length: " << contentLength << "\r\n";
       if (contentLanguages.size() > 0)
       {
           out << "Content-Language: " << contentLanguages << "\r\n";
       }
       if (httpMethod == HTTP_METHOD_M_POST)
       {
           out << "Ext:\r\n";
           out << "Cache-Control: no-cache\r\n";
           out << "Man: http://www.dmtf.org/cim/mapping/http/v1.0; ns=";
           out << nn <<"\r\n";
           out << nn << "-CIMExport: MethodResponse\r\n\r\n";
       }
       else
       {
           out << "CIMExport: MethodResponse\r\n\r\n";
       }
   }
   
   //------------------------------------------------------------------------------
   //
   // _appendSimpleExportReqElementBegin()
   // _appendSimpleExportReqElementEnd()
   //
   //     <!ELEMENT SIMPLEEXPREQ (EXPMETHODCALL)>
   //
   //------------------------------------------------------------------------------
   
   void XmlWriter::_appendSimpleExportReqElementBegin(
       Array<Sint8>& out)
   {
       out << "<SIMPLEEXPREQ>\n";
   }
   
   void XmlWriter::_appendSimpleExportReqElementEnd(
       Array<Sint8>& out)
   {
       out << "</SIMPLEEXPREQ>\n";
   }
   
   //------------------------------------------------------------------------------
   //
   // _appendEMethodCallElementBegin()
   // _appendEMethodCallElementEnd()
   //
   //     <!ELEMENT EXPMETHODCALL (IPARAMVALUE*)>
   //     <!ATTLIST EXPMETHODCALL %CIMName;>
   //
   //------------------------------------------------------------------------------
   
   void XmlWriter::_appendEMethodCallElementBegin(
       Array<Sint8>& out,
       const CIMName& name)
   {
       out << "<EXPMETHODCALL NAME=\"" << name << "\">\n";
   }
   
   void XmlWriter::_appendEMethodCallElementEnd(
       Array<Sint8>& out)
   {
       out << "</EXPMETHODCALL>\n";
   }
   
   //------------------------------------------------------------------------------
   //
   // _appendEParamValueElementBegin()
   // _appendEParamValueElementEnd()
   //
   //     <!ELEMENT EXPPARAMVALUE (INSTANCE)>
   //     <!ATTLIST EXPPARAMVALUE
   //         %CIMName;>
   //
   //------------------------------------------------------------------------------
   
   void XmlWriter::_appendEParamValueElementBegin(
       Array<Sint8>& out,
       const char* name)
   {
       out << "<EXPPARAMVALUE NAME=\"" << name << "\">\n";
   }
   
   void XmlWriter::_appendEParamValueElementEnd(
       Array<Sint8>& out)
   {
       out << "</EXPPARAMVALUE>\n";
   }
   
   //------------------------------------------------------------------------------
   //
   // appendInstanceEParameter()
   //
   //------------------------------------------------------------------------------
   
   void XmlWriter::appendInstanceEParameter(
       Array<Sint8>& out,
       const char* name,
       const CIMInstance& instance)
   {
       _appendEParamValueElementBegin(out, name);
       appendInstanceElement(out, instance);
       _appendEParamValueElementEnd(out);
   }
   
   //------------------------------------------------------------------------------
   //
   // _appendSimpleExportRspElementBegin()
   // _appendSimpleExportRspElementEnd()
   //
   //     <!ELEMENT SIMPLEEXPRSP (EXPMETHODRESPONSE)>
   //
   //------------------------------------------------------------------------------
   
   void XmlWriter::_appendSimpleExportRspElementBegin(
       Array<Sint8>& out)
   {
       out << "<SIMPLEEXPRSP>\n";
   }
   
   void XmlWriter::_appendSimpleExportRspElementEnd(
       Array<Sint8>& out)
   {
       out << "</SIMPLEEXPRSP>\n";
   }
   
   //------------------------------------------------------------------------------
   //
   // _appendEMethodResponseElementBegin()
   // _appendEMethodResponseElementEnd()
   //
   //     <!ELEMENT EXPMETHODRESPONSE (ERROR|IRETURNVALUE?)>
   //     <!ATTLIST EXPMETHODRESPONSE %CIMName;>
   //
   //------------------------------------------------------------------------------
   
   void XmlWriter::_appendEMethodResponseElementBegin(
       Array<Sint8>& out,
       const CIMName& name)
   {
       out << "<EXPMETHODRESPONSE NAME=\"" << name << "\">\n";
   }
   
   void XmlWriter::_appendEMethodResponseElementEnd(
       Array<Sint8>& out)
   {
       out << "</EXPMETHODRESPONSE>\n";
   }
   
   //------------------------------------------------------------------------------
   //
   // XmlWriter::formatSimpleEMethodReqMessage()
   //
   //------------------------------------------------------------------------------
   
   Array<Sint8> XmlWriter::formatSimpleEMethodReqMessage(
       const char* requestUri,
       const char* host,
       const CIMName& eMethodName,
       const String& messageId,
       HttpMethod httpMethod,
       const String& authenticationHeader,
       const AcceptLanguages& httpAcceptLanguages,
       const ContentLanguages& httpContentLanguages,
       const Array<Sint8>& body)
   {
       Array<Sint8> out;
       Array<Sint8> tmp;
   
       _appendMessageElementBegin(out, messageId);
       _appendSimpleExportReqElementBegin(out);
       _appendEMethodCallElementBegin(out, eMethodName);
       out << body;
       _appendEMethodCallElementEnd(out);
       _appendSimpleExportReqElementEnd(out);
       _appendMessageElementEnd(out);
   
       appendEMethodRequestHeader(
           tmp,
           requestUri,
           host,
           eMethodName,
           httpMethod,
           authenticationHeader,
           httpAcceptLanguages,
           httpContentLanguages,
           out.size());
       tmp << out;
   
       return tmp;
   }
   
   //------------------------------------------------------------------------------
   //
   // XmlWriter::formatSimpleEMethodRspMessage()
   //
   //------------------------------------------------------------------------------
   
   Array<Sint8> XmlWriter::formatSimpleEMethodRspMessage(
       const CIMName& eMethodName,
       const String& messageId,
       HttpMethod httpMethod,
       const ContentLanguages& httpContentLanguages,
       const Array<Sint8>& body)
   {
       Array<Sint8> out;
       Array<Sint8> tmp;
   
       _appendMessageElementBegin(out, messageId);
       _appendSimpleExportRspElementBegin(out);
       _appendEMethodResponseElementBegin(out, eMethodName);
       out << body;
       _appendEMethodResponseElementEnd(out);
       _appendSimpleExportRspElementEnd(out);
       _appendMessageElementEnd(out);
   
       appendEMethodResponseHeader(tmp,
           httpMethod,
           httpContentLanguages,
           out.size());
       tmp << out;
   
       return tmp;
   }
   
   //------------------------------------------------------------------------------
   //
   // XmlWriter::formatSimpleEMethodErrorRspMessage()
   //
   //------------------------------------------------------------------------------
   
   Array<Sint8> XmlWriter::formatSimpleEMethodErrorRspMessage(
       const CIMName& eMethodName,
       const String& messageId,
       HttpMethod httpMethod,
       const CIMException& cimException)
   {
       Array<Sint8> out;
       Array<Sint8> tmp;
   
       _appendMessageElementBegin(out, messageId);
       _appendSimpleExportRspElementBegin(out);
       _appendEMethodResponseElementBegin(out, eMethodName);
       _appendErrorElement(out, cimException);
       _appendEMethodResponseElementEnd(out);
       _appendSimpleExportRspElementEnd(out);
       _appendMessageElementEnd(out);
   
   // l10n
       appendEMethodResponseHeader(tmp,
            httpMethod,
            cimException.getContentLanguages(),
                    out.size());
       tmp << out;
   
       return tmp;
   }
   
   //------------------------------------------------------------------------------
   //
   // _printAttributes()
   //
   //------------------------------------------------------------------------------
   
   static void _printAttributes(
       PEGASUS_STD(ostream)& os,
       const XmlAttribute* attributes,
       Uint32 attributeCount)
   {
       for (Uint32 i = 0; i < attributeCount; i++)
       {
           os << attributes[i].name << "=";
   
           os << '"';
           _appendSpecial(os, attributes[i].value);
           os << '"';
   
           if (i + 1 != attributeCount)
               os << ' ';
       }
   }
   
   //------------------------------------------------------------------------------
   //
   // _indent()
   //
   //------------------------------------------------------------------------------
   
   static void _indent(PEGASUS_STD(ostream)& os, Uint32 level, Uint32 indentChars)
   {
       Uint32 n = level * indentChars;
   
       for (Uint32 i = 0; i < n; i++)
           os << ' ';
   }
   
   //------------------------------------------------------------------------------
   //
   // indentedPrint()
   //
   //------------------------------------------------------------------------------
   
   void XmlWriter::indentedPrint(
       PEGASUS_STD(ostream)& os,
       const char* text,
       Uint32 indentChars)
   {
       char* tmp = strcpy(new char[strlen(text) + 1], text);
   
       XmlParser parser(tmp);
       XmlEntry entry;
       Stack<const char*> stack;
   
       while (parser.next(entry))
       {
           switch (entry.type)
           {
               case XmlEntry::XML_DECLARATION:
               {
                   _indent(os, stack.size(), indentChars);
   
                   os << "<?" << entry.text << " ";
                   _printAttributes(os, entry.attributes, entry.attributeCount);
                   os << "?>";
                   break;
               }
   
               case XmlEntry::START_TAG:
               {
                   _indent(os, stack.size(), indentChars);
   
                   os << "<" << entry.text;
   
                   if (entry.attributeCount)
                       os << ' ';
   
                   _printAttributes(os, entry.attributes, entry.attributeCount);
                   os << ">";
                   stack.push(entry.text);
                   break;
               }
   
               case XmlEntry::EMPTY_TAG:
               {
                   _indent(os, stack.size(), indentChars);
   
                   os << "<" << entry.text << " ";
                   _printAttributes(os, entry.attributes, entry.attributeCount);
                   os << "/>";
                   break;
               }
   
               case XmlEntry::END_TAG:
               {
                   if (!stack.isEmpty() && strcmp(stack.top(), entry.text) == 0)
                       stack.pop();
   
                   _indent(os, stack.size(), indentChars);
   
                   os << "</" << entry.text << ">";
                   break;
               }
   
               case XmlEntry::COMMENT:
               {
   
                   _indent(os, stack.size(), indentChars);
                   os << "<!--";
                   _appendSpecial(os, entry.text);
                   os << "-->";
                   break;
               }
   
               case XmlEntry::CONTENT:
               {
                   _indent(os, stack.size(), indentChars);
                   _appendSpecial(os, entry.text);
                   break;
               }
   
               case XmlEntry::CDATA:
               {
                   _indent(os, stack.size(), indentChars);
                   os << "<![CDATA[...]]>";
                   break;
               }
   
               case XmlEntry::DOCTYPE:
               {
                   _indent(os, stack.size(), indentChars);
                   os << "<!DOCTYPE...>";
                   break;
               }
           }
   
           os << PEGASUS_STD(endl);
       }
   
       delete [] tmp;
   }
   
   //------------------------------------------------------------------------------
   //
   // XmlWriter::getNextMessageId()
   //
   //------------------------------------------------------------------------------
   
   String XmlWriter::getNextMessageId()
   {
       // ATTN: make thread-safe:
       static Uint32 messageId = 1000;
   
       messageId++;
   
       if (messageId < 1000)
           messageId = 1001;
   
       char buffer[16];
       sprintf(buffer, "%d", messageId);
       return buffer;
   }
   
   //------------------------------------------------------------------------------
   //
   // XmlWriter::keyBindingTypeToString
   //
   //------------------------------------------------------------------------------
   const char* XmlWriter::keyBindingTypeToString (CIMKeyBinding::Type type)
   {
       switch (type)
       {
           case CIMKeyBinding::BOOLEAN:
               return "boolean";
   
           case CIMKeyBinding::STRING:
               return "string";
   
           case CIMKeyBinding::NUMERIC:
               return "numeric";
   
           case CIMKeyBinding::REFERENCE:
           default:
               PEGASUS_ASSERT(false);
       }
   
       return "unknown";
 } }
  
 PEGASUS_NAMESPACE_END PEGASUS_NAMESPACE_END


Legend:
Removed from v.1.24  
changed lines
  Added in v.1.95

No CVS admin address has been configured
Powered by
ViewCVS 0.9.2