(file) Return to CMPI_Enumeration.cpp CVS log (file) (dir) Up to [Pegasus] / pegasus / src / Pegasus / ProviderManager2 / CMPI

File: [Pegasus] / pegasus / src / Pegasus / ProviderManager2 / CMPI / CMPI_Enumeration.cpp (download)
Revision: 1.18, Wed Apr 18 03:17:44 2007 UTC (17 years, 2 months ago) by venkat.puvvada
Branch: MAIN
CVS Tags: TASK-PEP286_PRIVILEGE_SEPARATION-root, TASK-PEP286_PRIVILEGE_SEPARATION-branch, TASK-Bug2102Final-root, TASK-Bug2102Final-merged_out_to_branch, TASK-Bug2102Final-merged_out_from_trunk, TASK-Bug2102Final-merged_in_to_trunk, TASK-Bug2102Final-merged_in_from_branch, TASK-Bug2102Final-branch
Changes since 1.17: +3 -3 lines
BUG#: 6163
TITLE: Run-Time Error in CMPIEnumerationFT while testing some Error-Conditions

//%2006////////////////////////////////////////////////////////////////////////
//
// 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
// of this software and associated documentation files (the "Software"), to
// deal in the Software without restriction, including without limitation the
// rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
// 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 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.
//
//==============================================================================
//
//%/////////////////////////////////////////////////////////////////////////////

#include "CMPI_Version.h"

#include "CMPI_Enumeration.h"
#include "CMPI_Object.h"
#include "CMPI_Ftabs.h"

PEGASUS_USING_STD;
PEGASUS_NAMESPACE_BEGIN

