version 1.13, 2005/05/17 14:52:26
|
version 1.23, 2013/09/26 16:04:18
|
|
|
//%2005//////////////////////////////////////////////////////////////////////// |
//%LICENSE//////////////////////////////////////////////////////////////// |
// | // |
// Copyright (c) 2000, 2001, 2002 BMC Software; Hewlett-Packard Development |
// Licensed to The Open Group (TOG) under one or more contributor license |
// Company, L.P.; IBM Corp.; The Open Group; Tivoli Systems. |
// agreements. Refer to the OpenPegasusNOTICE.txt file distributed with |
// Copyright (c) 2003 BMC Software; Hewlett-Packard Development Company, L.P.; |
// this work for additional information regarding copyright ownership. |
// IBM Corp.; EMC Corporation, The Open Group. |
// Each contributor licenses this file to you under the OpenPegasus Open |
// Copyright (c) 2004 BMC Software; Hewlett-Packard Development Company, L.P.; |
// Source License; you may not use this file except in compliance with the |
// IBM Corp.; EMC Corporation; VERITAS Software Corporation; The Open Group. |
// License. |
// Copyright (c) 2005 Hewlett-Packard Development Company, L.P.; IBM Corp.; |
// |
// EMC Corporation; VERITAS Software 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"), |
// Permission is hereby granted, free of charge, to any person obtaining a copy |
// to deal in the Software without restriction, including without limitation |
// of this software and associated documentation files (the "Software"), to |
// the rights to use, copy, modify, merge, publish, distribute, sublicense, |
// deal in the Software without restriction, including without limitation the |
// and/or sell copies of the Software, and to permit persons to whom the |
// rights to use, copy, modify, merge, publish, distribute, sublicense, and/or |
// Software is furnished to do so, subject to the following conditions: |
// 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 ABOVE COPYRIGHT NOTICE AND THIS PERMISSION NOTICE SHALL BE INCLUDED IN |
// |
// ALL COPIES OR SUBSTANTIAL PORTIONS OF THE SOFTWARE. THE SOFTWARE IS PROVIDED |
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS |
// "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT |
// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF |
// LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR |
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. |
// PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT |
// IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY |
// HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN |
// CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, |
// ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION |
// TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE |
// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. |
// SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. |
// | // |
//============================================================================== |
////////////////////////////////////////////////////////////////////////// |
// |
|
// Author: Mike Brasher (mbrasher@bmc.com) |
|
// |
|
// Modified By: Roger Kumpf, Hewlett-Packard Company (roger_kumpf@hp.com) |
|
// | // |
//%///////////////////////////////////////////////////////////////////////////// | //%///////////////////////////////////////////////////////////////////////////// |
| |
|
#include "CIMPropertyListRep.h" |
#include "CIMPropertyList.h" | #include "CIMPropertyList.h" |
|
#include "OrderedSet.h" |
| |
PEGASUS_NAMESPACE_BEGIN | PEGASUS_NAMESPACE_BEGIN |
| |
class CIMPropertyListRep |
template<class REP> |
|
inline void Ref(REP* rep) |
{ | { |
public: |
rep->_refCounter++; |
Array<CIMName> propertyNames; |
} |
Boolean isNull; |
|
}; |
|
| |
|
template<class REP> |
|
inline void Unref(REP* rep) |
|
{ |
|
if (rep->_refCounter.decAndTestIfZero()) |
|
delete rep; |
|
} |
| |
CIMPropertyList::CIMPropertyList() | CIMPropertyList::CIMPropertyList() |
{ | { |
_rep = new CIMPropertyListRep(); | _rep = new CIMPropertyListRep(); |
_rep->isNull = true; |
|
} | } |
| |
CIMPropertyList::CIMPropertyList(const CIMPropertyList& x) | CIMPropertyList::CIMPropertyList(const CIMPropertyList& x) |
{ | { |
_rep = new CIMPropertyListRep(); |
_rep = x._rep; |
_rep->propertyNames = x._rep->propertyNames; |
Ref(_rep); |
_rep->isNull = x._rep->isNull; |
|
} | } |
| |
CIMPropertyList::CIMPropertyList(const Array<CIMName>& propertyNames) |
static inline CIMPropertyListRep* _copyOnWriteCIMPropertyListRep( |
|
CIMPropertyListRep* rep) |
{ | { |
_rep = new CIMPropertyListRep(); |
if (rep->_refCounter.get() > 1) |
|
{ |
|
CIMPropertyListRep* tmpRep= new CIMPropertyListRep(*rep); |
|
Unref(rep); |
|
return tmpRep; |
|
} |
|
else |
|
{ |
|
return rep; |
|
} |
|
} |
| |
|
CIMPropertyList::CIMPropertyList(const Array<CIMName>& propertyNames) |
|
{ |
// ATTN: the following code is inefficient and problematic. besides | // ATTN: the following code is inefficient and problematic. besides |
// adding overhead to check for null property names, it has the | // adding overhead to check for null property names, it has the |
// disadvantage of returning an error if only 1 of n properties are null | // disadvantage of returning an error if only 1 of n properties are null |
|
|
throw UninitializedObjectException(); | throw UninitializedObjectException(); |
} | } |
} | } |
|
_rep = new CIMPropertyListRep(); |
_rep->propertyNames = propertyNames; | _rep->propertyNames = propertyNames; |
_rep->isNull = false; | _rep->isNull = false; |
} | } |
| |
CIMPropertyList::~CIMPropertyList() | CIMPropertyList::~CIMPropertyList() |
{ | { |
delete _rep; |
Unref(_rep); |
} | } |
| |
void CIMPropertyList::set(const Array<CIMName>& propertyNames) | void CIMPropertyList::set(const Array<CIMName>& propertyNames) |
|
|
throw UninitializedObjectException(); | throw UninitializedObjectException(); |
} | } |
} | } |
|
_rep = _copyOnWriteCIMPropertyListRep(_rep); |
| |
_rep->propertyNames = propertyNames; | _rep->propertyNames = propertyNames; |
|
_rep->cimNameTags.clear(); |
_rep->isNull = false; | _rep->isNull = false; |
|
_rep->isCimNameTagsUpdated = false; |
} | } |
| |
CIMPropertyList& CIMPropertyList::operator=(const CIMPropertyList& x) | CIMPropertyList& CIMPropertyList::operator=(const CIMPropertyList& x) |
{ | { |
if (&x != this) |
if (x._rep != _rep) |
{ | { |
_rep->propertyNames = x._rep->propertyNames; |
Unref(_rep); |
_rep->isNull = x._rep->isNull; |
_rep = x._rep; |
|
Ref(_rep); |
} | } |
|
|
return *this; | return *this; |
} | } |
| |
void CIMPropertyList::clear() | void CIMPropertyList::clear() |
{ | { |
|
// If there is more than one reference |
|
// remove reference and get a new shiny empty representation |
|
if (_rep->_refCounter.get() > 1) |
|
{ |
|
Unref(_rep); |
|
_rep = new CIMPropertyListRep(); |
|
} |
|
else |
|
{ |
|
// If there is only one reference |
|
// no need to copy the data, we own it |
|
// just clear the fields |
_rep->propertyNames.clear(); | _rep->propertyNames.clear(); |
_rep->isNull = true; | _rep->isNull = true; |
|
if(_rep->isCimNameTagsUpdated) |
|
{ |
|
_rep->cimNameTags.clear(); |
|
_rep->isCimNameTagsUpdated = false; |
|
} |
|
} |
} | } |
| |
Boolean CIMPropertyList::isNull() const | Boolean CIMPropertyList::isNull() const |
|
|
return _rep->propertyNames; | return _rep->propertyNames; |
} | } |
| |
|
Uint32 CIMPropertyList::getCIMNameTag(Uint32 index) const |
|
{ |
|
return _rep->cimNameTags[index]; |
|
} |
|
void CIMPropertyList::append(Array<String> & propertyListArray) |
|
{ |
|
_rep = _copyOnWriteCIMPropertyListRep(_rep); |
|
Array<Uint32> cimNameTags; |
|
Array<CIMName> cimNameArray; |
|
for (Uint32 i = 0; i < propertyListArray.size(); i++) |
|
{ |
|
CIMName name(propertyListArray[i]); |
|
Uint32 tag = generateCIMNameTag(name); |
|
Boolean dupFound=false; |
|
for(Uint32 j=0;j<cimNameTags.size();j++) |
|
{ |
|
if ((tag == cimNameTags[j]) && (name == cimNameArray[j])) |
|
{ |
|
dupFound = true; |
|
break; |
|
} |
|
} |
|
if(!dupFound) |
|
{ |
|
cimNameTags.append(tag); |
|
cimNameArray.append(name); |
|
} |
|
} |
|
if(cimNameTags.size() != 0 ) |
|
{ |
|
_rep->cimNameTags.appendArray(cimNameTags); |
|
_rep->propertyNames = cimNameArray; |
|
_rep->isCimNameTagsUpdated = true; |
|
} |
|
_rep->isNull = false; |
|
} |
|
|
|
void CIMPropertyList::appendCIMNameTag(Uint32 nameTag) |
|
{ |
|
_rep = _copyOnWriteCIMPropertyListRep(_rep); |
|
_rep->cimNameTags.append(nameTag); |
|
} |
|
|
|
String CIMPropertyList::toString() const |
|
{ |
|
if (_rep->isNull) |
|
{ |
|
return("NULL"); |
|
} |
|
|
|
if (_rep->propertyNames.size() == 0) |
|
{ |
|
return("EMPTY"); |
|
} |
|
|
|
String rtn(_rep->propertyNames[0].getString()); |
|
for (Uint32 i = 1 ; i < _rep->propertyNames.size() ; i++) |
|
{ |
|
rtn.append(", "); |
|
rtn.append(_rep->propertyNames[i].getString()); |
|
} |
|
return(rtn); |
|
} |
|
|
PEGASUS_NAMESPACE_END | PEGASUS_NAMESPACE_END |