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

Diff for /pegasus/src/Pegasus/Common/CIMQualifierRep.cpp between version 1.25 and 1.43

version 1.25, 2002/05/15 20:04:10 version 1.43, 2006/11/10 18:14:57
Line 1 
Line 1 
 //%/////////////////////////////////////////////////////////////////////////////  //%2006////////////////////////////////////////////////////////////////////////
 // //
 // Copyright (c) 2000, 2001 The Open group, BMC Software, Tivoli Systems, IBM  // Copyright (c) 2000, 2001, 2002 BMC Software; Hewlett-Packard Development
   // Company, L.P.; IBM Corp.; The Open Group; Tivoli Systems.
   // Copyright (c) 2003 BMC Software; Hewlett-Packard Development Company, L.P.;
   // IBM Corp.; EMC Corporation, The Open Group.
   // Copyright (c) 2004 BMC Software; Hewlett-Packard Development Company, L.P.;
   // IBM Corp.; EMC Corporation; VERITAS Software Corporation; The Open Group.
   // Copyright (c) 2005 Hewlett-Packard Development Company, L.P.; IBM Corp.;
   // EMC Corporation; VERITAS Software Corporation; The Open Group.
   // Copyright (c) 2006 Hewlett-Packard Development Company, L.P.; IBM Corp.;
   // EMC Corporation; Symantec Corporation; The Open Group.
 // //
 // Permission is hereby granted, free of charge, to any person obtaining a copy // Permission is hereby granted, free of charge, to any person obtaining a copy
 // of this software and associated documentation files (the "Software"), to // of this software and associated documentation files (the "Software"), to
Line 20 
Line 29 
 // //
 //============================================================================== //==============================================================================
 // //
 // Author: Mike Brasher (mbrasher@bmc.com)  
 //  
 // Modified By:  
 //  
 //%///////////////////////////////////////////////////////////////////////////// //%/////////////////////////////////////////////////////////////////////////////
  
 #include "CIMQualifier.h" #include "CIMQualifier.h"
 #include "CIMQualifierRep.h" #include "CIMQualifierRep.h"
 #include "Indentor.h" #include "Indentor.h"
 #include "CIMName.h" #include "CIMName.h"
 #include "Exception.h"  #include "InternalException.h"
 #include "XmlWriter.h" #include "XmlWriter.h"
 #include "MofWriter.h" #include "MofWriter.h"
   #include "StrLit.h"
  
 PEGASUS_NAMESPACE_BEGIN PEGASUS_NAMESPACE_BEGIN
 PEGASUS_USING_STD; PEGASUS_USING_STD;
Line 43 
Line 49 
 // //
 //////////////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////////////////
  
   CIMQualifierRep::CIMQualifierRep()
   {
   }
   
   CIMQualifierRep::CIMQualifierRep(const CIMQualifierRep& x) :
       Sharable(),
       _name(x._name),
       _value(x._value),
       _flavor(x._flavor),
       _propagated(x._propagated)
   {
   }
   
 CIMQualifierRep::CIMQualifierRep( CIMQualifierRep::CIMQualifierRep(
     const String& name,      const CIMName& name,
     const CIMValue& value,     const CIMValue& value,
     Uint32 flavor,      const CIMFlavor & flavor,
     Boolean propagated)     Boolean propagated)
     :     :
     _name(name),     _name(name),
Line 54 
Line 73 
     _flavor(flavor),     _flavor(flavor),
     _propagated(propagated)     _propagated(propagated)
 { {
     //cout << "KSTEST Qualifer create " << name << " Flavor " << flavor << endl;      // ensure name is not null
         if (!CIMName::legal(name))      if (name.isNull())
         throw IllegalName();      {
           throw UninitializedObjectException();
     if (_value.getType() == CIMType::NONE)      }
         throw NullType();  
 } }
  
 CIMQualifierRep::~CIMQualifierRep() CIMQualifierRep::~CIMQualifierRep()
 { {
   
 } }
  
 void CIMQualifierRep::setName(const String& name)  void CIMQualifierRep::setName(const CIMName& name)
   {
       // ensure name is not null
       if (name.isNull())
 { {
     if (!CIMName::legal(name))          throw UninitializedObjectException();
         throw IllegalName();      }
  
     _name = name;     _name = name;
 } }
  
 void CIMQualifierRep::resolveFlavor(Uint32 inheritedFlavor, Boolean inherited)  void CIMQualifierRep::resolveFlavor (
       const CIMFlavor & inheritedFlavor,
       Boolean inherited)
         {         {
                 // ATTN: KS P3 Needs more tests and expansion so we treate first different                 // ATTN: KS P3 Needs more tests and expansion so we treate first different
                 // from inheritance                 // from inheritance
  
                 // if the turnoff flags set, reset the functions.      // if the turnoff flags set, reset the flavor bits
                 if((inheritedFlavor & CIMFlavor::RESTRICTED) != 0) {      if (inheritedFlavor.hasFlavor (CIMFlavor::RESTRICTED))
                         unsetFlavor(CIMFlavor::TOSUBCLASS + CIMFlavor::TOINSTANCE);      {
           _flavor.removeFlavor (CIMFlavor::TOSUBCLASS);
           _flavor.removeFlavor (CIMFlavor::TOINSTANCE);
                 }                 }
                 if((inheritedFlavor & CIMFlavor::DISABLEOVERRIDE)) {      if (inheritedFlavor.hasFlavor (CIMFlavor::DISABLEOVERRIDE))
                         unsetFlavor(CIMFlavor::ENABLEOVERRIDE);      {
           _flavor.removeFlavor (CIMFlavor::ENABLEOVERRIDE);
                 }                 }
  
                 _flavor = inheritedFlavor | _flavor;      _flavor.addFlavor (inheritedFlavor);
         }         }
  
 static const char* _toString(Boolean x) static const char* _toString(Boolean x)