extern "C" {

   static CMPIStatus enumRelease(CMPIEnumeration* eObj) {
       if ((void*)eObj->ft==(void*)CMPI_InstEnumeration_Ftab)
       {
           CMPI_InstEnumeration* ie=(CMPI_InstEnumeration*)eObj->hdl;
           if (ie){
               Array<CIMInstance>* enm=(Array<CIMInstance>*)ie->hdl;
               if (enm) {
                   delete enm;
               }
               delete ie;
           }
           (reinterpret_cast<CMPI_Object*>(eObj))->unlinkAndDelete();
       }
       else if ((void*)eObj->ft==(void*)CMPI_ObjEnumeration_Ftab)
       {
           CMPI_ObjEnumeration* ie=(CMPI_ObjEnumeration*)eObj->hdl;
           if (ie){
               Array<CIMObject>* enm=(Array<CIMObject>*)ie->hdl;
               if (enm) {
                   delete enm;
               }
               delete ie;
           }
           (reinterpret_cast<CMPI_Object*>(eObj))->unlinkAndDelete();
       }
       else if ((void*)eObj->ft==(void*)CMPI_OpEnumeration_Ftab)
       {
           CMPI_OpEnumeration* ie=(CMPI_OpEnumeration*)eObj->hdl;
           if (ie){
               Array<CIMObjectPath>* enm=(Array<CIMObjectPath>*)ie->hdl;
               if (enm) {
                   delete enm;
               }
               delete ie;
           }
           (reinterpret_cast<CMPI_Object*>(eObj))->unlinkAndDelete();
       }

      CMReturn(CMPI_RC_OK);
   }

   static CMPIEnumeration* enumClone(const CMPIEnumeration* eEnumObj, CMPIStatus* rc)
   {
       const CMPIEnumeration* eEnum = (CMPIEnumeration*)eEnumObj->hdl;

       if (eEnum->hdl)
       {
           if ((void*)eEnum->ft == (void*)CMPI_InstEnumeration_Ftab)
           {
               Array<CIMInstance>* enm = (Array<CIMInstance>*)eEnum->hdl;
               CMPI_Object *obj = new CMPI_Object(
                   new CMPI_InstEnumeration(new Array<CIMInstance>(*enm)));
               obj->unlink(); // remove from current thread context.
               return reinterpret_cast<CMPIEnumeration*>(obj);
           }
           else if ((void*)eEnum->ft == (void*)CMPI_ObjEnumeration_Ftab)
           {
               Array<CIMObject>* enm = (Array<CIMObject>*)eEnum->hdl;
               CMPI_Object *obj = new CMPI_Object(
                   new CMPI_ObjEnumeration(new Array<CIMObject>(*enm)));
               obj->unlink(); // remove from current thread context.
               return reinterpret_cast<CMPIEnumeration*>(obj);
           }
           else if ((void*)eEnum->ft == (void*)CMPI_OpEnumeration_Ftab)
           {
               Array<CIMObjectPath>* enm = (Array<CIMObjectPath>*)eEnum->hdl;
               CMPI_Object *obj = new CMPI_Object(
                   new CMPI_OpEnumeration(new Array<CIMObjectPath>(*enm)));
               obj->unlink(); // remove from current thread context.
               return reinterpret_cast<CMPIEnumeration*>(obj);
           }
       }
       CMSetStatus(rc, CMPI_RC_ERR_INVALID_HANDLE);
      return NULL;
   }

   static CMPIData enumGetNext(const CMPIEnumeration* eEnumObj, CMPIStatus* rc) 
   {
      CMPIData data={0,CMPI_nullValue,{0}};
      const CMPIEnumeration* eEnum = (CMPIEnumeration*)eEnumObj->hdl;

      if (!eEnum ||!eEnum->hdl)
        {
            CMSetStatus(rc, CMPI_RC_ERR_INVALID_HANDLE);
            return data;
        }
      if ((void*)eEnum->ft==(void*)CMPI_ObjEnumeration_Ftab) {
         CMPI_ObjEnumeration* ie=(CMPI_ObjEnumeration*)eEnum;
         data.type=CMPI_instance;
         Array<CIMInstance>* ia=(Array<CIMInstance>*)ie->hdl;
         if (ie->cursor<ie->max) {
            data.value.inst=reinterpret_cast<CMPIInstance*>
         (new CMPI_Object(new CIMInstance((*ia)[ie->cursor++])));
            if (rc) CMSetStatus(rc,CMPI_RC_OK);
         }
         else if (rc) CMSetStatus(rc,CMPI_RC_ERR_FAILED);
      }

      else if ((void*)eEnum->ft==(void*)CMPI_InstEnumeration_Ftab) {
         CMPI_InstEnumeration* ie=(CMPI_InstEnumeration*)eEnum;
         data.type=CMPI_instance;
         Array<CIMInstance>* ia=(Array<CIMInstance>*)ie->hdl;
         if (ie->cursor<ie->max) {
            data.value.inst=reinterpret_cast<CMPIInstance*>
         (new CMPI_Object(new CIMInstance((*ia)[ie->cursor++])));
            if (rc) CMSetStatus(rc,CMPI_RC_OK);
         }
         else if (rc) CMSetStatus(rc,CMPI_RC_ERR_FAILED);
      }

      else {
         CMPI_OpEnumeration* oe=(CMPI_OpEnumeration*)eEnum;
         data.type=CMPI_ref;
         Array<CIMObjectPath>* opa=(Array<CIMObjectPath>*)oe->hdl;
         if (oe->cursor<oe->max) {
            data.value.ref=reinterpret_cast<CMPIObjectPath*>
         (new CMPI_Object(new CIMObjectPath((*opa)[oe->cursor++])));
            if (rc) CMSetStatus(rc,CMPI_RC_OK);
         }
         else if (rc) CMSetStatus(rc,CMPI_RC_ERR_FAILED);
      }
      return data;
   }

   static CMPIBoolean enumHasNext(const CMPIEnumeration* eEnumObj, 
                                  CMPIStatus* rc) 
   {
      const CMPIEnumeration* eEnum = (CMPIEnumeration*)eEnumObj->hdl;

      if (!eEnum || !eEnum->hdl)
        {
            CMSetStatus(rc, CMPI_RC_ERR_INVALID_HANDLE);
            return false;
        }
      if (rc) CMSetStatus(rc,CMPI_RC_OK);
      if ((void*)eEnum->ft==(void*)CMPI_ObjEnumeration_Ftab) {
         CMPI_ObjEnumeration* ie=(CMPI_ObjEnumeration*)eEnum;
         if (ie->cursor<ie->max) return true;
      }
      else if ((void*)eEnum->ft==(void*)CMPI_InstEnumeration_Ftab) {
         CMPI_InstEnumeration* ie=(CMPI_InstEnumeration*)eEnum;
         if (ie->cursor<ie->max) return true;
      }
      else {
         CMPI_OpEnumeration* oe=(CMPI_OpEnumeration*)eEnum;
         if (oe->cursor<oe->max) return true;
      }
      return false;
   }

   extern CMPIArray* mbEncNewArray(const CMPIBroker* mb, CMPICount count, CMPIType type,
                                 CMPIStatus *rc);
   extern CMPIStatus arraySetElementAt(CMPIArray* eArray, CMPICount pos,
                                       const CMPIValue *val, CMPIType type);

   static CMPIArray* enumToArray(const CMPIEnumeration* eEnumObj, CMPIStatus* rc) 
   {
      Uint32 size;
      CMPI_Object* obj;
      CMPIArray *nar=NULL;
      const CMPIEnumeration* eEnum = (CMPIEnumeration*)eEnumObj->hdl;

      if (!eEnum || !eEnum->hdl)
        {
            CMSetStatus(rc, CMPI_RC_ERR_INVALID_HANDLE);
            return NULL;
        }
      if ((void*)eEnum->ft==(void*)CMPI_ObjEnumeration_Ftab ||
         (void*)eEnum->ft==(void*)CMPI_InstEnumeration_Ftab) {
         Array<CIMInstance>* ia;
         if ((void*)eEnum->ft==(void*)CMPI_ObjEnumeration_Ftab) {
            CMPI_ObjEnumeration* ie=(CMPI_ObjEnumeration*)eEnum;
            ia=(Array<CIMInstance>*)ie->hdl;
         }
         else {
            CMPI_InstEnumeration* ie=(CMPI_InstEnumeration*)eEnum;
            ia=(Array<CIMInstance>*)ie->hdl;
         }
         size=ia->size();
         nar=mbEncNewArray(NULL,size,CMPI_instance,NULL);
         for (Uint32 i=0; i<size; i++) {
            CIMInstance &inst=(*ia)[i];
            obj=new CMPI_Object(new CIMInstance(inst));
            arraySetElementAt(nar,i,(CMPIValue*)&obj,CMPI_instance);
         }
      }
      else {
         CMPI_OpEnumeration* oe=(CMPI_OpEnumeration*)eEnum;
         Array<CIMObjectPath>* opa=(Array<CIMObjectPath>*)oe->hdl;
         size=opa->size();
         nar=mbEncNewArray(NULL,size,CMPI_ref,NULL);
         for (Uint32 i=0; i<size; i++) {
            CIMObjectPath &op=(*opa)[i];
            obj=new CMPI_Object(new CIMObjectPath(op));
            arraySetElementAt(nar,i,(CMPIValue*)&obj,CMPI_ref);
         }
      }
      return nar;
   }

}

