version 1.49, 2006/01/30 16:16:47
|
version 1.58, 2008/04/11 17:14:03
|
|
|
// | // |
//============================================================================== | //============================================================================== |
// | // |
// Author: Mike Brasher (mbrasher@bmc.com) |
|
// |
|
// Modified By: Carol Ann Krug Graves, Hewlett-Packard Company |
|
// (carolann_graves@hp.com) |
|
// David Dillard, VERITAS Software Corp. |
|
// (david.dillard@veritas.com) |
|
// |
|
//%///////////////////////////////////////////////////////////////////////////// | //%///////////////////////////////////////////////////////////////////////////// |
| |
#include <Pegasus/Common/Config.h> | #include <Pegasus/Common/Config.h> |
#include "CIMMethod.h" | #include "CIMMethod.h" |
#include "CIMMethodRep.h" | #include "CIMMethodRep.h" |
#include "Resolver.h" | #include "Resolver.h" |
#include "Indentor.h" |
|
#include "CIMName.h" | #include "CIMName.h" |
#include "CIMScope.h" | #include "CIMScope.h" |
#include "XmlWriter.h" |
#include <Pegasus/Common/MessageLoader.h> |
#include "MofWriter.h" |
|
#include <Pegasus/Common/MessageLoader.h> //l10n |
|
#include "StrLit.h" | #include "StrLit.h" |
| |
PEGASUS_NAMESPACE_BEGIN | PEGASUS_NAMESPACE_BEGIN |
| |
CIMMethodRep::CIMMethodRep() |
|
{ |
|
} |
|
|
|
CIMMethodRep::CIMMethodRep(const CIMMethodRep& x) : | CIMMethodRep::CIMMethodRep(const CIMMethodRep& x) : |
Sharable(), | Sharable(), |
_name(x._name), | _name(x._name), |
_type(x._type), | _type(x._type), |
_classOrigin(x._classOrigin), | _classOrigin(x._classOrigin), |
_propagated(x._propagated) |
_propagated(x._propagated), |
|
_ownerCount(0) |
{ | { |
x._qualifiers.cloneTo(_qualifiers); | x._qualifiers.cloneTo(_qualifiers); |
|
// Set the CIM name tag. |
|
_nameTag = generateCIMNameTag(_name); |
| |
_parameters.reserveCapacity(x._parameters.size()); | _parameters.reserveCapacity(x._parameters.size()); |
| |
|
|
const CIMName& classOrigin, | const CIMName& classOrigin, |
Boolean propagated) | Boolean propagated) |
: _name(name), _type(type), | : _name(name), _type(type), |
_classOrigin(classOrigin), _propagated(propagated) |
_classOrigin(classOrigin), |
|
_propagated(propagated), |
|
_ownerCount(0) |
{ | { |
// ensure name is not null | // ensure name is not null |
if(name.isNull()) | if(name.isNull()) |
{ | { |
throw UninitializedObjectException(); | throw UninitializedObjectException(); |
} | } |
} |
// Set the CIM name tag. |
|
_nameTag = generateCIMNameTag(_name); |
CIMMethodRep::~CIMMethodRep() |
|
{ |
|
} | } |
| |
void CIMMethodRep::setName(const CIMName& name) | void CIMMethodRep::setName(const CIMName& name) |
|
|
{ | { |
throw UninitializedObjectException(); | throw UninitializedObjectException(); |
} | } |
|
if (_ownerCount != 0 && _name != name) |
_name = name; |
|
} |
|
|
|
void CIMMethodRep::setClassOrigin(const CIMName& classOrigin) |
|
{ | { |
_classOrigin = classOrigin; |
MessageLoaderParms parms( |
|
"Common.CIMMethodRep.CONTAINED_METHOD_NAMECHANGEDEXCEPTION", |
|
"Attempted to change the name of a method" |
|
" already in a container."); |
|
throw Exception(parms); |
|
} |
|
_name = name; |
|
// Set the CIM name tag. |
|
_nameTag = generateCIMNameTag(_name); |
} | } |
| |
void CIMMethodRep::addParameter(const CIMParameter& x) | void CIMMethodRep::addParameter(const CIMParameter& x) |
|
|
if (x.isUninitialized()) | if (x.isUninitialized()) |
throw UninitializedObjectException(); | throw UninitializedObjectException(); |
| |
if (findParameter(x.getName()) != PEG_NOT_FOUND){ |
if (findParameter(x.getName()) != PEG_NOT_FOUND) |
//l10n |
{ |
//throw AlreadyExistsException |
|
//("parameter \"" + x.getName().getString () + "\""); |
|
MessageLoaderParms parms("Common.CIMMethodRep.PARAMETER", | MessageLoaderParms parms("Common.CIMMethodRep.PARAMETER", |
"parameter \"$0\"", | "parameter \"$0\"", |
x.getName().getString()); | x.getName().getString()); |
|
|
_parameters.append(x); | _parameters.append(x); |
} | } |
| |
Uint32 CIMMethodRep::findParameter(const CIMName& name) const |
|
{ |
|
for (Uint32 i = 0, n = _parameters.size(); i < n; i++) |
|
{ |
|
if (name.equal(_parameters[i].getName())) |
|
return i; |
|
} |
|
|
|
return PEG_NOT_FOUND; |
|
} |
|
|
|
CIMParameter CIMMethodRep::getParameter(Uint32 index) |
|
{ |
|
if (index >= _parameters.size()) |
|
throw IndexOutOfBoundsException(); |
|
|
|
return _parameters[index]; |
|
} |
|
|
|
void CIMMethodRep::removeParameter(Uint32 index) |
|
{ |
|
if (index >= _parameters.size()) |
|
throw IndexOutOfBoundsException(); |
|
|
|
_parameters.remove (index); |
|
} |
|
|
|
Uint32 CIMMethodRep::getParameterCount() const |
|
{ |
|
return _parameters.size(); |
|
} |
|
|
|
void CIMMethodRep::resolve( | void CIMMethodRep::resolve( |
DeclContext* declContext, | DeclContext* declContext, |
const CIMNamespaceName& nameSpace, | const CIMNamespaceName& nameSpace, |
|
|
Resolver::resolveParameter (_parameters[i], declContext, nameSpace); | Resolver::resolveParameter (_parameters[i], declContext, nameSpace); |
} | } |
| |
static const char* _toString(Boolean x) |
Boolean CIMMethodRep::identical(const CIMMethodRep* x) const |
{ |
|
return x ? "true" : "false"; |
|
} |
|
|
|
void CIMMethodRep::toXml(Buffer& out) const |
|
{ |
|
out << STRLIT("<METHOD NAME=\"") << _name; |
|
out.append('"'); |
|
|
|
out << STRLIT(" TYPE=\"") << cimTypeToString(_type); |
|
out.append('"'); |
|
|
|
if (!_classOrigin.isNull()) |
|
{ |
|
out << STRLIT(" CLASSORIGIN=\"") << _classOrigin; |
|
out.append('"'); |
|
} |
|
|
|
if (_propagated != false) |
|
{ |
|
out << STRLIT(" PROPAGATED=\"") << _toString(_propagated); |
|
out.append('"'); |
|
} |
|
|
|
out << STRLIT(">\n"); |
|
|
|
_qualifiers.toXml(out); |
|
|
|
for (Uint32 i = 0, n = _parameters.size(); i < n; i++) |
|
XmlWriter::appendParameterElement(out, _parameters[i]); |
|
|
|
out << STRLIT("</METHOD>\n"); |
|
} |
|
|
|
/** |
|
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(Buffer& out) const //ATTNKS: |
|
{ | { |
// Output the qualifier list starting on new line |
// If the pointers are the same, the objects must be identical |
if (_qualifiers.getCount()) |
if (this == x) |
out.append('\n'); |
|
|
|
_qualifiers.toMof(out); |
|
|
|
// output the type, MethodName and ParmeterList left enclosure |
|
out.append('\n'); |
|
out << cimTypeToString(_type); |
|
out.append(' '); |
|
out << _name; |
|
out.append('('); |
|
|
|
// output the param list separated by commas. |
|
|
|
for (Uint32 i = 0, n = _parameters.size(); i < n; i++) |
|
{ | { |
// If not first, output comma separator |
return true; |
if (i) |
|
out << STRLIT(", "); |
|
|
|
MofWriter::appendParameterElement(out, _parameters[i]); |
|
} |
|
|
|
// output the parameterlist and method terminator |
|
out << STRLIT(");"); |
|
} | } |
| |
|
|
Boolean CIMMethodRep::identical(const CIMMethodRep* x) const |
|
{ |
|
if (!_name.equal (x->_name)) | if (!_name.equal (x->_name)) |
return false; | return false; |
| |
|
|
return true; | return true; |
} | } |
| |
void CIMMethodRep::setType(CIMType type) |
|
{ |
|
_type = type; |
|
} |
|
|
|
PEGASUS_NAMESPACE_END | PEGASUS_NAMESPACE_END |