//%2004//////////////////////////////////////////////////////////////////////// // // 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. // // 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. // //============================================================================== // // Author: Adrian Schuur, schuur@de.ibm.com // // Modified By: // //%///////////////////////////////////////////////////////////////////////////// #include "CMPI_Version.h" #include "CMPI_SubCond.h" #include "CMPI_Ftabs.h" #include "CMPI_Value.h" #include "CMPI_String.h" PEGASUS_USING_STD; PEGASUS_NAMESPACE_BEGIN extern "C" { CMPIStatus sbcRelease(CMPISubCond* sc) { CMPI_SubCond *sbc = (CMPI_SubCond*)sc->hdl; if (sbc) { delete sbc; ((CMPI_Object*)sc)->unlinkAndDelete(); } CMReturn(CMPI_RC_OK); } CMPISubCond* sbcClone(CMPISubCond* eSc, CMPIStatus* rc) { if (rc) CMSetStatus(rc,CMPI_RC_ERR_NOT_SUPPORTED); return NULL; } CMPICount sbcGetCount(CMPISubCond* eSbc, CMPIStatus* rc) { if (rc) CMSetStatus(rc,CMPI_RC_OK); CMPI_Object *obj=reinterpret_cast(eSbc); CMPI_TableauRow* row = (CMPI_TableauRow* )obj->priv; if (row) return row->size(); return 0; } CMPIPredicate* sbcGetPredicateAt(CMPISubCond* eSbc, unsigned int index, CMPIStatus* rc) { CMPI_Object *obj=reinterpret_cast(eSbc); CMPI_TableauRow* row = (CMPI_TableauRow* )obj->priv; if (row) if (index<=row->size()) { const CMPI_term_el *term=(row->getData())+index; CMPIPredicate *prd=(CMPIPredicate*)new CMPI_Predicate(term); /* CMPI_Object puts in the hdl the pointer to the CMPI_Predicate. The sbcRelease will use that pointer to de-allocate the CMPI_Predicate structure. */ CMPI_Object *obj = new CMPI_Object(prd); /* We add our private data - the row in the priv pointer */ obj->priv = ((CMPI_Predicate *)prd)->priv; if (rc) CMSetStatus(rc,CMPI_RC_OK); return reinterpret_cast(obj); } if (rc) CMSetStatus(rc,CMPI_RC_ERR_FAILED); return NULL; } CMPIPredicate* sbcGetPredicate(CMPISubCond* eSbc, const char *name, CMPIStatus* rc) { //CMPI_SubCond *sc=(CMPI_SubCond*)eSbc; return NULL; } } static CMPISubCondFT scnd_FT={ CMPICurrentVersion, sbcRelease, sbcClone, sbcGetCount, sbcGetPredicateAt, sbcGetPredicate }; CMPISubCondFT *CMPI_SubCond_Ftab=&scnd_FT; CMPI_SubCond::CMPI_SubCond(const CMPI_TableauRow* tblor) : priv((void*)tblor) { ft=CMPI_SubCond_Ftab; } PEGASUS_NAMESPACE_END