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

Diff for /pegasus/src/Pegasus/Common/CIMMethodRep.cpp between version 1.3 and 1.23

version 1.3, 2001/03/04 21:57:34 version 1.23, 2002/05/15 12:28:21
Line 1 
Line 1 
 //BEGIN_LICENSE  //%/////////////////////////////////////////////////////////////////////////////
 // //
 // Copyright (c) 2000 The Open Group, BMC Software, Tivoli Systems, IBM  // Copyright (c) 2000, 2001 The Open group, BMC Software, Tivoli Systems, IBM
 // //
 // Permission is hereby granted, free of charge, to any person obtaining a  // Permission is hereby granted, free of charge, to any person obtaining a copy
 // copy of this software and associated documentation files (the "Software"),  // of this software and associated documentation files (the "Software"), to
 // to deal in the Software without restriction, including without limitation  // deal in the Software without restriction, including without limitation the
 // the rights to use, copy, modify, merge, publish, distribute, sublicense,  // rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
 // and/or sell copies of the Software, and to permit persons to whom the  // sell copies of the Software, and to permit persons to whom the Software is
 // Software is furnished to do so, subject to the following conditions:  // furnished to do so, subject to the following conditions:
 // //
 // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR  // THE ABOVE COPYRIGHT NOTICE AND THIS PERMISSION NOTICE SHALL BE INCLUDED IN
 // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,  // ALL COPIES OR SUBSTANTIAL PORTIONS OF THE SOFTWARE. THE SOFTWARE IS PROVIDED
 // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL  // "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT
 // THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER  // LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
 // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING  // PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
 // FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER  // HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
 // DEALINGS IN THE SOFTWARE.  // 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.
 // //
 //END_LICENSE  //==============================================================================
 //BEGIN_HISTORY  
 // //
 // Author:  // Author: Mike Brasher (mbrasher@bmc.com)
 // //
 // $Log$  // Modified By:
 // Revision 1.3  2001/03/04 21:57:34  bob  
 // Changed print methods to take a stream instead of hardcoded cout  
 // //
 // Revision 1.2  2001/02/19 01:47:16  mike  //%/////////////////////////////////////////////////////////////////////////////
 // Renamed names of the form CIMConst to ConstCIM.  
 //  
 // Revision 1.1  2001/02/18 18:39:06  mike  
 // new  
 //  
 // Revision 1.2  2001/02/18 03:56:01  mike  
 // Changed more class names (e.g., ConstClassDecl -> ConstCIMClass)  
 //  
 // Revision 1.1  2001/02/16 02:07:06  mike  
 // Renamed many classes and headers (using new CIM prefixes).  
 //  
 // Revision 1.3  2001/01/23 01:25:35  mike  
 // Reworked resolve scheme.  
 //  
 // Revision 1.2  2001/01/22 00:45:47  mike  
 // more work on resolve scheme  
 //  
 // Revision 1.1.1.1  2001/01/14 19:52:58  mike  
 // Pegasus import  
 //  
 //  
 //END_HISTORY  
  
   #include <Pegasus/Common/Config.h>
 #include <cassert> #include <cassert>
 #include "CIMMethod.h" #include "CIMMethod.h"
   #include "CIMMethodRep.h"
 #include "Indentor.h" #include "Indentor.h"
 #include "CIMName.h" #include "CIMName.h"
 #include "CIMScope.h" #include "CIMScope.h"
 #include "XmlWriter.h" #include "XmlWriter.h"
   #include "MofWriter.h"
  
 PEGASUS_NAMESPACE_BEGIN PEGASUS_NAMESPACE_BEGIN
  
Line 70 
Line 49 
     if (!CIMName::legal(name))     if (!CIMName::legal(name))
         throw IllegalName();         throw IllegalName();
  
     if (classOrigin.getLength() && !CIMName::legal(classOrigin))      if (classOrigin.size() && !CIMName::legal(classOrigin))
         throw IllegalName();         throw IllegalName();
  
     if (type == CIMType::NONE)     if (type == CIMType::NONE)