static CMPIEnumerationFT objEnumeration_FT={
     CMPICurrentVersion,
     enumRelease,
     enumClone,
     enumGetNext,
     enumHasNext,
     enumToArray,
};

static CMPIEnumerationFT instEnumeration_FT={
     CMPICurrentVersion,
     enumRelease,
     enumClone,
     enumGetNext,
     enumHasNext,
     enumToArray,
};

static CMPIEnumerationFT opEnumeration_FT={
     CMPICurrentVersion,
     enumRelease,
     enumClone,
     enumGetNext,
     enumHasNext,
     enumToArray,
};

CMPIEnumerationFT *CMPI_ObjEnumeration_Ftab=&objEnumeration_FT;
CMPIEnumerationFT *CMPI_InstEnumeration_Ftab=&instEnumeration_FT;
CMPIEnumerationFT *CMPI_OpEnumeration_Ftab=&opEnumeration_FT;

CMPI_ObjEnumeration::CMPI_ObjEnumeration(Array<CIMObject>* oa) {
   cursor=0;
   max=oa->size();
   hdl=(void*)oa;
   ft=CMPI_ObjEnumeration_Ftab;
}
CMPI_InstEnumeration::CMPI_InstEnumeration(Array<CIMInstance>* ia) {
   cursor=0;
   max=ia->size();
   hdl=(void*)ia;
   ft=CMPI_InstEnumeration_Ftab;
}

CMPI_OpEnumeration::CMPI_OpEnumeration(Array<CIMObjectPath>* opa) {
   cursor=0;
   max=opa->size();
   hdl=(void*)opa;
   ft=CMPI_OpEnumeration_Ftab;
}

PEGASUS_NAMESPACE_END














No CVS admin address has been configured
Powered by
ViewCVS 0.9.2