(file) Return to CIMClassRep.cpp CVS log (file) (dir) Up to [Pegasus] / pegasus / src / Pegasus / Common

Diff for /pegasus/src/Pegasus/Common/CIMClassRep.cpp between version 1.28 and 1.90

version 1.28, 2002/03/24 13:33:07 version 1.90, 2008/12/01 17:49:47
Line 1 
Line 1 
 //%/////////////////////////////////////////////////////////////////////////////  //%LICENSE////////////////////////////////////////////////////////////////
 //  
 // Copyright (c) 2000, 2001 The Open group, BMC Software, Tivoli Systems, IBM  
 // //
 // Permission is hereby granted, free of charge, to any person obtaining a copy  // Licensed to The Open Group (TOG) under one or more contributor license
 // of this software and associated documentation files (the "Software"), to  // agreements.  Refer to the OpenPegasusNOTICE.txt file distributed with
 // deal in the Software without restriction, including without limitation the  // this work for additional information regarding copyright ownership.
 // rights to use, copy, modify, merge, publish, distribute, sublicense, and/or  // Each contributor licenses this file to you under the OpenPegasus Open
 // sell copies of the Software, and to permit persons to whom the Software is  // Source License; you may not use this file except in compliance with the
 // furnished to do so, subject to the following conditions:  // License.
 // //
 // THE ABOVE COPYRIGHT NOTICE AND THIS PERMISSION NOTICE SHALL BE INCLUDED IN  // Permission is hereby granted, free of charge, to any person obtaining a
 // ALL COPIES OR SUBSTANTIAL PORTIONS OF THE SOFTWARE. THE SOFTWARE IS PROVIDED  // copy of this software and associated documentation files (the "Software"),
 // "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT  // to deal in the Software without restriction, including without limitation
 // LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR  // the rights to use, copy, modify, merge, publish, distribute, sublicense,
 // PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT  // and/or sell copies of the Software, and to permit persons to whom the
 // HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN  // Software is furnished to do so, subject to the following conditions:
 // 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.  
 // //
 //==============================================================================  // The above copyright notice and this permission notice shall be included
   // in all copies or substantial portions of the Software.
 // //
 // Author: Mike Brasher (mbrasher@bmc.com)  // 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.
 // //
 // Modified By:  //////////////////////////////////////////////////////////////////////////
 // //
 //%///////////////////////////////////////////////////////////////////////////// //%/////////////////////////////////////////////////////////////////////////////
  
 #include "CIMClass.h"  #include "CIMClassRep.h"
 #include "DeclContext.h" #include "DeclContext.h"
 #include "Indentor.h"  #include "Resolver.h"
 #include "CIMName.h" #include "CIMName.h"
 #include "CIMQualifierNames.h" #include "CIMQualifierNames.h"
 #include "XmlWriter.h"  #include "CIMScope.h"
   #include <Pegasus/Common/Tracer.h>
   #include <Pegasus/Common/MessageLoader.h>
   #include "StrLit.h"
   #include "CIMInstanceRep.h"
   #include "CIMPropertyInternal.h"
   #include "CIMMethodRep.h"
  
 PEGASUS_NAMESPACE_BEGIN PEGASUS_NAMESPACE_BEGIN
   PEGASUS_USING_STD;
  
 CIMClassRep::CIMClassRep( CIMClassRep::CIMClassRep(
     const CIMReference& reference,      const CIMName& className,
     const String& superClassName)      const CIMName& superClassName)
     :     :
     CIMObjectRep(reference),      CIMObjectRep(CIMObjectPath(String(), CIMNamespaceName(), className)),
     _superClassName(superClassName)     _superClassName(superClassName)
 { {
     if (superClassName.size() && !CIMName::legal(superClassName))  
         throw IllegalName();  
 } }
  
 CIMClassRep::~CIMClassRep() CIMClassRep::~CIMClassRep()
 { {
   
 } }
  
 Boolean CIMClassRep::isAssociation() const Boolean CIMClassRep::isAssociation() const
 { {
     Uint32 pos = findQualifier(CIMQualifierNames::ASSOCIATION);      Uint32 index = findQualifier(CIMQualifierNames::ASSOCIATION);
  
     if (pos == PEG_NOT_FOUND)      if (index == PEG_NOT_FOUND)
         return false;         return false;
  
     Boolean flag;     Boolean flag;
  
     const CIMValue& value = getQualifier(pos).getValue();      const CIMValue& value = getQualifier(index).getValue();
  
     if (value.getType() != CIMType::BOOLEAN)      if (value.getType() != CIMTYPE_BOOLEAN)
         return false;         return false;
  
     value.get(flag);     value.get(flag);
Line 71 
Line 78 
  
 Boolean CIMClassRep::isAbstract() const Boolean CIMClassRep::isAbstract() const
 { {
     Uint32 pos = findQualifier(CIMQualifierNames::ABSTRACT);      Uint32 index = findQualifier(CIMQualifierNames::ABSTRACT);
  
     if (pos == PEG_NOT_FOUND)      if (index == PEG_NOT_FOUND)
         return false;         return false;
  
     Boolean flag;     Boolean flag;
     const CIMValue& value = getQualifier(pos).getValue();      const CIMValue& value = getQualifier(index).getValue();
  
     if (value.getType() != CIMType::BOOLEAN)      if (value.getType() != CIMTYPE_BOOLEAN)
         return false;         return false;
  
     value.get(flag);     value.get(flag);
     return flag;     return flag;
 } }
  
 void CIMClassRep::setSuperClassName(const String& superClassName)  
 {  
     if (!CIMName::legal(superClassName))  
         throw IllegalName();  
   
     _superClassName = superClassName;  
 }  
   
 void CIMClassRep::addProperty(const CIMProperty& x) void CIMClassRep::addProperty(const CIMProperty& x)
 { {
     if (!x)      if (x.isUninitialized())
         throw UnitializedHandle();          throw UninitializedObjectException();
  
     // Reject addition of duplicate property name:     // Reject addition of duplicate property name:
  
     if (findProperty(x.getName()) != PEG_NOT_FOUND)     if (findProperty(x.getName()) != PEG_NOT_FOUND)
         throw AlreadyExists();      {
           MessageLoaderParms parms(
     // Reject addition of references to non-associations:              "Common.CIMClassRep.PROPERTY",
               "property \"$0\"",
     if (!isAssociation() && x.getValue().getType() == CIMType::REFERENCE)              x.getName().getString());
         throw AddedReferenceToClass(_reference.getClassName());          throw AlreadyExistsException(parms);
       }
  
     // Set the class origin:      // Reject addition of a reference property without a referenceClassName
     // ATTN: put this check in other places:  
  
     if (x.getClassOrigin().size() == 0)      if ((x.getType() == CIMTYPE_REFERENCE) &&
         CIMProperty(x).setClassOrigin(_reference.getClassName());          (x.getReferenceClassName().isNull()))
       {
           throw TypeMismatchException();
       }
  
     // Add the property:     // Add the property:
  
Line 122 
Line 124 
  
 void CIMClassRep::addMethod(const CIMMethod& x) void CIMClassRep::addMethod(const CIMMethod& x)
 { {
     if (!x)      if (x.isUninitialized())
         throw UnitializedHandle();          throw UninitializedObjectException();
  
     // Reject duplicate method names:     // Reject duplicate method names:
  
     if (findMethod(x.getName()) != PEG_NOT_FOUND)     if (findMethod(x.getName()) != PEG_NOT_FOUND)
         throw AlreadyExists();  
   
     // Add the method:  
   
     _methods.append(x);  
 }  
   
 Uint32 CIMClassRep::findMethod(const String& name)  
 { {
     for (Uint32 i = 0, n = _methods.size(); i < n; i++)          MessageLoaderParms parms(
     {              "Common.CIMClassRep.METHOD",
         if (CIMName::equal(_methods[i].getName(), name))              "method \"$0\"",
             return i;              x.getName().getString());
     }          throw AlreadyExistsException(parms);
   
     return PEG_NOT_FOUND;  
 }  
   
 Boolean CIMClassRep::existsMethod(const String& name)  
 {  
     return(findMethod(name) == PEG_NOT_FOUND) ? false : true;  
 }  
   
 CIMMethod CIMClassRep::getMethod(Uint32 pos)  
 {  
     if (pos >= _methods.size())  
         throw OutOfBounds();  
   
     return _methods[pos];  
 } }
  
 Uint32 CIMClassRep::getMethodCount() const      // Add the method:
 {  
     return _methods.size();  
 }  
   
 void CIMClassRep::removeMethod(Uint32 pos)  
 {  
     if (pos >= _methods.size())  
         throw OutOfBounds();  
  
     _methods.remove(pos);      _methods.append(x);
 } }
  
 void CIMClassRep::resolve( void CIMClassRep::resolve(
     DeclContext* context,     DeclContext* context,
     const String& nameSpace)      const CIMNamespaceName& nameSpace)
 { {
 #if 0      PEG_METHOD_ENTER(TRC_OBJECTRESOLUTION, "CIMClassRep::resolve()");
     if (_resolved)  
         throw ClassAlreadyResolved(_reference.getClassName());  
 #endif  
     if (!context)     if (!context)
         throw NullPointer();         throw NullPointer();
  
     if (_superClassName.size())      PEG_TRACE((TRC_OBJECTRESOLUTION, Tracer::LEVEL4,
           "CIMClassRep::resolve  class = %s, superclass = %s",
           (const char*)_reference.getClassName().getString().getCString(),
           (const char*)_superClassName.getString().getCString()));
   
       if (!_superClassName.isNull())
     {     {
         //----------------------------------------------------------------------         //----------------------------------------------------------------------
         // First check to see if the super-class really exists:          // First check to see if the super-class really exists and the
           // subclassing legal:
         //----------------------------------------------------------------------         //----------------------------------------------------------------------
         CIMConstClass superClass          CIMConstClass superClass =
             = context->lookupClass(nameSpace, _superClassName);              context->lookupClass(nameSpace, _superClassName);
  
         if (!superClass)          if (superClass.isUninitialized())
             throw PEGASUS_CIM_EXCEPTION(CIM_ERR_INVALID_SUPERCLASS,_superClassName);              throw PEGASUS_CIM_EXCEPTION(CIM_ERR_INVALID_SUPERCLASS,
                   _superClassName.getString());
  
 #if 0          // If subclass is abstract but superclass not, throw CIM Exception
         if (!superClass._rep->_resolved)  
             throw ClassNotResolved(_superClassName);  
 #endif  
  
           /* ATTN:KS-24 Mar 2002 P1 - Test this and confirm that rule is correct
           if isAbstract() && !superclass.isAbstract()
               throw PEGASUS_CIM_EXCEPTION(
                   CIM_ERR_INVALID_SUPERCLASS, _superClassName);
           */
           /*if (superclass.isTrueQualifier(CIMQualifierNames::TERMINAL)
               throw PEGASUS_CIM_EXCEPTION(
                   CIM_ERR_INVALID_SUPERCLASS, _superClassName);
           */
         //----------------------------------------------------------------------         //----------------------------------------------------------------------
         // Iterate all the properties of *this* class. Resolve each one and         // Iterate all the properties of *this* class. Resolve each one and
         // set the class-origin:         // set the class-origin:
         //----------------------------------------------------------------------         //----------------------------------------------------------------------
  
           Boolean isAssociationClass = isAssociation();
   
         for (Uint32 i = 0, n = _properties.size(); i < n; i++)         for (Uint32 i = 0, n = _properties.size(); i < n; i++)
         {         {
             CIMProperty& property = _properties[i];             CIMProperty& property = _properties[i];
             Uint32 pos = superClass.findProperty(property.getName());  
  
             if (pos == PEG_NOT_FOUND)              if (!isAssociationClass &&
                   property.getValue().getType() == CIMTYPE_REFERENCE)
             {             {
                         property.resolve(context, nameSpace, false, true);                  throw PEGASUS_CIM_EXCEPTION_L(CIM_ERR_INVALID_PARAMETER,
                       MessageLoaderParms(
                           "Common.CIMClassRep.NON_ASSOCIATION_CLASS_CONTAINS_"
                               "REFERENCE_PROPERTY",
                           "Non-assocation class contains reference property"));
               }
   
   
               Uint32 index = superClass.findProperty(property.getName());
   
               if (index == PEG_NOT_FOUND)
               {
                   Resolver::resolveProperty(
                       property, context, nameSpace, false, true);
                   if (property.getClassOrigin().isNull())
                   {
                       property.setClassOrigin(getClassName());
                   }
                   property.setPropagated(false);
             }             }
             else             else
             {             {
                         CIMConstProperty superClassProperty =                         CIMConstProperty superClassProperty =
                         superClass.getProperty(pos);                      superClass.getProperty(index);
                         property.resolve(                  Resolver::resolveProperty(property, context,
                                 context, nameSpace, false, superClassProperty, true);                      nameSpace, false, superClassProperty, true);
                   if (property.getClassOrigin().isNull())
                   {
                       property.setClassOrigin(
                           superClassProperty.getClassOrigin());
                   }
             }             }
         }         }
  
Line 237 
Line 244 
             // insert it (setting the propagated flag). Otherwise, change             // insert it (setting the propagated flag). Otherwise, change
             // the class-origin and propagated flag accordingly.             // the class-origin and propagated flag accordingly.
  
             Uint32 pos = PEG_NOT_FOUND;              Uint32 index = findProperty(superClassProperty.getName());
                 /*       ATTN: KS move to simpler  
             for (Uint32 j = m, n = _properties.size(); j < n; j++)  
             {  
                         if (CIMName::equal(_properties[j].getName(),  
                                                            superClassProperty.getName()))  
                         {  
                                 pos = j;  
                                 break;  
                         }  
             }  
                 */  
                 pos = findProperty(superClassProperty.getName());  
  
             // If property exists in super class but not in this one, then             // If property exists in super class but not in this one, then
             // clone and insert it. Otherwise, the properties class             // clone and insert it. Otherwise, the properties class
             // origin was set above.             // origin was set above.
  
             CIMProperty superproperty = superClassProperty.clone(true);              CIMProperty superproperty = superClassProperty.clone();
  
             if (pos == PEG_NOT_FOUND)              if (index == PEG_NOT_FOUND)
             {             {
                         superproperty.setPropagated(true);                         superproperty.setPropagated(true);
                         _properties.insert(m++, superproperty);                         _properties.insert(m++, superproperty);
             }             }
                 else                 else
                 {                 {
                   // Property Qualifiers must propagate if allowed
                 // If property exists in the superclass and in the subclass,                 // If property exists in the superclass and in the subclass,
                 // then, enumerate the qualifiers of the superclass's property.                 // then, enumerate the qualifiers of the superclass's property.
                 // If a qualifier is defined on the superclass's property                 // If a qualifier is defined on the superclass's property
                 // but not on the subclass's, then add it to the subclass's                 // but not on the subclass's, then add it to the subclass's
                 // property's qualifier list.                 // property's qualifier list.
                 CIMProperty subproperty = _properties[pos];                  CIMProperty subproperty = _properties[index];
                 for (Uint32 i = 0, n = superproperty.getQualifierCount();                  for (Uint32 j = 0, qc = superproperty.getQualifierCount();
                                 i < n; i++)                       j < qc; j++)
                         {                         {
                                 Uint32 pos = PEG_NOT_FOUND;  
                                 CIMQualifier superClassQualifier =                                 CIMQualifier superClassQualifier =
                                                                                 superproperty.getQualifier(i);                          superproperty.getQualifier(j);
                                 const String name = superClassQualifier.getName();                      const CIMName name = superClassQualifier.getName();
                                 for (Uint32 j = 0, m = subproperty.getQualifierCount();                      if (subproperty.findQualifier(name) == PEG_NOT_FOUND)
                                          j < m;  
                                          j++)  
                                 {  
                                         CIMConstQualifier q = subproperty.getQualifier(j);  
                                         if (CIMName::equal(name,  
                                                    q.getName()))  
                                         {  
                                                 pos = j;  
                                                 break;  
                                         }  
                                 }  // end comparison of subclass property's qualifiers  
                                 if (pos == PEG_NOT_FOUND)  
                                 {                                 {
                                         subproperty.addQualifier(superClassQualifier);                                         subproperty.addQualifier(superClassQualifier);
                                 }                                 }
                                 /*  
                                 if ((pos = subproperty.findQualifier(name)) == PEG_NOT_FOUND)  
                                 {  
                                         subproperty.addQualifier(superClassQualifier);  
                                 }  
                                 */  
                         } // end iteration over superclass property's qualifiers                         } // end iteration over superclass property's qualifiers
             }             }
         }         }
Line 311 
Line 288 
         for (Uint32 i = 0, n = _methods.size(); i < n; i++)         for (Uint32 i = 0, n = _methods.size(); i < n; i++)
         {         {
             CIMMethod& method = _methods[i];             CIMMethod& method = _methods[i];
             Uint32 pos = superClass.findMethod(method.getName());              Uint32 index = superClass.findMethod(method.getName());
  
             if (pos == PEG_NOT_FOUND)              if (index == PEG_NOT_FOUND)
             {             {
                         method.resolve(context, nameSpace);                  Resolver::resolveMethod(method, context, nameSpace);
                   if (method.getClassOrigin().isNull())
                   {
                       method.setClassOrigin(getClassName());
                   }
                   method.setPropagated(false);
             }             }
             else             else
             {             {
                         CIMConstMethod superClassMethod = superClass.getMethod(pos);                  CIMConstMethod superClassMethod = superClass.getMethod(index);
                         method.resolve(context, nameSpace, superClassMethod);                  Resolver::resolveMethod(
                       method, context, nameSpace, superClassMethod);
             }             }
         }         }
  
Line 337 
Line 320 
             // insert it (setting the propagated flag). Otherwise, change             // insert it (setting the propagated flag). Otherwise, change
             // the class-origin and propagated flag accordingly.             // the class-origin and propagated flag accordingly.
  
             Uint32 pos = PEG_NOT_FOUND;              Uint32 index = PEG_NOT_FOUND;
                 /**********************              /**********************     KS move to simpler version
             for (Uint32 j = m, n = _methods.size(); j < n; j++)             for (Uint32 j = m, n = _methods.size(); j < n; j++)
             {             {
                         if (CIMName::equal(_methods[j].getName(),                  if (_methods[j].getName() == superClassMethod.getName())
                                                                 superClassMethod.getName()))  
                         {                         {
                                 pos = j;                      index = j;
                                 break;                                 break;
                         }                         }
             }             }
Line 353 
Line 335 
             // clone and insert it. Otherwise, the method's class origin             // clone and insert it. Otherwise, the method's class origin
             // has already been set above.             // has already been set above.
  
             if (pos == PEG_NOT_FOUND)              if (index == PEG_NOT_FOUND)
             {             {
                         CIMMethod method = superClassMethod.clone();                         CIMMethod method = superClassMethod.clone();
                         method.setPropagated(true);                         method.setPropagated(true);
                         _methods.insert(m++, method);                         _methods.insert(m++, method);
             }             }
                 */                 */
                 if((pos = findMethod(superClassMethod.getName())) == PEG_NOT_FOUND)              if ((index = findMethod(superClassMethod.getName())) ==
                   PEG_NOT_FOUND)
                 {                 {
                         CIMMethod method = superClassMethod.clone();                         CIMMethod method = superClassMethod.clone();
                         method.setPropagated(true);                         method.setPropagated(true);
Line 372 
Line 355 
         //----------------------------------------------------------------------         //----------------------------------------------------------------------
         // Validate the qualifiers of this class:         // Validate the qualifiers of this class:
         //----------------------------------------------------------------------         //----------------------------------------------------------------------
   
         _qualifiers.resolve(         _qualifiers.resolve(
             context,             context,
             nameSpace,             nameSpace,
Line 381 
Line 363 
             superClass._rep->_qualifiers,             superClass._rep->_qualifiers,
             true);             true);
     }     }
     else      else     // No SuperClass exsts
     {     {
                 //----------------------------------------------------------------------                 //----------------------------------------------------------------------
                 // Resolve each property:                 // Resolve each property:
                 //----------------------------------------------------------------------                 //----------------------------------------------------------------------
  
                 for (Uint32 i = 0, n = _properties.size(); i < n; i++)                 for (Uint32 i = 0, n = _properties.size(); i < n; i++)
                         _properties[i].resolve(context, nameSpace, false, true);          {
                Resolver::resolveProperty(
                    _properties[i], context, nameSpace, false, true);
                _properties[i].setClassOrigin(getClassName());
                _properties[i].setPropagated(false);
           }
  
                 //----------------------------------------------------------------------                 //----------------------------------------------------------------------
                 // Resolve each method:                 // Resolve each method:
                 //----------------------------------------------------------------------                 //----------------------------------------------------------------------
  
                 for (Uint32 i = 0, n = _methods.size(); i < n; i++)                 for (Uint32 i = 0, n = _methods.size(); i < n; i++)
                         _methods[i].resolve(context, nameSpace);          {
               Resolver::resolveMethod (_methods[i], context, nameSpace);
               _methods[i].setClassOrigin(getClassName());
               _methods[i].setPropagated(false);
           }
  
                 //----------------------------------------------------------------------                 //----------------------------------------------------------------------
                 // Resolve the qualifiers:                 // Resolve the qualifiers:
Line 411 
Line 402 
                         dummy,                         dummy,
                         true);                         true);
     }     }
   
     // _resolved = true;  
 } }
  
 void CIMClassRep::toXml(Array<Sint8>& out) const  CIMInstance CIMClassRep::buildInstance(Boolean includeQualifiers,
       Boolean includeClassOrigin,
       const CIMPropertyList& propertyList) const
 { {
     // Class opening element:  
   
     out << "<CLASS ";  
     out << " NAME=\"" << _reference.getClassName() << "\" ";  
   
     if (_superClassName.size())  
         out << " SUPERCLASS=\"" << _superClassName << "\" ";  
  
     out << ">\n";      // Create the new instance representation
       CIMInstanceRep* newInstanceRep = new CIMInstanceRep(
           CIMObjectPath(String::EMPTY,
                         CIMNamespaceName(),
                         _reference.getClassName()));
  
     // Qualifiers:      // Copy qualifiers if required
       if (includeQualifiers)
     _qualifiers.toXml(out);      {
           for (Uint32 i = 0 ; i < getQualifierCount() ; i++)
     // Parameters:          {
               newInstanceRep->_qualifiers.add(getQualifier(i).clone());
     for (Uint32 i = 0, n = _properties.size(); i < n; i++)          }
         _properties[i].toXml(out);  
   
     // Methods:  
   
     for (Uint32 i = 0, n = _methods.size(); i < n; i++)  
         _methods[i].toXml(out);  
   
     // Class closing element:  
   
     out << "</CLASS>\n";  
 } }
 /** toMof prepares an 8-bit string with the MOF for the class.  
     The BNF for this is:  
     <pre>  
     classDeclaration    =    [ qualifierList ]  
                              CLASS className [ alias ] [ superClass ]  
                              "{" *classFeature "}" ";"  
   
     superClass          =    :" className  
   
     classFeature        =    propertyDeclaration | methodDeclaration  
  
 */      newInstanceRep->_properties.reserveCapacity(_properties.size());
  
 void CIMClassRep::toMof(Array<Sint8>& out) const      // Copy Properties
       for (Uint32 i = 0 ; i < _properties.size() ; i++)
 { {
     // Get and format the class qualifiers          CIMConstProperty cp = getProperty(i);
     out << "\n//    Class " << _reference.getClassName();          CIMName name = cp.getName();
     if (_qualifiers.getCount())          Array<CIMName> pl = propertyList.getPropertyNameArray();
         out << "\n";          if (propertyList.isNull() || Contains(pl, name))
     out << "\n";  
     _qualifiers.toMof(out);  
   
     // Separate qualifiers from Class Name  
     out << "\n";  
   
     // output class statement  
     out << "class " << _reference.getClassName();  
   
     if (_superClassName.size())  
         out << " : " << _superClassName;  
   
     out << "\n{";  
   
     // format the Properties:  
     for (Uint32 i = 0, n = _properties.size(); i < n; i++)  
     {     {
         // Generate MOF if this property not propogated              CIMProperty p;
         // Note that the test is required only because  
         // there is an error in getclass that does not  
         // test the localOnly flag.  
         if (!_properties[i].getPropagated())  
             _properties[i].toMof(out);  
     }  
  
     // Format the Methods:  for non-propagated methods              if (includeQualifiers)
     for (Uint32 i = 0, n = _methods.size(); i < n; i++)  
     {     {
         if (!_methods[i].getPropagated())                  p = getProperty(i).clone();
         _methods[i].toMof(out);  
     }     }
               else
     // Class closing element:  
     out << "\n};\n";  
 }  
   
 void CIMClassRep::print(PEGASUS_STD(ostream) &os) const  
 { {
     Array<Sint8> tmp;                  p = CIMProperty(cp.getName(),
     toXml(tmp);                                  cp.getValue(),
     tmp.append('\0');                                  cp.getArraySize(),
     XmlWriter::indentedPrint(os, tmp.getData(), 4);                                  cp.getReferenceClassName(),
     // cout << tmp.getData() << endl;                                  cp.getClassOrigin());
 } }
  
 void CIMClassRep::printMof(PEGASUS_STD(ostream) &os) const              // Delete class origin attribute if required
               if (!includeClassOrigin)
 { {
     Array<Sint8> tmp;                  p.setClassOrigin(CIMName());
     toMof(tmp);  
     tmp.append('\0');  
     os << tmp.getData() << PEGASUS_STD(endl);  
 } }
  
               newInstanceRep->_properties.append(p);
           }
       }
  
 CIMClassRep::CIMClassRep()      // Create new CIMInstance from CIMInstanceRep
 {      CIMInstance newInstance(newInstanceRep);
  
       return newInstance;
 } }
  
 CIMClassRep::CIMClassRep(const CIMClassRep& x) : CIMClassRep::CIMClassRep(const CIMClassRep& x) :
     CIMObjectRep(x),     CIMObjectRep(x),
     _superClassName(x._superClassName)     _superClassName(x._superClassName)
 { {
     _methods.reserve(x._methods.size());      _methods.reserveCapacity(x._methods.size());
  
     for (Uint32 i = 0, n = x._methods.size(); i < n; i++)     for (Uint32 i = 0, n = x._methods.size(); i < n; i++)
         _methods.append(x._methods[i].clone());         _methods.append(x._methods[i].clone());
 } }
  
 Boolean CIMClassRep::identical(const CIMClassRep* x) const  Boolean CIMClassRep::identical(const CIMObjectRep* x) const
 { {
     if (!CIMObjectRep::identical(x))     if (!CIMObjectRep::identical(x))
         return false;         return false;
  
     if (_superClassName != x->_superClassName)      const CIMClassRep* tmprep = dynamic_cast<const CIMClassRep*>(x);
       if (!tmprep)
           return false;
   
       // If the pointers are the same, the objects must be identical
       if (this == tmprep)
       {
           return true;
       }
   
       if (!_superClassName.equal (tmprep->_superClassName))
         return false;         return false;
  
     //     //
Line 546 
Line 498 
     //     //
  
     {     {
         const Array<CIMMethod>& tmp1 = _methods;          const MethodSet& tmp1 = _methods;
         const Array<CIMMethod>& tmp2 = x->_methods;          const MethodSet& tmp2 = tmprep->_methods;
  
         if (tmp1.size() != tmp2.size())         if (tmp1.size() != tmp2.size())
             return false;             return false;
Line 557 
Line 509 
             if (!tmp1[i].identical(tmp2[i]))             if (!tmp1[i].identical(tmp2[i]))
                 return false;                 return false;
  
             if (tmp1[i].getClassOrigin() != tmp2[i].getClassOrigin())              if (!tmp1[i].getClassOrigin().equal (tmp2[i].getClassOrigin()))
                 return false;                 return false;
  
             if (tmp1[i].getPropagated() != tmp2[i].getPropagated())             if (tmp1[i].getPropagated() != tmp2[i].getPropagated())
Line 565 
Line 517 
         }         }
     }     }
  
     if (_resolved != x->_resolved)  
         return false;  
   
     return true;     return true;
 } }
  
 void CIMClassRep::getKeyNames(Array<String>& keyNames) const  void CIMClassRep::getKeyNames(Array<CIMName>& keyNames) const
 { {
     keyNames.clear();     keyNames.clear();
  
Line 579 
Line 528 
     {     {
         CIMConstProperty property = getProperty(i);         CIMConstProperty property = getProperty(i);
  
         if (property.isKey())          if (CIMPropertyInternal::isKeyProperty(property))
           {
             keyNames.append(property.getName());             keyNames.append(property.getName());
     }     }
 } }
   }
  
 Boolean CIMClassRep::hasKeys() const Boolean CIMClassRep::hasKeys() const
 { {
     for (Uint32 i = 0, n = getPropertyCount(); i < n; i++)     for (Uint32 i = 0, n = getPropertyCount(); i < n; i++)
     {     {
         CIMConstProperty property = getProperty(i);         CIMConstProperty property = getProperty(i);
           if (CIMPropertyInternal::isKeyProperty(property))
         if (getProperty(i).isKey())          {
             return true;             return true;
     }     }
       }
     return false;     return false;
 } }
  


Legend:
Removed from v.1.28  
changed lines
  Added in v.1.90

No CVS admin address has been configured
Powered by
ViewCVS 0.9.2