Line 100 
Line 79 
  
 void CIMMethodRep::addParameter(const CIMParameter& x) void CIMMethodRep::addParameter(const CIMParameter& x)
 { {
     if (!x)      if (x.isNull())
         throw UnitializedHandle();          throw UninitializedHandle();
  
     if (findParameter(x.getName()) != Uint32(-1))      if (findParameter(x.getName()) != PEG_NOT_FOUND)
         throw AlreadyExists();         throw AlreadyExists();
  
     _parameters.append(x);     _parameters.append(x);
 } }
  
 Uint32 CIMMethodRep::findParameter(const String& name)  Uint32 CIMMethodRep::findParameter(const String& name) const
 { {
     for (Uint32 i = 0, n = _parameters.getSize(); i < n; i++)      for (Uint32 i = 0, n = _parameters.size(); i < n; i++)
     {     {
         if (CIMName::equal(_parameters[i].getName(), name))         if (CIMName::equal(_parameters[i].getName(), name))
             return i;             return i;
     }     }
  
     return Uint32(-1);      return PEG_NOT_FOUND;
 } }
  
 CIMParameter CIMMethodRep::getParameter(Uint32 pos) CIMParameter CIMMethodRep::getParameter(Uint32 pos)
 { {
     if (pos >= _parameters.getSize())      if (pos >= _parameters.size())
         throw OutOfBounds();         throw OutOfBounds();
  
     return _parameters[pos];     return _parameters[pos];
Line 130 
Line 109 
  
 Uint32 CIMMethodRep::getParameterCount() const Uint32 CIMMethodRep::getParameterCount() const
 { {
     return _parameters.getSize();      return _parameters.size();
 } }
  
 void CIMMethodRep::resolve( void CIMMethodRep::resolve(
Line 143 
Line 122 
  
     // Check for type mismatch between return types.     // Check for type mismatch between return types.
  
     assert (inheritedMethod);      assert (!inheritedMethod.isNull());
  
     // Validate the qualifiers of the method (according to     // Validate the qualifiers of the method (according to
     // superClass's method with the same name). This method     // superClass's method with the same name). This method
Line 154 
Line 133 
         nameSpace,         nameSpace,
         CIMScope::METHOD,         CIMScope::METHOD,
         false,         false,
         inheritedMethod._rep->_qualifiers);          inheritedMethod._rep->_qualifiers,
           true);
  
     // Validate each of the parameters:     // Validate each of the parameters:
  
     for (size_t i = 0; i < _parameters.getSize(); i++)      for (size_t i = 0; i < _parameters.size(); i++)
         _parameters[i].resolve(declContext, nameSpace);         _parameters[i].resolve(declContext, nameSpace);
  
     _classOrigin = inheritedMethod.getClassOrigin();     _classOrigin = inheritedMethod.getClassOrigin();
Line 177 
Line 157 
         nameSpace,         nameSpace,
         CIMScope::METHOD,         CIMScope::METHOD,
         false,         false,
         dummy);          dummy,
           true);
  
     // Validate each of the parameters:     // Validate each of the parameters:
  
     for (size_t i = 0; i < _parameters.getSize(); i++)      for (size_t i = 0; i < _parameters.size(); i++)
         _parameters[i].resolve(declContext, nameSpace);         _parameters[i].resolve(declContext, nameSpace);
 } }
  
Line 196 
Line 177 
  
     out << " NAME=\"" << _name << "\"";     out << " NAME=\"" << _name << "\"";
  
     out << " TYPE=\"" << TypeToString(_type) << "\"";      out << " TYPE=\"" << _type.toString() << "\"";
  
     if (_classOrigin.getLength())      if (_classOrigin.size())
         out << " CLASSORIGIN=\"" << _classOrigin << "\"";         out << " CLASSORIGIN=\"" << _classOrigin << "\"";
  
     if (_propagated != false)     if (_propagated != false)
Line 208 
Line 189 
  
     _qualifiers.toXml(out);     _qualifiers.toXml(out);
  
     for (Uint32 i = 0, n = _parameters.getSize(); i < n; i++)      for (Uint32 i = 0, n = _parameters.size(); i < n; i++)
         _parameters[i].toXml(out);          XmlWriter::appendParameterElement(out, _parameters[i]);
  
     out << "</METHOD>\n";     out << "</METHOD>\n";
 } }
  
 void CIMMethodRep::print(std::ostream &os) const  /**
       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(Array<Sint8>& out) const   //ATTNKS:
   {
       // Output the qualifier list starting on new line
       if (_qualifiers.getCount())
           out << "\n";
   
       _qualifiers.toMof(out);
   
       // output the type, MethodName and ParmeterList left enclosure
       out << "\n" << _type.toString() << " " << _name << "(";
   
       // output the param list separated by commas.
   
       for (Uint32 i = 0, n = _parameters.size(); i < n; i++)
 { {
     Array<Sint8> tmp;          // If not first, output comma separator
     toXml(tmp);          if (i)
     tmp.append('\0');              out << ", ";
     os << tmp.getData() << std::endl;  
           MofWriter::appendParameterElement(out, _parameters[i]);
       }
   
       // output the parameterlist and method terminator
       out << ");";
 } }
  
   
 CIMMethodRep::CIMMethodRep() CIMMethodRep::CIMMethodRep()
 { {
  
Line 236 
Line 245 
 { {
     x._qualifiers.cloneTo(_qualifiers);     x._qualifiers.cloneTo(_qualifiers);
  
     _parameters.reserve(x._parameters.getSize());      _parameters.reserve(x._parameters.size());
  
     for (Uint32 i = 0, n = x._parameters.getSize(); i < n; i++)      for (Uint32 i = 0, n = x._parameters.size(); i < n; i++)
         _parameters.append(x._parameters[i].clone());         _parameters.append(x._parameters[i].clone());
 } }
  
 CIMMethodRep& CIMMethodRep::operator=(const CIMMethodRep& x)  
 {  
     return *this;  
 }  
   
 Boolean CIMMethodRep::identical(const CIMMethodRep* x) const Boolean CIMMethodRep::identical(const CIMMethodRep* x) const
 { {
     if (_name != x->_name)     if (_name != x->_name)
Line 258 
Line 262 
     if (!_qualifiers.identical(x->_qualifiers))     if (!_qualifiers.identical(x->_qualifiers))
         return false;         return false;
  
     if (_parameters.getSize() != x->_parameters.getSize())      if (_parameters.size() != x->_parameters.size())
         return false;         return false;
  
     for (Uint32 i = 0, n = _parameters.getSize(); i < n; i++)      for (Uint32 i = 0, n = _parameters.size(); i < n; i++)
     {     {
         if (!_parameters[i].identical(x->_parameters[i]))         if (!_parameters[i].identical(x->_parameters[i]))
             return false;             return false;
Line 270 
Line 274 
     return true;     return true;
 } }
  
   void CIMMethodRep::setType(CIMType type)
   {
       _type = type;
   
       if (type == CIMType::NONE)
           throw NullType();
   }
   
 PEGASUS_NAMESPACE_END PEGASUS_NAMESPACE_END


Legend:
Removed from v.1.3  
changed lines
  Added in v.1.23

No CVS admin address has been configured
Powered by
ViewCVS 0.9.2