version 1.1, 2001/02/18 18:39:06
|
version 1.30, 2004/04/14 22:18:56
|
|
|
//BEGIN_LICENSE |
//%2003//////////////////////////////////////////////////////////////////////// |
// | // |
// Copyright (c) 2000 The Open Group, BMC Software, Tivoli Systems, IBM |
// Copyright (c) 2000, 2001, 2002 BMC Software, Hewlett-Packard Development |
|
// Company, L. P., IBM Corp., The Open Group, Tivoli Systems. |
|
// Copyright (c) 2003 BMC Software; Hewlett-Packard Development Company, L. P.; |
|
// IBM Corp.; EMC Corporation, The Open Group. |
|
// |
|
// Permission is hereby granted, free of charge, to any person obtaining a copy |
|
// of this software and associated documentation files (the "Software"), to |
|
// deal in the Software without restriction, including without limitation the |
|
// rights to use, copy, modify, merge, publish, distribute, sublicense, and/or |
|
// sell copies of the Software, and to permit persons to whom the Software is |
|
// furnished to do so, subject to the following conditions: |
|
// |
|
// THE ABOVE COPYRIGHT NOTICE AND THIS PERMISSION NOTICE SHALL BE INCLUDED IN |
|
// ALL COPIES OR SUBSTANTIAL PORTIONS OF THE SOFTWARE. THE SOFTWARE IS PROVIDED |
|
// "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT |
|
// LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR |
|
// PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT |
|
// HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN |
|
// ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION |
|
// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. |
|
// |
|
//============================================================================== |
// | // |
// Permission is hereby granted, free of charge, to any person obtaining a |
// Author: Mike Brasher (mbrasher@bmc.com) |
// copy of this software and associated documentation files (the "Software"), |
|
// to deal in the Software without restriction, including without limitation |
|
// the rights to use, copy, modify, merge, publish, distribute, sublicense, |
|
// and/or sell copies of the Software, and to permit persons to whom the |
|
// Software is furnished to do so, subject to the following conditions: |
|
// | // |
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR |
// Modified By: Carol Ann Krug Graves, Hewlett-Packard Company |
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, |
// (carolann_graves@hp.com) |
// 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.1 2001/02/18 18:39:06 mike |
|
// new |
|
// |
|
// Revision 1.1 2001/02/16 02:07:06 mike |
|
// Renamed many classes and headers (using new CIM prefixes). |
|
// |
|
// Revision 1.2 2001/01/22 00:45:47 mike |
|
// more work on resolve scheme |
|
// |
|
// Revision 1.1.1.1 2001/01/14 19:53:02 mike |
|
// Pegasus import |
|
// |
|
// |
|
//END_HISTORY |
|
| |
|
#include <Pegasus/Common/Config.h> |
#include <cstdio> | #include <cstdio> |
#include "CIMParameter.h" | #include "CIMParameter.h" |
|
#include "CIMParameterRep.h" |
#include "Indentor.h" | #include "Indentor.h" |
#include "CIMName.h" | #include "CIMName.h" |
#include "CIMScope.h" | #include "CIMScope.h" |
|
|
PEGASUS_NAMESPACE_BEGIN | PEGASUS_NAMESPACE_BEGIN |
| |
CIMParameterRep::CIMParameterRep( | CIMParameterRep::CIMParameterRep( |
const String& name, |
const CIMName& name, |
CIMType type, | CIMType type, |
Boolean isArray, | Boolean isArray, |
Uint32 arraySize, | Uint32 arraySize, |
const String& referenceClassName) |
const CIMName& referenceClassName) |
: _name(name), _type(type), | : _name(name), _type(type), |
_isArray(isArray), _arraySize(arraySize), | _isArray(isArray), _arraySize(arraySize), |
_referenceClassName(referenceClassName) | _referenceClassName(referenceClassName) |
{ | { |
if (!CIMName::legal(name)) |
|
throw IllegalName(); |
|
|
|
if (_type == CIMType::NONE) |
|
throw NullType(); |
|
|
|
if (_arraySize && !_isArray) | if (_arraySize && !_isArray) |
throw IncompatibleTypes(); |
throw TypeMismatchException(); |
| |
if (referenceClassName.getLength()) |
if (!referenceClassName.isNull()) |
{ | { |
if (!CIMName::legal(referenceClassName)) |
if (_type != CIMTYPE_REFERENCE) |
throw IllegalName(); |
|
|
|
if (_type != CIMType::REFERENCE) |
|
{ | { |
throw ExpectedReferenceValue(); |
throw TypeMismatchException(); |
} | } |
} | } |
else | else |
{ | { |
|
// ATTN: revisit this later! (Make consistent with CIMPropertyRep) |
// ATTN: revisit this later! |
|
#if 0 | #if 0 |
if (_type == CIMType::REFERENCE) |
if (_type == CIMTYPE_REFERENCE) |
throw MissingReferenceClassName(); |
throw TypeMismatchException(); |
#endif | #endif |
} | } |
} | } |
|
|
| |
} | } |
| |
void CIMParameterRep::setName(const String& name) |
void CIMParameterRep::setName(const CIMName& name) |
{ | { |
if (!CIMName::legal(name)) |
|
throw IllegalName(); |
|
|
|
_name = name; | _name = name; |
} | } |
| |
|
void CIMParameterRep::removeQualifier(Uint32 index) |
|
{ |
|
if (index >= _qualifiers.getCount()) |
|
throw IndexOutOfBoundsException(); |
|
|
|
_qualifiers.removeQualifier (index); |
|
} |
|
|
void CIMParameterRep::resolve( | void CIMParameterRep::resolve( |
DeclContext* declContext, | DeclContext* declContext, |
const String& nameSpace) |
const CIMNamespaceName& nameSpace) |
{ | { |
// Validate the qualifiers of the method (according to | // Validate the qualifiers of the method (according to |
// superClass's method with the same name). This method | // superClass's method with the same name). This method |
|
|
nameSpace, | nameSpace, |
CIMScope::PARAMETER, | CIMScope::PARAMETER, |
false, | false, |
dummy); |
dummy, |
|
true); |
} | } |
| |
void CIMParameterRep::toXml(Array<Sint8>& out) const | void CIMParameterRep::toXml(Array<Sint8>& out) const |
{ | { |
if (_isArray) | if (_isArray) |
{ | { |
out << "<PARAMETER.ARRAY"; |
if (_type == CIMTYPE_REFERENCE) |
|
{ |
|
out << "<PARAMETER.REFARRAY"; |
out << " NAME=\"" << _name << "\" "; | out << " NAME=\"" << _name << "\" "; |
| |
out << " TYPE=\"" << TypeToString(_type) << "\""; |
if (!_referenceClassName.isNull()) |
|
{ |
|
out << " REFERENCECLASS=\"" << _referenceClassName.getString() |
|
<< "\""; |
|
} |
|
|
|
out << ">\n"; |
|
|
|
_qualifiers.toXml(out); |
|
|
|
out << "</PARAMETER.REFARRAY>\n"; |
|
} |
|
else |
|
{ |
|
out << "<PARAMETER.ARRAY"; |
|
out << " NAME=\"" << _name << "\" "; |
|
out << " TYPE=\"" << cimTypeToString (_type) << "\""; |
| |
if (_arraySize) | if (_arraySize) |
{ | { |
|
|
| |
out << "</PARAMETER.ARRAY>\n"; | out << "</PARAMETER.ARRAY>\n"; |
} | } |
else |
} |
|
else if (_type == CIMTYPE_REFERENCE) |
{ | { |
out << "<PARAMETER"; |
out << "<PARAMETER.REFERENCE"; |
|
|
out << " NAME=\"" << _name << "\" "; | out << " NAME=\"" << _name << "\" "; |
|
if (!_referenceClassName.isNull()) |
|
{ |
|
out << " REFERENCECLASS=\"" << _referenceClassName.getString() << |
|
"\""; |
|
} |
|
out << ">\n"; |
| |
out << " TYPE=\"" << TypeToString(_type) << "\""; |
_qualifiers.toXml(out); |
| |
|
out << "</PARAMETER.REFERENCE>\n"; |
|
} |
|
else |
|
{ |
|
out << "<PARAMETER"; |
|
out << " NAME=\"" << _name << "\" "; |
|
out << " TYPE=\"" << cimTypeToString (_type) << "\""; |
out << ">\n"; | out << ">\n"; |
| |
_qualifiers.toXml(out); | _qualifiers.toXml(out); |
|
|
} | } |
} | } |
| |
void CIMParameterRep::print() const |
/** toMof - puts the Mof representation of teh Parameter object to |
|
the output parameter array |
|
The BNF for this conversion is: |
|
parameterList = parameter *( "," parameter ) |
|
|
|
parameter = [ qualifierList ] (dataType|objectRef) parameterName |
|
[ array ] |
|
|
|
parameterName= IDENTIFIER |
|
|
|
array = "[" [positiveDecimalValue] "]" |
|
|
|
Format on a single line. |
|
*/ |
|
void CIMParameterRep::toMof(Array<Sint8>& out) const |
|
{ |
|
// Output the qualifiers for the parameter |
|
_qualifiers.toMof(out); |
|
|
|
if (_qualifiers.getCount()) |
|
out << " "; |
|
|
|
// Output the data type and name |
|
out << cimTypeToString (_type) << " " << _name; |
|
|
|
if (_isArray) |
|
{ |
|
//Output the array indicator "[ [arraysize] ]" |
|
if (_arraySize) |
{ | { |
Array<Sint8> tmp; |
char buffer[32]; |
toXml(tmp); |
sprintf(buffer, "[%d]", _arraySize); |
tmp.append('\0'); |
out << buffer; |
std::cout << tmp.getData() << std::endl; |
} |
|
else |
|
out << "[]"; |
|
} |
} | } |
| |
|
|
Boolean CIMParameterRep::identical(const CIMParameterRep* x) const | Boolean CIMParameterRep::identical(const CIMParameterRep* x) const |
{ | { |
if (_name != x->_name) |
if (!_name.equal (x->_name)) |
return false; | return false; |
| |
if (_type != x->_type) | if (_type != x->_type) |
return false; | return false; |
| |
if (_referenceClassName != x->_referenceClassName) |
if (!_referenceClassName.equal (x->_referenceClassName)) |
return false; | return false; |
| |
if (!_qualifiers.identical(x->_qualifiers)) | if (!_qualifiers.identical(x->_qualifiers)) |
|
|
x._qualifiers.cloneTo(_qualifiers); | x._qualifiers.cloneTo(_qualifiers); |
} | } |
| |
CIMParameterRep& CIMParameterRep::operator=(const CIMParameterRep& x) |
|
{ |
|
return *this; |
|
} |
|
|
|
void CIMParameterRep::setType(CIMType type) |
|
{ |
|
_type = type; |
|
|
|
if (_referenceClassName.getLength() == 0 && _type == CIMType::REFERENCE) |
|
{ |
|
throw MissingReferenceClassName(); |
|
} |
|
} |
|
|
|
PEGASUS_NAMESPACE_END | PEGASUS_NAMESPACE_END |