version 1.3, 2001/03/04 21:57:34
|
version 1.23, 2002/05/15 12:28:21
|
|
|
//BEGIN_LICENSE |
//%///////////////////////////////////////////////////////////////////////////// |
// | // |
// Copyright (c) 2000 The Open Group, BMC Software, Tivoli Systems, IBM |
// Copyright (c) 2000, 2001 The Open group, BMC Software, Tivoli Systems, IBM |
// | // |
// 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 SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR |
// THE ABOVE COPYRIGHT NOTICE AND THIS PERMISSION NOTICE SHALL BE INCLUDED IN |
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, |
// ALL COPIES OR SUBSTANTIAL PORTIONS OF THE SOFTWARE. THE SOFTWARE IS PROVIDED |
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL |
// "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT |
// THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER |
// LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR |
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING |
// PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT |
// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER |
// HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN |
// DEALINGS IN THE SOFTWARE. |
// 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: |
// Author: Mike Brasher (mbrasher@bmc.com) |
// | // |
// $Log$ |
// Modified By: |
// Revision 1.3 2001/03/04 21:57:34 bob |
|
// Changed print methods to take a stream instead of hardcoded cout |
|
// | // |
// Revision 1.2 2001/02/19 01:47:16 mike |
//%///////////////////////////////////////////////////////////////////////////// |
// Renamed names of the form CIMConst to ConstCIM. |
|
// |
|
// Revision 1.1 2001/02/18 18:39:06 mike |
|
// new |
|
// |
|
// Revision 1.2 2001/02/18 03:56:01 mike |
|
// Changed more class names (e.g., ConstClassDecl -> ConstCIMClass) |
|
// |
|
// Revision 1.1 2001/02/16 02:07:06 mike |
|
// Renamed many classes and headers (using new CIM prefixes). |
|
// |
|
// Revision 1.3 2001/01/23 01:25:35 mike |
|
// Reworked resolve scheme. |
|
// |
|
// Revision 1.2 2001/01/22 00:45:47 mike |
|
// more work on resolve scheme |
|
// |
|
// Revision 1.1.1.1 2001/01/14 19:52:58 mike |
|
// Pegasus import |
|
// |
|
// |
|
//END_HISTORY |
|
| |
|
#include <Pegasus/Common/Config.h> |
#include <cassert> | #include <cassert> |
#include "CIMMethod.h" | #include "CIMMethod.h" |
|
#include "CIMMethodRep.h" |
#include "Indentor.h" | #include "Indentor.h" |
#include "CIMName.h" | #include "CIMName.h" |
#include "CIMScope.h" | #include "CIMScope.h" |
#include "XmlWriter.h" | #include "XmlWriter.h" |
|
#include "MofWriter.h" |
| |
PEGASUS_NAMESPACE_BEGIN | PEGASUS_NAMESPACE_BEGIN |
| |
|
|
if (!CIMName::legal(name)) | if (!CIMName::legal(name)) |
throw IllegalName(); | throw IllegalName(); |
| |
if (classOrigin.getLength() && !CIMName::legal(classOrigin)) |
if (classOrigin.size() && !CIMName::legal(classOrigin)) |
throw IllegalName(); | throw IllegalName(); |
| |
if (type == CIMType::NONE) | if (type == CIMType::NONE) |
|
|
| |
void CIMMethodRep::addParameter(const CIMParameter& x) | void CIMMethodRep::addParameter(const CIMParameter& x) |
{ | { |
if (!x) |
if (x.isNull()) |
throw UnitializedHandle(); |
throw UninitializedHandle(); |
| |
if (findParameter(x.getName()) != Uint32(-1)) |
if (findParameter(x.getName()) != PEG_NOT_FOUND) |
throw AlreadyExists(); | throw AlreadyExists(); |
| |
_parameters.append(x); | _parameters.append(x); |
} | } |
| |
Uint32 CIMMethodRep::findParameter(const String& name) |
Uint32 CIMMethodRep::findParameter(const String& name) const |
{ | { |
for (Uint32 i = 0, n = _parameters.getSize(); i < n; i++) |
for (Uint32 i = 0, n = _parameters.size(); i < n; i++) |
{ | { |
if (CIMName::equal(_parameters[i].getName(), name)) | if (CIMName::equal(_parameters[i].getName(), name)) |
return i; | return i; |
} | } |
| |
return Uint32(-1); |
return PEG_NOT_FOUND; |
} | } |
| |
CIMParameter CIMMethodRep::getParameter(Uint32 pos) | CIMParameter CIMMethodRep::getParameter(Uint32 pos) |
{ | { |
if (pos >= _parameters.getSize()) |
if (pos >= _parameters.size()) |
throw OutOfBounds(); | throw OutOfBounds(); |
| |
return _parameters[pos]; | return _parameters[pos]; |
|
|
| |
Uint32 CIMMethodRep::getParameterCount() const | Uint32 CIMMethodRep::getParameterCount() const |
{ | { |
return _parameters.getSize(); |
return _parameters.size(); |
} | } |
| |
void CIMMethodRep::resolve( | void CIMMethodRep::resolve( |
|
|
| |
// Check for type mismatch between return types. | // Check for type mismatch between return types. |
| |
assert (inheritedMethod); |
assert (!inheritedMethod.isNull()); |
| |
// 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::METHOD, | CIMScope::METHOD, |
false, | false, |
inheritedMethod._rep->_qualifiers); |
inheritedMethod._rep->_qualifiers, |
|
true); |
| |
// Validate each of the parameters: | // Validate each of the parameters: |
| |
for (size_t i = 0; i < _parameters.getSize(); i++) |
for (size_t i = 0; i < _parameters.size(); i++) |
_parameters[i].resolve(declContext, nameSpace); | _parameters[i].resolve(declContext, nameSpace); |
| |
_classOrigin = inheritedMethod.getClassOrigin(); | _classOrigin = inheritedMethod.getClassOrigin(); |
|
|
nameSpace, | nameSpace, |
CIMScope::METHOD, | CIMScope::METHOD, |
false, | false, |
dummy); |
dummy, |
|
true); |
| |
// Validate each of the parameters: | // Validate each of the parameters: |
| |
for (size_t i = 0; i < _parameters.getSize(); i++) |
for (size_t i = 0; i < _parameters.size(); i++) |
_parameters[i].resolve(declContext, nameSpace); | _parameters[i].resolve(declContext, nameSpace); |
} | } |
| |
|
|
| |
out << " NAME=\"" << _name << "\""; | out << " NAME=\"" << _name << "\""; |
| |
out << " TYPE=\"" << TypeToString(_type) << "\""; |
out << " TYPE=\"" << _type.toString() << "\""; |
| |
if (_classOrigin.getLength()) |
if (_classOrigin.size()) |
out << " CLASSORIGIN=\"" << _classOrigin << "\""; | out << " CLASSORIGIN=\"" << _classOrigin << "\""; |
| |
if (_propagated != false) | if (_propagated != false) |
|
|
| |
_qualifiers.toXml(out); | _qualifiers.toXml(out); |
| |
for (Uint32 i = 0, n = _parameters.getSize(); i < n; i++) |
for (Uint32 i = 0, n = _parameters.size(); i < n; i++) |
_parameters[i].toXml(out); |
XmlWriter::appendParameterElement(out, _parameters[i]); |
| |
out << "</METHOD>\n"; | out << "</METHOD>\n"; |
} | } |
| |
void CIMMethodRep::print(std::ostream &os) const |
/** |
|
The BNF for this is; |
|
methodDeclaration = [ qualifierList ] dataType methodName |
|
"(" [ parameterList ] ")" ";" |
|
|
|
parameterList = parameter *( "," parameter ) |
|
Format with qualifiers on one line and declaration on another. Start |
|
with newline but none at the end. |
|
*/ |
|
void CIMMethodRep::toMof(Array<Sint8>& out) const //ATTNKS: |
|
{ |
|
// Output the qualifier list starting on new line |
|
if (_qualifiers.getCount()) |
|
out << "\n"; |
|
|
|
_qualifiers.toMof(out); |
|
|
|
// output the type, MethodName and ParmeterList left enclosure |
|
out << "\n" << _type.toString() << " " << _name << "("; |
|
|
|
// output the param list separated by commas. |
|
|
|
for (Uint32 i = 0, n = _parameters.size(); i < n; i++) |
{ | { |
Array<Sint8> tmp; |
// If not first, output comma separator |
toXml(tmp); |
if (i) |
tmp.append('\0'); |
out << ", "; |
os << tmp.getData() << std::endl; |
|
|
MofWriter::appendParameterElement(out, _parameters[i]); |
|
} |
|
|
|
// output the parameterlist and method terminator |
|
out << ");"; |
} | } |
| |
|
|
CIMMethodRep::CIMMethodRep() | CIMMethodRep::CIMMethodRep() |
{ | { |
| |
|
|
{ | { |
x._qualifiers.cloneTo(_qualifiers); | x._qualifiers.cloneTo(_qualifiers); |
| |
_parameters.reserve(x._parameters.getSize()); |
_parameters.reserve(x._parameters.size()); |
| |
for (Uint32 i = 0, n = x._parameters.getSize(); i < n; i++) |
for (Uint32 i = 0, n = x._parameters.size(); i < n; i++) |
_parameters.append(x._parameters[i].clone()); | _parameters.append(x._parameters[i].clone()); |
} | } |
| |
CIMMethodRep& CIMMethodRep::operator=(const CIMMethodRep& x) |
|
{ |
|
return *this; |
|
} |
|
|
|
Boolean CIMMethodRep::identical(const CIMMethodRep* x) const | Boolean CIMMethodRep::identical(const CIMMethodRep* x) const |
{ | { |
if (_name != x->_name) | if (_name != x->_name) |
|
|
if (!_qualifiers.identical(x->_qualifiers)) | if (!_qualifiers.identical(x->_qualifiers)) |
return false; | return false; |
| |
if (_parameters.getSize() != x->_parameters.getSize()) |
if (_parameters.size() != x->_parameters.size()) |
return false; | return false; |
| |
for (Uint32 i = 0, n = _parameters.getSize(); i < n; i++) |
for (Uint32 i = 0, n = _parameters.size(); i < n; i++) |
{ | { |
if (!_parameters[i].identical(x->_parameters[i])) | if (!_parameters[i].identical(x->_parameters[i])) |
return false; | return false; |
|
|
return true; | return true; |
} | } |
| |
|
void CIMMethodRep::setType(CIMType type) |
|
{ |
|
_type = type; |
|
|
|
if (type == CIMType::NONE) |
|
throw NullType(); |
|
} |
|
|
PEGASUS_NAMESPACE_END | PEGASUS_NAMESPACE_END |