Line 96 
Line 121 
     return x ? "true" : "false";     return x ? "true" : "false";
 } }
  
 void CIMQualifierRep::toXml(Array<Sint8>& out) const  void CIMQualifierRep::toXml(Buffer& out) const
 { {
     out << "<QUALIFIER";      out << STRLIT("<QUALIFIER NAME=\"") << _name;
     out << " NAME=\"" << _name << "\"";      out.append('"');
     out << " TYPE=\"" << _value.getType().toString() << "\"";      out << STRLIT(" TYPE=\"") << cimTypeToString(_value.getType ());
       out.append('"');
  
     if (_propagated != false)     if (_propagated != false)
         out << " PROPAGATED=\"" << _toString(_propagated) << "\"";      {
           out << STRLIT(" PROPAGATED=\"") << _toString(_propagated);
           out.append('"');
       }
  
     XmlWriter::appendQualifierFlavorEntity(out, _flavor);     XmlWriter::appendQualifierFlavorEntity(out, _flavor);
  
     out << ">\n";      out << STRLIT(">\n");
  
     XmlWriter::appendValueElement(out, _value);     XmlWriter::appendValueElement(out, _value);
  
     out << "</QUALIFIER>\n";      out << STRLIT("</QUALIFIER>\n");
 } }
  
 /** toMof Generates MOF output for a qualifier. /** toMof Generates MOF output for a qualifier.
Line 124 
Line 153 
     arrayInitializer   = "{" constantValue*( "," constantValue)"}"     arrayInitializer   = "{" constantValue*( "," constantValue)"}"
     </pre>     </pre>
 */ */
 void CIMQualifierRep::toMof(Array<Sint8>& out) const  void CIMQualifierRep::toMof(Buffer& out) const
 { {
     // Output Qualifier name     // Output Qualifier name
     out << _name;     out << _name;
Line 139 
Line 168 
     Boolean hasValueField = false;     Boolean hasValueField = false;
     if (!_value.isNull())     if (!_value.isNull())
     {     {
            if (_value.getType() == CIMType::BOOLEAN)          if (_value.getType() == CIMTYPE_BOOLEAN)
            {            {
                     Boolean b;                     Boolean b;
                         _value.get(b);                         _value.get(b);
                     if(!b)                     if(!b)
                                 out << " (false)";                  out << STRLIT(" (false)");
            }            }
            else            else
            {            {
                    out << " (";              out << STRLIT(" (");
                    hasValueField = true;                    hasValueField = true;
                    MofWriter::appendValueElement(out, _value);                    MofWriter::appendValueElement(out, _value);
                    out << ")";              out.append(')');
            }            }
     }     }
  
Line 160 
Line 189 
     flavorString = MofWriter::getQualifierFlavor(_flavor);     flavorString = MofWriter::getQualifierFlavor(_flavor);
     if (flavorString.size())     if (flavorString.size())
     {     {
                 out << " : ";          out << STRLIT(" : ");
                 out << flavorString;                 out << flavorString;
     }     }
 } }
  
  
 CIMQualifierRep::CIMQualifierRep()  
 {  
   
 }  
   
 CIMQualifierRep::CIMQualifierRep(const CIMQualifierRep& x) :  
     Sharable(),  
     _name(x._name),  
     _value(x._value),  
     _flavor(x._flavor),  
     _propagated(x._propagated)  
 {  
   
 }  
   
 Boolean CIMQualifierRep::identical(const CIMQualifierRep* x) const Boolean CIMQualifierRep::identical(const CIMQualifierRep* x) const
 { {
     return     return
         this == x ||         this == x ||
         CIMName::equal(_name, x->_name) &&          _name.equal(x->_name) &&
         _value == x->_value &&         _value == x->_value &&
         _flavor == x->_flavor &&          (_flavor.equal (x->_flavor)) &&
         _propagated == x->_propagated;         _propagated == x->_propagated;
 } }
  
 void CIMQualifierRep::setValue(const CIMValue& value) void CIMQualifierRep::setValue(const CIMValue& value)
 { {
     _value = value;     _value = value;
   
     if (_value.getType() == CIMType::NONE)  
         throw NullType();  
 } }
  
 PEGASUS_NAMESPACE_END PEGASUS_NAMESPACE_END


Legend:
Removed from v.1.25  
changed lines
  Added in v.1.43

No CVS admin address has been configured
Powered by
ViewCVS 0.9.2