version 1.2, 2009/12/15 11:39:34
|
version 1.4.2.1, 2012/05/25 13:04:22
|
|
|
*/ | */ |
void buildKeyBindingsFromProperties(); | void buildKeyBindingsFromProperties(); |
| |
/** |
//This function is not implemented and now Property filtering is done by |
* Set/replace a property filter on an instance. |
//the CIMOM infrastructure |
* The filter is a white list of property names. |
|
* A property part of the list can be accessed by name or index and |
|
* is eligible to be returned to requester. |
|
* Key properties can not be filtered. They are always a part of the |
|
* instance. If a key property is not part of the property list, |
|
* it will not be filtered out. |
|
* @param propertyList Is an NULL terminated array of char* to |
|
* property names |
|
*/ |
|
void setPropertyFilter(const char **propertyList); | void setPropertyFilter(const char **propertyList); |
| |
/** | /** |
|
|
void setHostName(const char* hostName); | void setHostName(const char* hostName); |
| |
/** | /** |
* Sets the provided host name unchecked at the instance. |
|
* @param hostName The host name as UTF8. |
|
* @param len The strlen of the host name. |
|
*/ |
|
void setHostName_l(const char* hostName, Uint32 len); |
|
|
|
/** |
|
* Get the host name of the instance. The caller has to make a copy ! | * Get the host name of the instance. The caller has to make a copy ! |
* @return The host name as UTF8. | * @return The host name as UTF8. |
*/ | */ |
|
|
const char* getNameSpace_l(Uint32 & length) const; | const char* getNameSpace_l(Uint32 & length) const; |
| |
/** | /** |
|
* If hostname or namespace of the SCMOInstance are NULL or empty string, |
|
* replace them with the given input. |
|
* @param hn The host name to apply to the SCMOInstance. |
|
* @param hnLen The length of the hostname in byte without closing zero. |
|
* @param ns The namespace name to apply to the SCMOInstance. |
|
* @param nsLen The length of the hostname in byte without closing zero. |
|
*/ |
|
void completeHostNameAndNamespace( |
|
const char* hn, |
|
Uint32 hnLen, |
|
const char* ns, |
|
Uint32 nsLen); |
|
|
|
/** |
* Is the name space or class name of the instance the origianl values | * Is the name space or class name of the instance the origianl values |
* set by the used SCMOClass. | * set by the used SCMOClass. |
* The class name and/or name space may differ with the associated class. | * The class name and/or name space may differ with the associated class. |
|
|
if ( 1 < inst.hdr->refCount.get() ) | if ( 1 < inst.hdr->refCount.get() ) |
{ | { |
SCMBInstance_Main * oldRef = inst.hdr; | SCMBInstance_Main * oldRef = inst.hdr; |
|
SCMBMgmt_Header* oldMgmt = inst.mem; |
|
|
_clone(); | _clone(); |
if (oldRef->refCount.decAndTestIfZero()) | if (oldRef->refCount.decAndTestIfZero()) |
{ | { |
// All external references has to be destroyed. | // All external references has to be destroyed. |
_destroyExternalReferencesInternal((SCMBMgmt_Header*)oldRef); |
_destroyExternalReferencesInternal(oldMgmt); |
// The class has also be dereferenced. | // The class has also be dereferenced. |
delete oldRef->theClass.ptr; | delete oldRef->theClass.ptr; |
free((void*)oldRef); | free((void*)oldRef); |
|
|
const char ** valueBase, | const char ** valueBase, |
SCMBClassProperty ** propDef) const | SCMBClassProperty ** propDef) const |
{ | { |
Uint32 node; |
|
// is filtering on ? |
|
if (inst.hdr->flags.isFiltered) |
|
{ |
|
// Get absolut pointer to property filter index map of the instance |
|
Uint32* propertyFilterIndexMap = |
|
(Uint32*)&(inst.base[inst.hdr->propertyFilterIndexMap.start]); |
|
// get the real node index of the property. |
|
node = propertyFilterIndexMap[pos]; |
|
} |
|
else |
|
{ |
|
// the index is used as node index. |
|
node = pos; |
|
} |
|
|
|
SCMBValue* theInstPropNodeArray = | SCMBValue* theInstPropNodeArray = |
(SCMBValue*)&(inst.base[inst.hdr->propertyArray.start]); | (SCMBValue*)&(inst.base[inst.hdr->propertyArray.start]); |
| |
|
|
(SCMBClassPropertyNode*)&(inst.hdr->theClass.ptr->cls.base)[idx]; | (SCMBClassPropertyNode*)&(inst.hdr->theClass.ptr->cls.base)[idx]; |
| |
// return the absolute pointer to the property definition | // return the absolute pointer to the property definition |
*propDef= &(theClassPropNodeArray[node].theProperty); |
*propDef= &(theClassPropNodeArray[pos].theProperty); |
| |
// need check if property set or not, if not set use the default value | // need check if property set or not, if not set use the default value |
if (theInstPropNodeArray[node].flags.isSet) |
if (theInstPropNodeArray[pos].flags.isSet) |
{ | { |
// return the absolute pointer to the property value in the instance | // return the absolute pointer to the property value in the instance |
*value = &(theInstPropNodeArray[node]); |
*value = &(theInstPropNodeArray[pos]); |
*valueBase = inst.base; | *valueBase = inst.base; |
} | } |
else | else |
{ | { |
// return the absolute pointer to | // return the absolute pointer to |
*value = &(theClassPropNodeArray[node].theProperty.defaultValue); |
*value = &(theClassPropNodeArray[pos].theProperty.defaultValue); |
*valueBase = inst.hdr->theClass.ptr->cls.base; | *valueBase = inst.hdr->theClass.ptr->cls.base; |
} | } |
} | } |