version 1.6, 2001/04/08 01:13:22
|
version 1.39, 2002/03/20 19:13:40
|
|
|
//BEGIN_LICENSE |
//%///////////////////////////////////////////////////////////////////////////// |
// | // |
// Copyright (c) 2000 The Open Group, BMC Software, Tivoli Systems, IBM |
// Copyright (c) 2000, 2001 BMC Software, Hewlett-Packard Company, IBM, |
|
// The Open Group, Tivoli Systems |
// | // |
// Permission is hereby granted, free of charge, to any person obtaining a |
// Permission is hereby granted, free of charge, to any person obtaining a copy |
// copy of this software and associated documentation files (the "Software"), |
// of this software and associated documentation files (the "Software"), to |
// to deal in the Software without restriction, including without limitation |
// deal in the Software without restriction, including without limitation the |
// the rights to use, copy, modify, merge, publish, distribute, sublicense, |
// rights to use, copy, modify, merge, publish, distribute, sublicense, and/or |
// and/or sell copies of the Software, and to permit persons to whom the |
// sell copies of the Software, and to permit persons to whom the Software is |
// Software is furnished to do so, subject to the following conditions: |
// furnished to do so, subject to the following conditions: |
|
// |
|
// THE ABOVE COPYRIGHT NOTICE AND THIS PERMISSION NOTICE SHALL BE INCLUDED IN |
|
// ALL COPIES OR SUBSTANTIAL PORTIONS OF THE SOFTWARE. THE SOFTWARE IS PROVIDED |
|
// "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT |
|
// LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR |
|
// PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT |
|
// HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN |
|
// ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION |
|
// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. |
|
// |
|
//============================================================================== |
|
// |
|
// Author: Mike Brasher (mbrasher@bmc.com) |
|
// |
|
// Modified By: Carol Ann Krug Graves, Hewlett-Packard Company |
|
// (carolann_graves@hp.com) |
|
// Nitin Upasani, Hewlett-Packard Company (Nitin_Upasani@hp.com) |
|
// Roger Kumpf, Hewlett-Packard Company (roger_kumpf@hp.com) |
// | // |
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR |
//%///////////////////////////////////////////////////////////////////////////// |
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, |
|
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL |
|
// THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER |
|
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING |
|
// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER |
|
// DEALINGS IN THE SOFTWARE. |
|
// |
|
//END_LICENSE |
|
//BEGIN_HISTORY |
|
// |
|
// Author: |
|
// |
|
// $Log$ |
|
// Revision 1.6 2001/04/08 01:13:22 mike |
|
// Changed "ConstCIM" to "CIMConst" |
|
// |
|
// Revision 1.4 2001/02/26 04:33:28 mike |
|
// Fixed many places where cim names were be compared with operator==(String,String). |
|
// Changed all of these to use CIMName::equal() |
|
// |
|
// Revision 1.3 2001/02/19 01:47:16 mike |
|
// Renamed names of the form CIMConst to CIMConst. |
|
// |
|
// Revision 1.2 2001/02/16 02:06:07 mike |
|
// Renamed many classes and headers. |
|
// |
|
// Revision 1.1.1.1 2001/01/14 19:53:32 mike |
|
// Pegasus import |
|
// |
|
// |
|
//END_HISTORY |
|
| |
#include <cassert> | #include <cassert> |
#include <cctype> | #include <cctype> |
|
|
#include "CIMQualifierDecl.h" | #include "CIMQualifierDecl.h" |
#include "CIMClass.h" | #include "CIMClass.h" |
#include "CIMInstance.h" | #include "CIMInstance.h" |
|
#include "CIMObject.h" |
|
#include "CIMNamedInstance.h" |
|
#include "CIMParamValue.h" |
| |
|
PEGASUS_USING_STD; |
PEGASUS_NAMESPACE_BEGIN | PEGASUS_NAMESPACE_BEGIN |
| |
static const Uint32 MESSAGE_SIZE = 128; | static const Uint32 MESSAGE_SIZE = 128; |
|
|
| |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
// | // |
|
// testXmlDeclaration () |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
Boolean XmlReader::testXmlDeclaration ( |
|
XmlParser& parser, |
|
XmlEntry& entry) |
|
{ |
|
if (!parser.next (entry) || |
|
entry.type != XmlEntry::XML_DECLARATION || |
|
strcmp (entry.text, "xml") != 0) |
|
{ |
|
parser.putBack (entry); |
|
return false; |
|
} |
|
|
|
return true; |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
// expectStartTag() | // expectStartTag() |
// | // |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
|
|
strcmp(entry.text, tagName) != 0) | strcmp(entry.text, tagName) != 0) |
{ | { |
char message[MESSAGE_SIZE]; | char message[MESSAGE_SIZE]; |
sprintf(message, "Expected close of %s element", tagName); |
sprintf(message, "Expected close of %s element, got %s instead", |
|
tagName,entry.text); |
throw XmlValidationError(parser.getLine(), message); | throw XmlValidationError(parser.getLine(), message); |
} | } |
} | } |
|
|
| |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
// | // |
// testCimStartTag() |
// getCimStartTag() |
// | // |
// <!ELEMENT CIM (MESSAGE|DECLARATION)> | // <!ELEMENT CIM (MESSAGE|DECLARATION)> |
// <!ATTRLIST CIM | // <!ATTRLIST CIM |
|
|
// | // |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
void XmlReader::testCimStartTag(XmlParser& parser) |
void XmlReader::getCimStartTag( |
|
XmlParser& parser, |
|
const char*& cimVersion, |
|
const char*& dtdVersion) |
{ | { |
XmlEntry entry; | XmlEntry entry; |
XmlReader::expectStartTag(parser, entry, "CIM"); | XmlReader::expectStartTag(parser, entry, "CIM"); |
| |
const char* cimVersion; |
|
|
|
if (!entry.getAttributeValue("CIMVERSION", cimVersion)) | if (!entry.getAttributeValue("CIMVERSION", cimVersion)) |
throw XmlValidationError( | throw XmlValidationError( |
parser.getLine(), "missing CIM.CIMVERSION attribute"); | parser.getLine(), "missing CIM.CIMVERSION attribute"); |
| |
if (strcmp(cimVersion, "2.0") != 0) |
|
throw XmlValidationError(parser.getLine(), |
|
"CIM.CIMVERSION attribute must be \"2.0\""); |
|
|
|
const char* dtdVersion; |
|
|
|
if (!entry.getAttributeValue("DTDVERSION", dtdVersion)) | if (!entry.getAttributeValue("DTDVERSION", dtdVersion)) |
throw XmlValidationError( | throw XmlValidationError( |
parser.getLine(), "missing CIM.DTDVERSION attribute"); | parser.getLine(), "missing CIM.DTDVERSION attribute"); |
|
|
if (strcmp(dtdVersion, "2.0") != 0) |
|
throw XmlValidationError(parser.getLine(), |
|
"CIM.DTDVERSION attribute must be \"2.0\""); |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// getIsArrayAttribute() |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
Boolean XmlReader::getIsArrayAttribute( |
|
Uint32 lineNumber, |
|
const XmlEntry& entry, |
|
const char* tagName, |
|
Boolean& value) |
|
{ |
|
const char* tmp; |
|
|
|
if (!entry.getAttributeValue("ISARRAY", tmp)) |
|
return false; |
|
|
|
if (strcmp(tmp, "true") == 0) |
|
{ |
|
value = true; |
|
return true; |
|
} |
|
else if (strcmp(tmp, "false") == 0) |
|
{ |
|
value = false; |
|
return true; |
|
} |
|
|
|
char buffer[62]; |
|
sprintf(buffer, "Bad %s.%s attribute value", "ISARRAY", tagName); |
|
throw XmlSemanticError(lineNumber, buffer); |
|
return false; |
|
} | } |
| |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
|
|
throw XmlValidationError(lineNumber, buffer); | throw XmlValidationError(lineNumber, buffer); |
} | } |
| |
if (acceptNull && name.getLength() == 0) |
if (acceptNull && name.size() == 0) |
return name; | return name; |
| |
if (!CIMName::legal(name)) | if (!CIMName::legal(name)) |
|
|
// | // |
// getCimTypeAttribute() | // getCimTypeAttribute() |
// | // |
|
// This method can be used to get a TYPE attribute or a PARAMTYPE attribute. |
|
// The only significant difference is that PARAMTYPE may specify a value of |
|
// "reference" type. This method recognizes these attributes by name, and |
|
// does not allow a "TYPE" attribute to be of "reference" type. |
|
// |
// <!ENTITY % CIMType "TYPE (boolean|string|char16|uint8|sint8|uint16 | // <!ENTITY % CIMType "TYPE (boolean|string|char16|uint8|sint8|uint16 |
// |sint16|uint32|sint32|uint64|sint64|datetime|real32|real64)"> | // |sint16|uint32|sint32|uint64|sint64|datetime|real32|real64)"> |
// | // |
|
// <!ENTITY % ParamType "PARAMTYPE (boolean|string|char16|uint8|sint8 |
|
// |uint16|sint16|uint32|sint32|uint64|sint64|datetime|real32|real64 |
|
// |reference)"> |
|
// |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
CIMType XmlReader::getCimTypeAttribute( | CIMType XmlReader::getCimTypeAttribute( |
Uint32 lineNumber, | Uint32 lineNumber, |
const XmlEntry& entry, | const XmlEntry& entry, |
const char* tagName) |
const char* tagName, |
|
const char* attributeName, |
|
Boolean required) |
{ | { |
const char* typeName; | const char* typeName; |
| |
if (!entry.getAttributeValue("TYPE", typeName)) |
if (!entry.getAttributeValue(attributeName, typeName)) |
|
{ |
|
if (required) |
{ | { |
char message[MESSAGE_SIZE]; | char message[MESSAGE_SIZE]; |
sprintf(message, "missing %s.TYPE attribute", tagName); |
sprintf(message, "missing %s.%s attribute", tagName, attributeName); |
throw XmlValidationError(lineNumber, message); | throw XmlValidationError(lineNumber, message); |
} | } |
|
else |
|
{ |
|
return CIMType::NONE; |
|
} |
|
} |
| |
CIMType type = CIMType::NONE; | CIMType type = CIMType::NONE; |
| |
|
|
else if (strcmp(typeName, "reference") == 0) | else if (strcmp(typeName, "reference") == 0) |
type = CIMType::REFERENCE; | type = CIMType::REFERENCE; |
| |
// ATTN: "reference" is not legal according to the DTD; however, it is |
if ((type == CIMType::NONE) || |
// used by the XML version of the CIM schema. |
((type == CIMType::REFERENCE) && |
|
(strcmp(attributeName, "PARAMTYPE") != 0))) |
if (type == CIMType::NONE) |
|
{ | { |
char message[MESSAGE_SIZE]; | char message[MESSAGE_SIZE]; |
sprintf(message, "Illegal value for %s.TYPE attribute", tagName); |
sprintf(message, "Illegal value for %s.%s attribute", tagName, |
|
attributeName); |
throw XmlSemanticError(lineNumber, message); | throw XmlSemanticError(lineNumber, message); |
} | } |
| |
|
|
| |
const char* last = p; | const char* last = p; |
| |
|
// Build the Sint64 as a negative number, regardless of the eventual sign |
|
x = -(*first++ - '0'); |
|
|
while (first != last) | while (first != last) |
x = 10 * x + (*first++ - '0'); |
{ |
|
if (x < PEGASUS_LLONG_MIN/10) |
|
{ |
|
return false; |
|
} |
|
x = 10 * x; |
|
Sint64 newDigit = (*first++ - '0'); |
|
if (PEGASUS_LLONG_MIN - x > -newDigit) |
|
{ |
|
return false; |
|
} |
|
x = x - newDigit; |
|
} |
| |
if (negative) |
if (!negative) |
|
{ |
|
if (x == PEGASUS_LLONG_MIN) |
|
{ |
|
return false; |
|
} |
x = -x; | x = -x; |
|
} |
return true; | return true; |
} | } |
| |
|
|
// | // |
// stringToUnsignedInteger | // stringToUnsignedInteger |
// | // |
// [ "+" | "-" ] ( positiveDecimalDigit *decimalDigit | "0" ) |
// [ "+" ] ( positiveDecimalDigit *decimalDigit | "0" ) |
// | // |
// ATTN-B: handle conversion from hexadecimal. | // ATTN-B: handle conversion from hexadecimal. |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
|
|
const char* last = p; | const char* last = p; |
| |
while (first != last) | while (first != last) |
x = 10 * x + (*first++ - '0'); |
{ |
|
if (x > PEGASUS_ULLONG_MAX/10) |
|
{ |
|
return false; |
|
} |
|
x = 10 * x; |
|
Uint64 newDigit = (*first++ - '0'); |
|
if (PEGASUS_ULLONG_MAX - x < newDigit) |
|
{ |
|
return false; |
|
} |
|
x = x + newDigit; |
|
} |
| |
return true; | return true; |
} | } |
|
|
// | // |
// stringToValue() | // stringToValue() |
// | // |
// ATTN-C: note that integers are truncated without warning. What should be |
// Return: CIMValue. If the string input is zero length creates a CIMValue |
// done in this case? In C they are truncated without warning by design. |
// with value defined by the type. Else the value is inserted. |
|
// |
|
// Note that this does not set the CIMValue Null if the string is empty. |
// | // |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
|
|
{ | { |
// ATTN-B: accepting only UTF-8 for now! (affects string and char16): | // ATTN-B: accepting only UTF-8 for now! (affects string and char16): |
| |
|
// If strlen == 0, set to default value for type |
|
|
|
if (strlen(valueString)==0) |
|
{ |
|
switch (type) |
|
{ |
|
case CIMType::BOOLEAN: return CIMValue(false); |
|
case CIMType::STRING: return CIMValue(valueString); |
|
case CIMType::CHAR16: return CIMValue(Char16('\0')); |
|
case CIMType::UINT8: return CIMValue(Uint8(0)); |
|
case CIMType::UINT16: return CIMValue(Uint16(0)); |
|
case CIMType::UINT32: return CIMValue(Uint32(0)); |
|
case CIMType::UINT64: return CIMValue(Uint64(0)); |
|
case CIMType::SINT8: return CIMValue(Sint8(0)); |
|
case CIMType::SINT16: return CIMValue(Sint16(0)); |
|
case CIMType::SINT32: return CIMValue(Sint32(0)); |
|
case CIMType::SINT64: return CIMValue(Sint64(0)); |
|
case CIMType::REAL32: return CIMValue(Real32(0)); |
|
case CIMType::REAL64: return CIMValue(Real64(0)); |
|
} |
|
} |
|
|
|
// Create value per type |
switch (type) | switch (type) |
{ | { |
case CIMType::BOOLEAN: | case CIMType::BOOLEAN: |
{ | { |
if (strcmp(valueString, "TRUE") == 0) |
if (CompareNoCase(valueString, "TRUE") == 0) |
return CIMValue(true); | return CIMValue(true); |
else if (strcmp(valueString, "FALSE") == 0) |
else if (CompareNoCase(valueString, "FALSE") == 0) |
return CIMValue(false); | return CIMValue(false); |
else | else |
throw XmlSemanticError( | throw XmlSemanticError( |
|
|
| |
switch (type) | switch (type) |
{ | { |
case CIMType::UINT8: return CIMValue(Uint8(x)); |
case CIMType::UINT8: |
case CIMType::UINT16: return CIMValue(Uint16(x)); |
{ |
case CIMType::UINT32: return CIMValue(Uint32(x)); |
if (x >= (Uint64(1)<<8)) |
|
{ |
|
throw XmlSemanticError( |
|
lineNumber, "Uint8 value out of range"); |
|
} |
|
return CIMValue(Uint8(x)); |
|
} |
|
case CIMType::UINT16: |
|
{ |
|
if (x >= (Uint64(1)<<16)) |
|
{ |
|
throw XmlSemanticError( |
|
lineNumber, "Uint16 value out of range"); |
|
} |
|
return CIMValue(Uint16(x)); |
|
} |
|
case CIMType::UINT32: |
|
{ |
|
if (x >= (Uint64(1)<<32)) |
|
{ |
|
throw XmlSemanticError( |
|
lineNumber, "Uint32 value out of range"); |
|
} |
|
return CIMValue(Uint32(x)); |
|
} |
case CIMType::UINT64: return CIMValue(Uint64(x)); | case CIMType::UINT64: return CIMValue(Uint64(x)); |
default: break; | default: break; |
} | } |
|
|
| |
switch (type) | switch (type) |
{ | { |
case CIMType::SINT8: return CIMValue(Sint8(x)); |
case CIMType::SINT8: |
case CIMType::SINT16: return CIMValue(Sint16(x)); |
{ |
case CIMType::SINT32: return CIMValue(Sint32(x)); |
if( (x >= (Sint64(1)<<7)) || (x < (-(Sint64(1)<<7))) ) |
|
{ |
|
throw XmlSemanticError( |
|
lineNumber, "Sint8 value out of range"); |
|
} |
|
return CIMValue(Sint8(x)); |
|
} |
|
case CIMType::SINT16: |
|
{ |
|
if( (x >= (Sint64(1)<<15)) || (x < (-(Sint64(1)<<15))) ) |
|
{ |
|
throw XmlSemanticError( |
|
lineNumber, "Sint16 value out of range"); |
|
} |
|
return CIMValue(Sint16(x)); |
|
} |
|
case CIMType::SINT32: |
|
{ |
|
if( (x >= (Sint64(1)<<31)) || (x < (-(Sint64(1)<<31))) ) |
|
{ |
|
throw XmlSemanticError( |
|
lineNumber, "Sint32 value out of range"); |
|
} |
|
return CIMValue(Sint32(x)); |
|
} |
case CIMType::SINT64: return CIMValue(Sint64(x)); | case CIMType::SINT64: return CIMValue(Sint64(x)); |
default: break; | default: break; |
} | } |
|
|
if (!stringToReal(valueString, x)) | if (!stringToReal(valueString, x)) |
throw XmlSemanticError(lineNumber, "Bad real value"); | throw XmlSemanticError(lineNumber, "Bad real value"); |
| |
|
// ATTN-RK-P3-20010319: This value gets truncated. |
return CIMValue(Real32(x)); | return CIMValue(Real32(x)); |
} | } |
| |
|
|
// | // |
// <!ELEMENT VALUE (#PCDATA)> | // <!ELEMENT VALUE (#PCDATA)> |
// | // |
|
// Return: false if no value element. |
|
// |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
Boolean XmlReader::getValueElement( | Boolean XmlReader::getValueElement( |
|
|
CIMType type, | CIMType type, |
CIMValue& value) | CIMValue& value) |
{ | { |
// Get VALUE start tag: |
// Get VALUE start tag: Return false if no VALUE start Tag |
| |
XmlEntry entry; | XmlEntry entry; |
|
|
if (!testStartTagOrEmptyTag(parser, entry, "VALUE")) | if (!testStartTagOrEmptyTag(parser, entry, "VALUE")) |
return false; | return false; |
| |
Boolean empty = entry.type == XmlEntry::EMPTY_TAG; | Boolean empty = entry.type == XmlEntry::EMPTY_TAG; |
| |
// Get VALUE content: |
|
|
|
const char* valueString = ""; | const char* valueString = ""; |
| |
if (!empty) | if (!empty) |
|
|
} | } |
| |
value = stringToValue(parser.getLine(), valueString,type); | value = stringToValue(parser.getLine(), valueString,type); |
|
|
|
return true; |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// getStringValueElement() |
|
// |
|
// <!ELEMENT VALUE (#PCDATA)> |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
Boolean XmlReader::getStringValueElement( |
|
XmlParser& parser, |
|
String& str, |
|
Boolean required) |
|
{ |
|
XmlEntry entry; |
|
|
|
if (!testStartTagOrEmptyTag(parser, entry, "VALUE")) |
|
{ |
|
if (required) |
|
throw XmlValidationError(parser.getLine(),"Expected VALUE element"); |
|
return false; |
|
} |
|
|
|
Boolean empty = entry.type == XmlEntry::EMPTY_TAG; |
|
|
|
const char* valueString = ""; |
|
|
|
if (!empty) |
|
{ |
|
if (testContentOrCData(parser, entry)) |
|
valueString = entry.text; |
|
|
|
expectEndTag(parser, "VALUE"); |
|
} |
|
|
|
str = valueString; |
|
return true; |
|
} |
|
|
|
//---------------------------------------------------------------------------- |
|
// |
|
// getPropertyValue |
|
// Use: Decode property value from SetProperty request and |
|
// GetProperty response. |
|
// |
|
// PropertyValue is one of: |
|
// |
|
// |
|
// <!ELEMENT VALUE.ARRAY (VALUE*)> |
|
// |
|
// <!ELEMENT VALUE.REFERENCE (CLASSPATH|LOCALCLASSPATH|CLASSNAME| |
|
// <!ELEMENT VALUE.ARRAY (VALUE*)> |
|
// |
|
// <!ELEMENT VALUE.REFERENCE (CLASSPATH|LOCALCLASSPATH|CLASSNAME| |
|
// INSTANCEPATH|LOCALINSTANCEPATH|INSTANCENAME)> |
|
// |
|
// <!ELEMENT VALUE.REFARRAY (VALUE.REFERENCE*)> |
|
// |
|
//---------------------------------------------------------------------------- |
|
Boolean XmlReader::getPropertyValue( |
|
XmlParser& parser, |
|
CIMValue& cimValue) |
|
{ |
|
// Can not test for value type, so assume String |
|
const CIMType type = CIMType::STRING; |
|
|
|
// Test for VALUE element |
|
if (XmlReader::getValueElement(parser, type, cimValue)) |
|
{ |
|
return true; |
|
} |
|
|
|
// Test for VALUE.ARRAY element |
|
if (XmlReader::getValueArrayElement(parser, type, cimValue)) |
|
{ |
|
return true; |
|
} |
|
|
|
// Test for VALUE.REFERENCE element |
|
CIMReference reference; |
|
if (XmlReader::getValueReferenceElement(parser, reference)) |
|
{ |
|
cimValue.set(reference); |
|
return true; |
|
} |
|
|
|
// Test for VALUE.REFARRAY element |
|
if (XmlReader::getValueReferenceArrayElement(parser, cimValue)) |
|
{ |
return true; | return true; |
} | } |
| |
|
return false; |
|
} |
|
|
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
// | // |
// stringArrayToValue() | // stringArrayToValue() |
|
|
{ | { |
Array<T> array; | Array<T> array; |
| |
for (Uint32 i = 0, n = stringArray.getSize(); i < n; i++) |
for (Uint32 i = 0, n = stringArray.size(); i < n; i++) |
{ | { |
CIMValue value = XmlReader::stringToValue( | CIMValue value = XmlReader::stringToValue( |
lineNumber, stringArray[i], type); | lineNumber, stringArray[i], type); |
|
|
// | // |
// <!ELEMENT VALUE.ARRAY (VALUE*)> | // <!ELEMENT VALUE.ARRAY (VALUE*)> |
// | // |
|
// Return: Boolean. Returns false if there is no VALUE.ARRAY start element |
|
// |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
Boolean XmlReader::getValueArrayElement( | Boolean XmlReader::getValueArrayElement( |
|
|
CIMType type, | CIMType type, |
CIMValue& value) | CIMValue& value) |
{ | { |
|
// Clears any values from the Array. Assumes this is array CIMValue |
value.clear(); | value.clear(); |
| |
// Get VALUE.ARRAY open tag: | // Get VALUE.ARRAY open tag: |
| |
XmlEntry entry; | XmlEntry entry; |
|
Array<const char*> stringArray; |
| |
|
// If no VALUE.ARRAY start tag, return false |
if (!testStartTagOrEmptyTag(parser, entry, "VALUE.ARRAY")) | if (!testStartTagOrEmptyTag(parser, entry, "VALUE.ARRAY")) |
return false; | return false; |
| |
|
//ATTN: P1 KS KSTESTNULL - Need to relook at this one. |
if (entry.type == XmlEntry::EMPTY_TAG) | if (entry.type == XmlEntry::EMPTY_TAG) |
return true; | return true; |
| |
|
if (entry.type != XmlEntry::EMPTY_TAG) |
|
{ |
// For each VALUE element: | // For each VALUE element: |
| |
Array<const char*> stringArray; |
|
|
|
while (testStartTagOrEmptyTag(parser, entry, "VALUE")) | while (testStartTagOrEmptyTag(parser, entry, "VALUE")) |
{ | { |
if (entry.type == XmlEntry::EMPTY_TAG) | if (entry.type == XmlEntry::EMPTY_TAG) |
|
|
} | } |
| |
expectEndTag(parser, "VALUE.ARRAY"); | expectEndTag(parser, "VALUE.ARRAY"); |
|
} |
| |
value = stringArrayToValue(parser.getLine(), stringArray, type); | value = stringArrayToValue(parser.getLine(), stringArray, type); |
return true; | return true; |
|
|
Boolean translatable = getCimBooleanAttribute( | Boolean translatable = getCimBooleanAttribute( |
lineNumber, entry, tagName, "TRANSLATABLE", false, false); | lineNumber, entry, tagName, "TRANSLATABLE", false, false); |
| |
Uint32 flavor = 0; |
// ATTN: KS P1 5 Mar 2002 Should this not be CIMFlavor::DEFAULTS?? |
|
//Uint32 flavor = CIMFlavor::DEFAULTS; |
|
// ATTN-RK-P1-20020307: No, Karl. If you initialize to the defaults, |
|
// you have to unset the default flavors that don't apply. The code |
|
// below only adds qualifiers. |
|
Uint32 flavor = CIMFlavor::NONE; |
| |
if (overridable) | if (overridable) |
flavor |= CIMFlavor::OVERRIDABLE; | flavor |= CIMFlavor::OVERRIDABLE; |
|
|
| |
// Get VALUE or VALUE.ARRAY element: | // Get VALUE or VALUE.ARRAY element: |
| |
|
// ATTN: KS P1 4 March 2002 - Requires either value or array element or |
|
// generates exception. Correct for spec but means no NULL values on qualifier |
|
// values. Alternative is to set NULL value and continue |
|
|
CIMValue value; | CIMValue value; |
| |
if (!getValueElement(parser, type, value) && | if (!getValueElement(parser, type, value) && |
|
|
| |
CIMType type = getCimTypeAttribute(parser.getLine(), entry, "PROPERTY"); | CIMType type = getCimTypeAttribute(parser.getLine(), entry, "PROPERTY"); |
| |
// Create property: |
// Create property: Sets type and !isarray |
|
// ATTN: KS P1 change to use the correct constructor |
| |
CIMValue value; | CIMValue value; |
value.setNullValue(type, false); | value.setNullValue(type, false); |
|
|
| |
getQualifierElements(parser, property); | getQualifierElements(parser, property); |
| |
// Get value: |
// Get value: Insert value if getValueElement exists (returns True) |
| |
if (getValueElement(parser, type, value)) | if (getValueElement(parser, type, value)) |
property.setValue(value); | property.setValue(value); |
|
|
| |
// Create property: | // Create property: |
| |
|
// ATTN: KS P1 4 March 2002 Change to use correct constructor. |
|
// ATTN: KS P3 4 March 2002. Why create extra value. Use same one. |
|
|
CIMValue nullValue; | CIMValue nullValue; |
nullValue.setNullValue(type, true, arraySize); | nullValue.setNullValue(type, true, arraySize); |
property = CIMProperty( | property = CIMProperty( |
|
|
| |
// Get value: | // Get value: |
| |
|
// ATTN: KS P1 4 March 2002. Does not set array type into value. |
|
// ATTN: Thus, if it returns false, the CIMValue is nothing. |
CIMValue value; | CIMValue value; |
| |
if (getValueArrayElement(parser, type, value)) | if (getValueArrayElement(parser, type, value)) |
|
|
| |
while (getNameSpaceElement(parser, nameSpaceComponent)) | while (getNameSpaceElement(parser, nameSpaceComponent)) |
{ | { |
if (nameSpace.getLength()) |
if (nameSpace.size()) |
nameSpace += '/'; | nameSpace += '/'; |
| |
nameSpace += nameSpaceComponent; | nameSpace += nameSpaceComponent; |
} | } |
| |
if (!nameSpace.getLength()) |
if (!nameSpace.size()) |
{ | { |
throw XmlValidationError(parser.getLine(), | throw XmlValidationError(parser.getLine(), |
"Expected one or more NAMESPACE elements within " | "Expected one or more NAMESPACE elements within " |
|
|
// | // |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
KeyBinding::CIMType XmlReader::getValueTypeAttribute( |
KeyBinding::Type XmlReader::getValueTypeAttribute( |
Uint32 lineNumber, | Uint32 lineNumber, |
const XmlEntry& entry, | const XmlEntry& entry, |
const char* elementName) | const char* elementName) |
|
|
// <!ATTLIST KEYVALUE | // <!ATTLIST KEYVALUE |
// VALUETYPE (string|boolean|numeric) 'string'> | // VALUETYPE (string|boolean|numeric) 'string'> |
// | // |
// ATTN-B: VALUE.REFERENCE ignored above; can't understand why it is needed! |
|
// |
|
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
Boolean XmlReader::getKeyValueElement( | Boolean XmlReader::getKeyValueElement( |
XmlParser& parser, | XmlParser& parser, |
KeyBinding::CIMType& type, |
KeyBinding::Type& type, |
String& value) | String& value) |
{ | { |
XmlEntry entry; | XmlEntry entry; |
|
|
// <!ATTLIST KEYBINDING | // <!ATTLIST KEYBINDING |
// %CIMName;> | // %CIMName;> |
// | // |
// ATTN-B: VALUE.REFERENCE ignored above; can't understand why it is needed! |
|
// |
|
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
Boolean XmlReader::getKeyBindingElement( | Boolean XmlReader::getKeyBindingElement( |
XmlParser& parser, | XmlParser& parser, |
String& name, | String& name, |
String& value, | String& value, |
KeyBinding::CIMType& type) |
KeyBinding::Type& type) |
{ | { |
XmlEntry entry; | XmlEntry entry; |
| |
|
|
name = getCimNameAttribute(parser.getLine(), entry, "KEYBINDING"); | name = getCimNameAttribute(parser.getLine(), entry, "KEYBINDING"); |
| |
if (!getKeyValueElement(parser, type, value)) | if (!getKeyValueElement(parser, type, value)) |
throw XmlValidationError(parser.getLine(), "Expected KEYVALUE element"); |
{ |
|
CIMReference reference; |
|
|
|
if (!getValueReferenceElement(parser, reference)) |
|
{ |
|
throw XmlValidationError(parser.getLine(), |
|
"Expected KEYVALUE or VALUE.REFERENCE element"); |
|
} |
|
|
|
type = KeyBinding::REFERENCE; |
|
value = reference.toString(); |
|
} |
| |
expectEndTag(parser, "KEYBINDING"); | expectEndTag(parser, "KEYBINDING"); |
return true; | return true; |
|
|
// <!ATTLIST INSTANCENAME | // <!ATTLIST INSTANCENAME |
// %ClassName;> | // %ClassName;> |
// | // |
// ATTN-B: VALUE.REFERENCE sub-element not accepted yet. |
// Note: An empty key name is used in the keyBinding when the INSTANCENAME is |
// ATTN-B: KEYVALUE sub-element nothandled yet. |
// specified using a KEYVALUE or a VALUE.REFERENCE. |
// | // |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
|
|
| |
className = getClassNameAttribute(parser.getLine(), entry, "INSTANCENAME"); | className = getClassNameAttribute(parser.getLine(), entry, "INSTANCENAME"); |
| |
if (!empty) |
if (empty) |
{ | { |
|
return true; |
|
} |
|
|
String name; | String name; |
KeyBinding::CIMType type; |
KeyBinding::Type type; |
String value; | String value; |
|
CIMReference reference; |
| |
|
if (getKeyValueElement(parser, type, value)) |
|
{ |
|
// Use empty key name because none was specified |
|
keyBindings.append(KeyBinding(name, value, type)); |
|
} |
|
else if (getValueReferenceElement(parser, reference)) |
|
{ |
|
// Use empty key name because none was specified |
|
type = KeyBinding::REFERENCE; |
|
value = reference.toString(); |
|
keyBindings.append(KeyBinding(name, value, type)); |
|
} |
|
else |
|
{ |
while (getKeyBindingElement(parser, name, value, type)) | while (getKeyBindingElement(parser, name, value, type)) |
keyBindings.append(KeyBinding(name, value, type)); | keyBindings.append(KeyBinding(name, value, type)); |
|
} |
| |
if (!empty) |
|
expectEndTag(parser, "INSTANCENAME"); | expectEndTag(parser, "INSTANCENAME"); |
} |
|
| |
return true; | return true; |
} | } |
| |
//------------------------------------------------------------------------------ |
Boolean XmlReader::getInstanceNameElement( |
// |
XmlParser& parser, |
// getInstancePathElement() |
CIMReference& instanceName) |
|
{ |
|
String className; |
|
Array<KeyBinding> keyBindings; |
|
|
|
if (!XmlReader::getInstanceNameElement(parser, className, keyBindings)) |
|
return false; |
|
|
|
instanceName.set(String(), String(), className, keyBindings); |
|
return true; |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// getInstancePathElement() |
// | // |
// <!ELEMENT INSTANCEPATH (NAMESPACEPATH,INSTANCENAME)> | // <!ELEMENT INSTANCEPATH (NAMESPACEPATH,INSTANCENAME)> |
// | // |
|
|
| |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
// | // |
|
// getValueReferenceArrayElement() |
|
// |
|
// <!ELEMENT VALUE.REFARRAY (VALUE.REFERENCE*)> |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
Boolean XmlReader::getValueReferenceArrayElement( |
|
XmlParser& parser, |
|
CIMValue& value) |
|
{ |
|
XmlEntry entry; |
|
Array<CIMReference> referenceArray; |
|
CIMReference reference; |
|
|
|
value.clear(); |
|
|
|
// Get VALUE.REFARRAY open tag: |
|
|
|
if (!testStartTagOrEmptyTag(parser, entry, "VALUE.REFARRAY")) |
|
return false; |
|
|
|
if (entry.type != XmlEntry::EMPTY_TAG) |
|
{ |
|
// For each VALUE.REFERENCE element: |
|
|
|
while (getValueReferenceElement(parser, reference)) |
|
{ |
|
referenceArray.append(reference); |
|
} |
|
|
|
expectEndTag(parser, "VALUE.REFARRAY"); |
|
} |
|
|
|
value.set(referenceArray); |
|
return true; |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
// getPropertyReferenceElement() | // getPropertyReferenceElement() |
// | // |
// <!ELEMENT PROPERTY.REFERENCE (QUALIFIER*,(VALUE.REFERENCE)?)> | // <!ELEMENT PROPERTY.REFERENCE (QUALIFIER*,(VALUE.REFERENCE)?)> |
|
|
| |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
// | // |
|
// getParameterReferenceArrayElement() |
|
// |
|
// <!ELEMENT PARAMETER.REFARRAY (QUALIFIER*)> |
|
// <!ATTLIST PARAMETER.REFARRAY |
|
// %CIMName; |
|
// %ReferenceClass; |
|
// %ArraySize;> |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
Boolean XmlReader::getParameterReferenceArrayElement( |
|
XmlParser& parser, |
|
CIMParameter& parameter) |
|
{ |
|
XmlEntry entry; |
|
|
|
if (!testStartTagOrEmptyTag(parser, entry, "PARAMETER.REFARRAY")) |
|
return false; |
|
|
|
Boolean empty = entry.type == XmlEntry::EMPTY_TAG; |
|
|
|
// Get PARAMETER.NAME attribute: |
|
|
|
String name = getCimNameAttribute( |
|
parser.getLine(), entry, "PARAMETER.REFARRAY"); |
|
|
|
// Get PARAMETER.REFERENCECLASS attribute: |
|
|
|
String referenceClass = getReferenceClassAttribute( |
|
parser.getLine(), entry, "PARAMETER.REFARRAY"); |
|
|
|
// Get PARAMETER.ARRAYSIZE attribute: |
|
|
|
Uint32 arraySize = 0; |
|
getArraySizeAttribute(parser.getLine(), entry, "PARAMETER.REFARRAY", |
|
arraySize); |
|
|
|
// Create parameter: |
|
|
|
parameter = CIMParameter(name, CIMType::REFERENCE, true, arraySize, |
|
referenceClass); |
|
|
|
if (!empty) |
|
{ |
|
getQualifierElements(parser, parameter); |
|
expectEndTag(parser, "PARAMETER.REFARRAY"); |
|
} |
|
|
|
return true; |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
// GetParameterElements() | // GetParameterElements() |
// | // |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
|
|
| |
while (XmlReader::getParameterElement(parser, parameter) || | while (XmlReader::getParameterElement(parser, parameter) || |
XmlReader::getParameterArrayElement(parser, parameter) || | XmlReader::getParameterArrayElement(parser, parameter) || |
XmlReader::getParameterReferenceElement(parser, parameter)) |
XmlReader::getParameterReferenceElement(parser, parameter) || |
|
XmlReader::getParameterReferenceArrayElement(parser, parameter)) |
{ | { |
try | try |
{ | { |
|
|
| |
// Get ISARRAY attribute: | // Get ISARRAY attribute: |
| |
Boolean isArray = false; |
Boolean isArray = getCimBooleanAttribute( |
getIsArrayAttribute( |
parser.getLine(), entry, "QUALIFIER.DECLARATION", "ISARRAY", |
parser.getLine(), entry, "QUALIFIER.DECLARATION", isArray); |
false, false); |
| |
// Get ARRAYSIZE attribute: | // Get ARRAYSIZE attribute: |
| |
|
|
| |
if (!empty) | if (!empty) |
{ | { |
|
// ATTN-RK-P2-20020219: Decoding algorithm must not depend on the |
|
// ordering of qualifiers and parameters. |
getQualifierElements(parser, method); | getQualifierElements(parser, method); |
| |
GetParameterElements(parser, method); | GetParameterElements(parser, method); |
|
|
} | } |
| |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
|
// getNamedInstanceElement() |
|
// |
|
// <!ELEMENT VALUE.NAMEDINSTANCE (INSTANCENAME,INSTANCE)> |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
Boolean XmlReader::getNamedInstanceElement( |
|
XmlParser& parser, |
|
CIMNamedInstance& namedInstance) |
|
{ |
|
XmlEntry entry; |
|
|
|
if (!testStartTag(parser, entry, "VALUE.NAMEDINSTANCE")) |
|
return false; |
|
|
|
CIMReference instanceName; |
|
|
|
// Get INSTANCENAME elements: |
|
|
|
if (!getInstanceNameElement(parser, instanceName)) |
|
{ |
|
throw XmlValidationError(parser.getLine(), |
|
"expected INSTANCENAME element"); |
|
} |
|
|
|
CIMInstance instance; |
|
|
|
// Get INSTANCE elements: |
|
|
|
if (!getInstanceElement(parser, instance)) |
|
{ |
|
throw XmlValidationError(parser.getLine(), |
|
"expected INSTANCE element"); |
|
} |
|
|
|
// Get VALUE.NAMEDINSTANCE end tag: |
|
|
|
expectEndTag(parser, "VALUE.NAMEDINSTANCE"); |
|
|
|
namedInstance.set(instanceName, instance); |
|
|
|
return true; |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// getObject() |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
void XmlReader::getObject(XmlParser& parser, CIMClass& x) |
|
{ |
|
if (!getClassElement(parser, x)) |
|
{ |
|
throw XmlValidationError(parser.getLine(), |
|
"expected CLASS element"); |
|
} |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// getObject() |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
void XmlReader::getObject(XmlParser& parser, CIMInstance& x) |
|
{ |
|
if (!getInstanceElement(parser, x)) |
|
{ |
|
throw XmlValidationError(parser.getLine(), |
|
"expected INSTANCE element"); |
|
} |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// getObject() |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
void XmlReader::getObject(XmlParser& parser, CIMQualifierDecl& x) |
|
{ |
|
if (!getQualifierDeclElement(parser, x)) |
|
{ |
|
throw XmlValidationError(parser.getLine(), |
|
"expected QUALIFIER.DECLARATION element"); |
|
} |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
// | // |
// getMessageStartTag() | // getMessageStartTag() |
// | // |
|
|
| |
Boolean XmlReader::getMessageStartTag( | Boolean XmlReader::getMessageStartTag( |
XmlParser& parser, | XmlParser& parser, |
Uint32& id, |
String& id, |
const char*& protocolVersion) |
String& protocolVersion) |
{ | { |
XmlEntry entry; | XmlEntry entry; |
| |
|
|
| |
if (!entry.getAttributeValue("PROTOCOLVERSION", protocolVersion)) | if (!entry.getAttributeValue("PROTOCOLVERSION", protocolVersion)) |
throw XmlValidationError(parser.getLine(), | throw XmlValidationError(parser.getLine(), |
"Bad or missing MESSAGE.ID attribute"); |
"Bad or missing MESSAGE.PROTOCOLVERSION attribute"); |
| |
return true; | return true; |
} | } |
|
|
| |
expectContentOrCData(parser, entry); | expectContentOrCData(parser, entry); |
| |
if (strcmp(entry.text, "TRUE") == 0) |
if (CompareNoCase(entry.text, "TRUE") == 0) |
result = true; | result = true; |
else if (strcmp(entry.text, "FALSE") == 0) |
else if (CompareNoCase(entry.text, "FALSE") == 0) |
result = false; | result = false; |
else | else |
throw XmlSemanticError(parser.getLine(), | throw XmlSemanticError(parser.getLine(), |
|
|
| |
Boolean XmlReader::getErrorElement( | Boolean XmlReader::getErrorElement( |
XmlParser& parser, | XmlParser& parser, |
CIMException::Code& code, |
CIMStatusCode& code, |
const char*& description, | const char*& description, |
Boolean required) | Boolean required) |
{ | { |
|
|
throw XmlValidationError( | throw XmlValidationError( |
parser.getLine(), "missing ERROR.CODE attribute"); | parser.getLine(), "missing ERROR.CODE attribute"); |
| |
code = CIMException::Code(tmpCode); |
code = CIMStatusCode(tmpCode); |
| |
// Get ERROR.DESCRIPTION: | // Get ERROR.DESCRIPTION: |
| |
|
|
return true; | return true; |
} | } |
| |
|
|
|
//------------------------------------------------------------------------------ |
|
// getObjectWithPath() |
|
// |
|
// <!ELEMENT VALUE.OBJECTWITHPATH ((CLASSPATH,CLASS)|(INSTANCEPATH,INSTANCE))> |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
Boolean XmlReader::getObjectWithPath( |
|
XmlParser& parser, |
|
CIMObjectWithPath& objectWithPath) |
|
{ |
|
XmlEntry entry; |
|
|
|
if (!testStartTag(parser, entry, "VALUE.OBJECTWITHPATH")) |
|
return false; |
|
|
|
CIMReference reference; |
|
Boolean isInstance = false; |
|
|
|
if (XmlReader::getInstancePathElement(parser, reference)) |
|
isInstance = true; |
|
else if (!XmlReader::getClassPathElement(parser, reference)) |
|
{ |
|
throw XmlValidationError(parser.getLine(), |
|
"Expected INSTANCE element"); |
|
} |
|
|
|
if (isInstance) |
|
{ |
|
CIMInstance cimInstance; |
|
|
|
if (!XmlReader::getInstanceElement(parser, cimInstance)) |
|
{ |
|
throw XmlValidationError(parser.getLine(), |
|
"Expected INSTANCEPATH or CLASSPATH element"); |
|
} |
|
objectWithPath.set(reference, CIMObject(cimInstance)); |
|
} |
|
else |
|
{ |
|
CIMClass cimClass; |
|
|
|
if (!XmlReader::getClassElement(parser, cimClass)) |
|
{ |
|
throw XmlValidationError(parser.getLine(), |
|
"Expected CLASS element"); |
|
} |
|
objectWithPath.set(reference, CIMObject(cimClass)); |
|
} |
|
|
|
expectEndTag(parser, "VALUE.OBJECTWITHPATH"); |
|
|
|
return true; |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// <objectName>: (CLASSNAME|INSTANCENAME) |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
Boolean XmlReader::getObjectNameElement( |
|
XmlParser& parser, |
|
CIMReference& objectName) |
|
{ |
|
String className; |
|
|
|
if (getClassNameElement(parser, className, false)) |
|
{ |
|
objectName.set(String(), String(), className); |
|
return true; |
|
} |
|
else if (getInstanceNameElement(parser, objectName)) |
|
return true; |
|
else |
|
{ |
|
throw XmlValidationError(parser.getLine(), |
|
"expected CLASSNAME or INSTANCENAME element"); |
|
} |
|
|
|
return false; |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// <!ELEMENT OBJECTPATH (INSTANCEPATH|CLASSPATH)> |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
Boolean XmlReader::getObjectPathElement( |
|
XmlParser& parser, |
|
CIMReference& objectPath) |
|
{ |
|
XmlEntry entry; |
|
|
|
if (!testStartTag(parser, entry, "OBJECTPATH")) |
|
return false; |
|
|
|
if (getClassPathElement(parser, objectPath)) |
|
{ |
|
expectEndTag(parser, "OBJECTPATH"); |
|
return true; |
|
} |
|
else if (getInstancePathElement(parser, objectPath)) |
|
{ |
|
expectEndTag(parser, "OBJECTPATH"); |
|
return true; |
|
} |
|
else |
|
{ |
|
throw XmlValidationError(parser.getLine(), |
|
"expected INSTANCEPATH or CLASSPATH element"); |
|
} |
|
|
|
PEGASUS_UNREACHABLE ( return false; ) |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// getEMethodCallStartTag() |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
Boolean XmlReader::getEMethodCallStartTag( |
|
XmlParser& parser, |
|
const char*& name) |
|
{ |
|
XmlEntry entry; |
|
|
|
if (!testStartTag(parser, entry, "EXPMETHODCALL")) |
|
return false; |
|
|
|
// Get EXPMETHODCALL.NAME attribute: |
|
|
|
if (!entry.getAttributeValue("NAME", name)) |
|
throw XmlValidationError(parser.getLine(), |
|
"Missing EXPMETHODCALL.NAME attribute"); |
|
|
|
return true; |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// getEMethodResponseStartTag() |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
Boolean XmlReader::getEMethodResponseStartTag( |
|
XmlParser& parser, |
|
const char*& name) |
|
{ |
|
XmlEntry entry; |
|
|
|
if (!testStartTag(parser, entry, "EXPMETHODRESPONSE")) |
|
return false; |
|
|
|
// Get EXPMETHODRESPONSE.NAME attribute: |
|
|
|
if (!entry.getAttributeValue("NAME", name)) |
|
throw XmlValidationError(parser.getLine(), |
|
"Missing EXPMETHODRESPONSE.NAME attribute"); |
|
|
|
return true; |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// getMethodCallStartTag() |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
Boolean XmlReader::getMethodCallStartTag( |
|
XmlParser& parser, |
|
const char*& name) |
|
{ |
|
XmlEntry entry; |
|
|
|
if (!testStartTag(parser, entry, "METHODCALL")) |
|
return false; |
|
|
|
// Get METHODCALL.NAME attribute: |
|
|
|
if (!entry.getAttributeValue("NAME", name)) |
|
throw XmlValidationError(parser.getLine(), |
|
"Missing METHODCALL.NAME attribute"); |
|
|
|
return true; |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// getMethodResponseStartTag() |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
Boolean XmlReader::getMethodResponseStartTag( |
|
XmlParser& parser, |
|
const char*& name) |
|
{ |
|
XmlEntry entry; |
|
|
|
if (!testStartTag(parser, entry, "METHODRESPONSE")) |
|
return false; |
|
|
|
// Get METHODRESPONSE.NAME attribute: |
|
|
|
if (!entry.getAttributeValue("NAME", name)) |
|
throw XmlValidationError(parser.getLine(), |
|
"Missing METHODRESPONSE.NAME attribute"); |
|
|
|
return true; |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// getParamValueElement() |
|
// |
|
// <!ELEMENT PARAMVALUE (VALUE|VALUE.REFERENCE|VALUE.ARRAY|VALUE.REFARRAY)?> |
|
// <!ATTLIST PARAMVALUE |
|
// %CIMName; |
|
// %ParamType;> |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
Boolean XmlReader::getParamValueElement( |
|
XmlParser& parser, |
|
CIMParamValue& paramValue) |
|
{ |
|
XmlEntry entry; |
|
const char* name; |
|
CIMType type; |
|
CIMValue value; |
|
|
|
if (!testStartTagOrEmptyTag(parser, entry, "PARAMVALUE")) |
|
return false; |
|
|
|
Boolean empty = entry.type == XmlEntry::EMPTY_TAG; |
|
|
|
// Get PARAMVALUE.NAME attribute: |
|
|
|
if (!entry.getAttributeValue("NAME", name)) |
|
throw XmlValidationError(parser.getLine(), |
|
"Missing PARAMVALUE.NAME attribute"); |
|
|
|
// Get PARAMVALUE.PARAMTYPE attribute: |
|
|
|
type = getCimTypeAttribute(parser.getLine(), entry, "PARAMVALUE", |
|
"PARAMTYPE", false); |
|
|
|
if (!empty) |
|
{ |
|
// Parse VALUE.REFERENCE and VALUE.REFARRAY type |
|
if ( (type == CIMType::REFERENCE) || (type == CIMType::NONE) ) |
|
{ |
|
CIMReference reference; |
|
if (XmlReader::getValueReferenceElement(parser, reference)) |
|
{ |
|
value.set(reference); |
|
type = CIMType::REFERENCE; |
|
} |
|
else if (XmlReader::getValueReferenceArrayElement(parser, value)) |
|
{ |
|
type = CIMType::REFERENCE; |
|
} |
|
// If type==reference but no VALUE.REFERENCE found, use null value |
|
} |
|
|
|
// Parse non-reference value |
|
if ( type != CIMType::REFERENCE ) |
|
{ |
|
// If we don't know what type the value is, read it as a String |
|
CIMType effectiveType = type; |
|
if ( effectiveType == CIMType::NONE) |
|
{ |
|
effectiveType = CIMType::STRING; |
|
} |
|
|
|
if ( !XmlReader::getValueArrayElement(parser, effectiveType, value) && |
|
!XmlReader::getValueElement(parser, effectiveType, value) ) |
|
{ |
|
value.clear(); // Isn't necessary; should already be cleared |
|
} |
|
} |
|
|
|
expectEndTag(parser, "PARAMVALUE"); |
|
} |
|
|
|
paramValue = CIMParamValue(name, value, Boolean(type!=CIMType::NONE)); |
|
|
|
return true; |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// getReturnValueElement() |
|
// |
|
// <!ELEMENT RETURNVALUE (VALUE|VALUE.REFERENCE)> |
|
// <!ATTLIST RETURNVALUE |
|
// %ParamType;> |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
Boolean XmlReader::getReturnValueElement( |
|
XmlParser& parser, |
|
CIMValue& returnValue) |
|
{ |
|
XmlEntry entry; |
|
CIMType type; |
|
CIMValue value; |
|
|
|
if (!testStartTag(parser, entry, "RETURNVALUE")) |
|
return false; |
|
|
|
// Get RETURNVALUE.PARAMTYPE attribute: |
|
// NOTE: Array type return values are not allowed (2/20/02) |
|
|
|
type = getCimTypeAttribute(parser.getLine(), entry, "RETURNVALUE", |
|
"PARAMTYPE", false); |
|
|
|
// Parse VALUE.REFERENCE type |
|
if ( (type == CIMType::REFERENCE) || (type == CIMType::NONE) ) |
|
{ |
|
CIMReference reference; |
|
if (XmlReader::getValueReferenceElement(parser, reference)) |
|
{ |
|
returnValue.set(reference); |
|
type = CIMType::REFERENCE; |
|
} |
|
else if (type == CIMType::REFERENCE) |
|
{ |
|
throw XmlValidationError(parser.getLine(), |
|
"expected VALUE.REFERENCE element"); |
|
} |
|
} |
|
|
|
// Parse non-reference return value |
|
if ( type != CIMType::REFERENCE ) |
|
{ |
|
// If we don't know what type the value is, read it as a String |
|
if ( type == CIMType::NONE) |
|
{ |
|
type = CIMType::STRING; |
|
} |
|
|
|
if ( !XmlReader::getValueElement(parser, type, returnValue) ) |
|
{ |
|
throw XmlValidationError(parser.getLine(), |
|
"expected VALUE element"); |
|
} |
|
} |
|
|
|
expectEndTag(parser, "RETURNVALUE"); |
|
|
|
return true; |
|
} |
|
|
PEGASUS_NAMESPACE_END | PEGASUS_NAMESPACE_END |