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

File: [Pegasus] / pegasus / src / Pegasus / Provider / CMPI / CmpiImpl.cpp (download)
Revision: 1.30, Thu Sep 14 15:28:03 2006 UTC (17 years, 9 months ago) by mark.hamzy
Branch: MAIN
CVS Tags: TASK-TASK-BUG4011_WinLocalConnect-branch-New-root, TASK-TASK-BUG4011_WinLocalConnect-branch-New-merged_out_to_branch, TASK-TASK-BUG4011_WinLocalConnect-branch-New-merged_out_from_trunk, TASK-TASK-BUG4011_WinLocalConnect-branch-New-merged_in_to_trunk, TASK-TASK-BUG4011_WinLocalConnect-branch-New-merged_in_from_branch, TASK-TASK-BUG4011_WinLocalConnect-branch-New-branch, TASK-PEP268_SSLClientCertificatePropagation-root, TASK-PEP268_SSLClientCertificatePropagation-merged_out_to_branch, TASK-PEP268_SSLClientCertificatePropagation-merged_out_from_trunk, TASK-PEP268_SSLClientCertificatePropagation-merged_in_to_trunk, TASK-PEP268_SSLClientCertificatePropagation-merged_in_from_branch, TASK-PEP268_SSLClientCertificatePropagation-branch, TASK-PEP267_SLPReregistrationSupport-root, TASK-PEP267_SLPReregistrationSupport-merging_out_to_branch, TASK-PEP267_SLPReregistrationSupport-merged_out_to_branch, TASK-PEP267_SLPReregistrationSupport-merged_out_from_trunk, TASK-PEP267_SLPReregistrationSupport-merged_in_to_trunk, TASK-PEP267_SLPReregistrationSupport-merged_in_from_branch, TASK-PEP267_SLPReregistrationSupport-branch, TASK-Bugs5690_3913_RemoteCMPI-root, TASK-Bugs5690_3913_RemoteCMPI-merged_out_to_branch, TASK-Bugs5690_3913_RemoteCMPI-merged_out_from_trunk, TASK-Bugs5690_3913_RemoteCMPI-merged_in_to_trunk, TASK-Bugs5690_3913_RemoteCMPI-merged_in_from_branch, TASK-Bugs5690_3913_RemoteCMPI-branch, TASK-Bug2021_RemoteCMPIonWindows-root, TASK-Bug2021_RemoteCMPIonWindows-merged_out_to_branch, TASK-Bug2021_RemoteCMPIonWindows-merged_out_from_trunk, TASK-Bug2021_RemoteCMPIonWindows-merged_in_to_trunk, TASK-Bug2021_RemoteCMPIonWindows-merged_in_from_branch, TASK-Bug2021_RemoteCMPIonWindows-branch, TASK-BUG4011_WinLocalConnect-branch-New
Changes since 1.29: +411 -33 lines
BUG#: 4991
TITLE: CmpiData::operator CmpiInstance() won't compile

DESCRIPTION:
CmpiData::operator CmpiInstance() won't compile

//%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.
//
//==============================================================================
//
// Author:      Adrian Schuur, schuur@de.ibm.com
//
// Modified By: Heidi Neuman, heidineu@de.ibm.com
//              Angel Nunez Mencias, anunez@de.ibm.com
//              Viktor Mihajlovski, mihajlov@de.ibm.com
//              David Dillard, VERITAS Software Corp.
//                  (david.dillard@veritas.com)
//
//%/////////////////////////////////////////////////////////////////////////////

#include "CmpiInstance.h"
#include "CmpiObjectPath.h"
#include "CmpiResult.h"
#include "CmpiDateTime.h"

#include "CmpiBaseMI.h"
#include "CmpiInstanceMI.h"
#include "CmpiAssociationMI.h"
#include "CmpiMethodMI.h"
#include "CmpiPropertyMI.h"
#include "CmpiIndicationMI.h"

#include "CmpiData.h"
#include "CmpiCharData.h"
#include "CmpiBooleanData.h"


#ifdef CMPI_STANDALONE
# define PEGASUS_USING_STD using namespace std
#else
#  include <Pegasus/Common/Config.h>
#endif

PEGASUS_USING_STD;

//---------------------------------------------------
//--
//	C to C++ base provider function drivers
//--
//---------------------------------------------------

CmpiBaseMI::CmpiBaseMI(const CmpiBroker& mbp, const CmpiContext& ctx)
{
  broker = new CmpiBroker(mbp);
}

CmpiBaseMI::~CmpiBaseMI()
{
  delete broker;
}

CMPIStatus CmpiBaseMI::driveBaseCleanup
      (void* vi, const CMPIContext* eCtx, CMPIBoolean b) {
  try {
   CMPIInstanceMI *mi=( CMPIInstanceMI*)vi;
   CmpiContext ctx((CMPIContext*)eCtx);
   CmpiStatus rc(CMPI_RC_OK);
   CmpiBaseMI* cmi = reinterpret_cast<CmpiBaseMI*>(mi->hdl);
   if (cmi->isUnloadable()) {
     if (cmi->getProviderBase() && cmi->getProviderBase()->decUseCount()==0) {
       cmi->getProviderBase()->setBaseMI(0);
       cmi->setProviderBase(0);
       rc=cmi->cleanup(ctx);
       delete cmi;
     }
   } else {
     rc = CmpiStatus(CMPI_RC_ERR_NOT_SUPPORTED);
   }
   return rc.status();
  } catch (const CmpiStatus& stat) {
#ifdef PEGASUS_DEBUG
    cerr << "caught status :" << stat.rc() << " "  << stat.msg() << endl;
#endif
    return stat.status();
  }
}

void CmpiBaseMI::setProviderBase(CmpiProviderBase* base)
{
  providerBase=base;
  CmpiProviderBase::setBroker(broker->getEnc());
}

CmpiProviderBase* CmpiBaseMI::getProviderBase()
{
  return providerBase;
}

CmpiStatus CmpiBaseMI::initialize(const CmpiContext& ctx) {
   return CmpiStatus(CMPI_RC_OK);
}

CmpiStatus CmpiBaseMI::cleanup(CmpiContext& ctx) {
#ifdef PEGASUS_DEBUG
    cerr << "cleaning up provider" << endl;
#endif
   return CmpiStatus(CMPI_RC_OK);
}

int CmpiBaseMI::isUnloadable() const {
   return 1;
}

//---------------------------------------------------
//--
//	C to C++ instance provider function drivers
//--
//---------------------------------------------------

CMPIStatus CmpiInstanceMI::driveEnumInstanceNames
   (CMPIInstanceMI* mi, const CMPIContext* eCtx, const CMPIResult* eRslt,
    const CMPIObjectPath* eCop)
{
  try {
   CmpiContext ctx((CMPIContext*)eCtx);
   CmpiResult rslt((CMPIResult*)eRslt);
   CmpiObjectPath cop((CMPIObjectPath*)eCop);
   CmpiBaseMI* cmi = reinterpret_cast<CmpiBaseMI*> (mi->hdl);
   CmpiInstanceMI* imi = dynamic_cast<CmpiInstanceMI*>(cmi);
   return imi->enumInstanceNames(ctx,rslt,cop).status();
  } catch (const CmpiStatus& stat) {
#ifdef PEGASUS_DEBUG
    cerr << "caught status :" << stat.rc() << " "  << stat.msg() << endl;
#endif
    return stat.status();
  }
}

CMPIStatus CmpiInstanceMI::driveEnumInstances
   (CMPIInstanceMI* mi, const CMPIContext* eCtx, const CMPIResult* eRslt,
    const CMPIObjectPath* eCop, const char* *properties)
{
  try {
   CmpiContext ctx((CMPIContext*)eCtx);
   CmpiResult rslt((CMPIResult*)eRslt);
   CmpiObjectPath cop((CMPIObjectPath*)eCop);
   CmpiBaseMI* cmi = reinterpret_cast<CmpiBaseMI*> (mi->hdl);
   CmpiInstanceMI* imi = dynamic_cast<CmpiInstanceMI*>(cmi);
   return imi->enumInstances
      (ctx,rslt,cop,properties).status();
  } catch (const CmpiStatus& stat) {
#ifdef PEGASUS_DEBUG
    cerr << "caught status :" << stat.rc() << " "  << stat.msg() << endl;
#endif
    return stat.status();
  }
}

CMPIStatus CmpiInstanceMI::driveGetInstance
   (CMPIInstanceMI* mi, const CMPIContext* eCtx, const CMPIResult* eRslt,
    const CMPIObjectPath* eCop, const char* *properties)
{
  try {
   CmpiContext ctx((CMPIContext*)eCtx);
   CmpiResult rslt((CMPIResult*)eRslt);
   CmpiObjectPath cop((CMPIObjectPath*)eCop);
   CmpiBaseMI* cmi = reinterpret_cast<CmpiBaseMI*> (mi->hdl);
   CmpiInstanceMI* imi = dynamic_cast<CmpiInstanceMI*>(cmi);
   return imi->getInstance
      (ctx,rslt,cop,properties).status();
  } catch (const CmpiStatus& stat) {
#ifdef PEGASUS_DEBUG
    cerr << "caught status :" << stat.rc() << " "  << stat.msg() << endl;
#endif
    return stat.status();
  }
}

CMPIStatus CmpiInstanceMI::driveCreateInstance
   (CMPIInstanceMI* mi, const CMPIContext* eCtx, const CMPIResult* eRslt,
    const CMPIObjectPath* eCop, const CMPIInstance* eInst)
{
  try {
   CmpiContext ctx((CMPIContext*)eCtx);
   CmpiResult rslt((CMPIResult*)eRslt);
   CmpiObjectPath cop((CMPIObjectPath*)eCop);
   CmpiInstance inst(eInst);
   CmpiBaseMI* cmi = reinterpret_cast<CmpiBaseMI*> (mi->hdl);
   CmpiInstanceMI* imi = dynamic_cast<CmpiInstanceMI*>(cmi);
   return imi->createInstance
      (ctx,rslt,cop,inst).status();
  } catch (const CmpiStatus& stat) {
#ifdef PEGASUS_DEBUG
    cerr << "caught status :" << stat.rc() << " "  << stat.msg() << endl;
#endif
    return stat.status();
  }
}

CMPIStatus CmpiInstanceMI::driveSetInstance
   (CMPIInstanceMI* mi, const CMPIContext* eCtx, const CMPIResult* eRslt,
    const CMPIObjectPath* eCop, const CMPIInstance* eInst, 
    const char* *properties)
{
  try {
   CmpiContext ctx((CMPIContext*)eCtx);
   CmpiResult rslt((CMPIResult*)eRslt);
   CmpiObjectPath cop((CMPIObjectPath*)eCop);
   CmpiInstance inst(eInst);
   CmpiBaseMI* cmi = reinterpret_cast<CmpiBaseMI*> (mi->hdl);
   CmpiInstanceMI* imi = dynamic_cast<CmpiInstanceMI*>(cmi);
   return imi->setInstance
      (ctx,rslt,cop,inst,(const char**)properties).status();
  } catch (const CmpiStatus& stat) {
#ifdef PEGASUS_DEBUG
    cerr << "caught status :" << stat.rc() << " "  << stat.msg() << endl;
#endif
    return stat.status();
  }
}

CMPIStatus CmpiInstanceMI::driveDeleteInstance
   (CMPIInstanceMI* mi, const CMPIContext* eCtx, const CMPIResult* eRslt,
    const CMPIObjectPath* eCop)
{
  try {
   CmpiContext ctx((CMPIContext*)eCtx);
   CmpiResult rslt((CMPIResult*)eRslt);
   CmpiObjectPath cop((CMPIObjectPath*)eCop);
   CmpiBaseMI* cmi = reinterpret_cast<CmpiBaseMI*> (mi->hdl);
   CmpiInstanceMI* imi = dynamic_cast<CmpiInstanceMI*>(cmi);
   return imi->deleteInstance
      (ctx,rslt,cop).status();
  } catch (const CmpiStatus& stat) {
#ifdef PEGASUS_DEBUG
    cerr << "caught status :" << stat.rc() << " "  << stat.msg() << endl;
#endif

    return stat.status();
  }
}

CMPIStatus CmpiInstanceMI::driveExecQuery
   (CMPIInstanceMI* mi, const CMPIContext* eCtx, const CMPIResult* eRslt,
    const CMPIObjectPath* eCop, const char* language ,const char* query)
{
  try {
   CmpiContext ctx((CMPIContext*)eCtx);
   CmpiResult rslt((CMPIResult*)eRslt);
   CmpiObjectPath cop((CMPIObjectPath*)eCop);
   CmpiBaseMI* cmi = reinterpret_cast<CmpiBaseMI*> (mi->hdl);
   CmpiInstanceMI* imi = dynamic_cast<CmpiInstanceMI*>(cmi);
   return imi->execQuery
    (ctx,rslt,cop,language,query).status();
  } catch (const CmpiStatus& stat) {
#ifdef PEGASUS_DEBUG
    cerr << "caught status :" << stat.rc() << " "  << stat.msg() << endl;
#endif
    return stat.status();
  }
}


//---------------------------------------------------
//--
//	Default Instance provider functions
//--
//---------------------------------------------------

CmpiInstanceMI::CmpiInstanceMI(const CmpiBroker &mbp, const CmpiContext& ctx)
   : CmpiBaseMI (mbp,ctx) {
}

CmpiStatus CmpiInstanceMI::enumInstanceNames
              (const CmpiContext& ctx, CmpiResult& rslt, const CmpiObjectPath& cop) {
   return CmpiStatus(CMPI_RC_ERR_NOT_SUPPORTED);
}

CmpiStatus CmpiInstanceMI::enumInstances
              (const CmpiContext& ctx, CmpiResult& rslt, const CmpiObjectPath& cop,
	       const char* *properties){
   return CmpiStatus(CMPI_RC_ERR_NOT_SUPPORTED);
}

CmpiStatus CmpiInstanceMI::getInstance
              (const CmpiContext& ctx, CmpiResult& rslt, const CmpiObjectPath& cop,
	       const char* *properties) {
   return CmpiStatus(CMPI_RC_ERR_NOT_SUPPORTED);
}

CmpiStatus CmpiInstanceMI::createInstance
              (const CmpiContext& ctx, CmpiResult& rslt, const CmpiObjectPath& cop,
               const CmpiInstance& inst) {
   return CmpiStatus(CMPI_RC_ERR_NOT_SUPPORTED);
}

CmpiStatus CmpiInstanceMI::setInstance
              (const CmpiContext& ctx, CmpiResult& rslt, const CmpiObjectPath& cop,
              const  CmpiInstance& inst, const char* *properties) {
   return CmpiStatus(CMPI_RC_ERR_NOT_SUPPORTED);
}

CmpiStatus CmpiInstanceMI::deleteInstance
              (const CmpiContext& ctx, CmpiResult& rslt, const CmpiObjectPath& cop) {
   return CmpiStatus(CMPI_RC_ERR_NOT_SUPPORTED);
}

CmpiStatus CmpiInstanceMI::execQuery
              (const CmpiContext& ctx, CmpiResult& rslt, const CmpiObjectPath& cop,
               const char* language, const char* query) {
   return CmpiStatus(CMPI_RC_ERR_NOT_SUPPORTED);
}


//---------------------------------------------------
//--
//	C to C++ association provider function drivers
//--
//---------------------------------------------------

CMPIStatus CmpiAssociationMI::driveAssociators
      (CMPIAssociationMI* mi, const CMPIContext* eCtx, const CMPIResult* eRslt,
       const CMPIObjectPath* eOp, const char* assocClass, const char* resultClass,
       const char* role, const char* resultRole, const char** properties) {
  try {
   CmpiContext ctx((CMPIContext*)eCtx);
   CmpiResult rslt((CMPIResult*)eRslt);
   CmpiObjectPath cop((CMPIObjectPath*)eOp);
   CmpiBaseMI* cmi = reinterpret_cast<CmpiBaseMI*> (mi->hdl);
   CmpiAssociationMI* ami = dynamic_cast<CmpiAssociationMI*>(cmi);
   return ami->associators
      (ctx,rslt,cop,
       (const char*)assocClass,resultClass,
       role,resultRole,(const char**)properties).status();
  } catch (const CmpiStatus& stat) {
#ifdef PEGASUS_DEBUG
    cerr << "caught status :" << stat.rc() << " "  << stat.msg() << endl;
#endif
    return stat.status();
  }
}

CMPIStatus CmpiAssociationMI::driveAssociatorNames
      (CMPIAssociationMI* mi, const CMPIContext* eCtx, const CMPIResult* eRslt,
       const CMPIObjectPath* eOp, const char* assocClass, const char* resultClass,
       const char* role, const char* resultRole) {
  try {
   CmpiContext ctx((CMPIContext*)eCtx);
   CmpiResult rslt((CMPIResult*)eRslt);
   CmpiObjectPath cop((CMPIObjectPath*)eOp);
   CmpiBaseMI* cmi = reinterpret_cast<CmpiBaseMI*> (mi->hdl);
   CmpiAssociationMI* ami = dynamic_cast<CmpiAssociationMI*>(cmi);
   return ami->associatorNames
      (ctx,rslt,cop,
       assocClass,resultClass,
       role,resultRole).status();
  } catch (const CmpiStatus& stat) {
#ifdef PEGASUS_DEBUG
    cerr << "caught status :" << stat.rc() << " "  << stat.msg() << endl;
#endif
    return stat.status();
  }
}

CMPIStatus CmpiAssociationMI::driveReferences
      (CMPIAssociationMI* mi, const CMPIContext* eCtx, const CMPIResult* eRslt,
       const CMPIObjectPath* eOp, const char* resultClass, const char* role ,
       const char** properties) {
  try {
   CmpiContext ctx((CMPIContext*)eCtx);
   CmpiResult rslt((CMPIResult*)eRslt);
   CmpiObjectPath cop((CMPIObjectPath*)eOp);
   CmpiBaseMI* cmi = reinterpret_cast<CmpiBaseMI*> (mi->hdl);
   CmpiAssociationMI* ami = dynamic_cast<CmpiAssociationMI*>(cmi);
   return ami->references
      (ctx,rslt,cop,
       resultClass,role,(const char**)properties).status();
  } catch (const CmpiStatus& stat) {
#ifdef PEGASUS_DEBUG
    cerr << "caught status :" << stat.rc() << " "  << stat.msg() << endl;
#endif
    return stat.status();
  }
}

CMPIStatus CmpiAssociationMI::driveReferenceNames
      (CMPIAssociationMI* mi, const CMPIContext* eCtx, const CMPIResult* eRslt,
       const CMPIObjectPath* eOp, const char* resultClass, const char* role) {
  try {
   CmpiContext ctx((CMPIContext*)eCtx);
   CmpiResult rslt((CMPIResult*)eRslt);
   CmpiObjectPath cop((CMPIObjectPath*)eOp);
   CmpiBaseMI* cmi = reinterpret_cast<CmpiBaseMI*> (mi->hdl);
   CmpiAssociationMI* ami = dynamic_cast<CmpiAssociationMI*>(cmi);
   return ami->referenceNames
      (ctx,rslt,cop,
       resultClass,role).status();
  } catch (const CmpiStatus& stat) {
#ifdef PEGASUS_DEBUG
    cerr << "caught status :" << stat.rc() << " "  << stat.msg() << endl;
#endif
    return stat.status();
  }
}


//---------------------------------------------------
//--
//	Default Association provider functions
//--
//---------------------------------------------------

CmpiAssociationMI::CmpiAssociationMI(const CmpiBroker &mbp, const CmpiContext& ctx)
    : CmpiBaseMI (mbp,ctx) {
}

CmpiStatus CmpiAssociationMI::associators
      (const CmpiContext& ctx, CmpiResult& rslt,
       const CmpiObjectPath& op, const char* assocClass, const char* resultClass,
       const char* role, const char* resultRole, const char** properties) {
   return CmpiStatus(CMPI_RC_ERR_NOT_SUPPORTED);
}

CmpiStatus CmpiAssociationMI::associatorNames
      (const CmpiContext& ctx, CmpiResult& rslt,
       const CmpiObjectPath& op, const char* assocClass, const char* resultClass,
       const char* role, const char* resultRole) {
   return CmpiStatus(CMPI_RC_ERR_NOT_SUPPORTED);
}

CmpiStatus CmpiAssociationMI::references
      (const CmpiContext& ctx, CmpiResult& rslt,
       const CmpiObjectPath& op, const char* resultClass, const char* role ,
       const char** properties) {
   return CmpiStatus(CMPI_RC_ERR_NOT_SUPPORTED);
}

CmpiStatus CmpiAssociationMI::referenceNames
      (const CmpiContext& ctx, CmpiResult& rslt,
       const CmpiObjectPath& op, const char* resultClass, const char* role) {
   return CmpiStatus(CMPI_RC_ERR_NOT_SUPPORTED);
}


//---------------------------------------------------
//--
//	C to C++ method provider function drivers
//--
//---------------------------------------------------

CMPIStatus CmpiMethodMI::driveInvokeMethod
   (CMPIMethodMI* mi, const CMPIContext* eCtx, const CMPIResult* eRslt,
    const CMPIObjectPath* eCop, const char* methodName,
    const CMPIArgs* eIn, CMPIArgs* eOut)
{
  try {
   const CmpiContext ctx((CMPIContext*)eCtx);
   CmpiResult rslt((CMPIResult*)eRslt);
   const CmpiObjectPath cop((CMPIObjectPath*)eCop);
   const CmpiArgs in((CMPIArgs*)eIn);
   CmpiArgs out(eOut);
   CmpiBaseMI* cmi = reinterpret_cast<CmpiBaseMI*> (mi->hdl);
   CmpiMethodMI* mmi = dynamic_cast<CmpiMethodMI*>(cmi);
   return mmi->invokeMethod
      (ctx,rslt,cop,methodName,in,out).status();
  } catch (const CmpiStatus& stat) {
#ifdef PEGASUS_DEBUG
    cerr << "caught status :" << stat.rc() << " "  << stat.msg() << endl;
#endif
    return stat.status();
  }
}


//---------------------------------------------------
//--
//	Default Method provider functions
//--
//---------------------------------------------------

CmpiMethodMI::CmpiMethodMI(const CmpiBroker &mbp, const CmpiContext& ctx)
   : CmpiBaseMI (mbp,ctx) {
}

CmpiStatus CmpiMethodMI::invokeMethod
              (const CmpiContext& ctx, CmpiResult& rslt,
	       const CmpiObjectPath& ref, const char* methodName,
	       const CmpiArgs& in, CmpiArgs& out) {
   return CmpiStatus(CMPI_RC_ERR_NOT_SUPPORTED);
}


//---------------------------------------------------
//--
//	C to C++ property provider function drivers
//--
//---------------------------------------------------

CmpiPropertyMI::CmpiPropertyMI(const CmpiBroker &mbp, const CmpiContext& ctx)
   : CmpiBaseMI (mbp,ctx) {
}

CMPIStatus CmpiPropertyMI::driveSetProperty
      (CMPIPropertyMI* mi, const CMPIContext* eCtx, const CMPIResult* eRslt,
       const CMPIObjectPath* eCop, const char* name, CMPIData eData) {
  try {
   const CmpiContext ctx((CMPIContext*)eCtx);
   CmpiResult rslt((CMPIResult*)eRslt);
   const CmpiObjectPath cop((CMPIObjectPath*)eCop);
   const CmpiData data(eData);
   CmpiBaseMI* cmi = reinterpret_cast<CmpiBaseMI*> (mi->hdl);
   CmpiPropertyMI* pmi = dynamic_cast<CmpiPropertyMI*>(cmi);
   return pmi->setProperty
      (ctx,rslt,cop,name,data).status();
  } catch (const CmpiStatus& stat) {
#ifdef PEGASUS_DEBUG
    cerr << "caught status :" << stat.rc() << " "  << stat.msg() << endl;
#endif
    return stat.status();
  }
}

CMPIStatus CmpiPropertyMI::driveGetProperty
      (CMPIPropertyMI* mi, const CMPIContext* eCtx, const CMPIResult* eRslt,
       const CMPIObjectPath* eCop, const char* name) {
  try {
   const CmpiContext ctx((CMPIContext*)eCtx);
   CmpiResult rslt((CMPIResult*)eRslt);
   const CmpiObjectPath cop((CMPIObjectPath*)eCop);
   CmpiBaseMI* cmi = reinterpret_cast<CmpiBaseMI*> (mi->hdl);
   CmpiPropertyMI* pmi = dynamic_cast<CmpiPropertyMI*>(cmi);
   return pmi->getProperty
      (ctx,rslt,cop,name).status();
  } catch (const CmpiStatus& stat) {
#ifdef PEGASUS_DEBUG
    cerr << "caught status :" << stat.rc() << " "  << stat.msg() << endl;
#endif
    return stat.status();
  }
}


//---------------------------------------------------
//--
//	Default property provider functions
//--
//---------------------------------------------------

CmpiStatus CmpiPropertyMI::setProperty
      (const CmpiContext& ctx, CmpiResult& rslt,
       const CmpiObjectPath& op, const char* name, const CmpiData& data) {
   return CmpiStatus(CMPI_RC_ERR_NOT_SUPPORTED);
}

CmpiStatus CmpiPropertyMI::getProperty
      (const CmpiContext& ctx, CmpiResult& rslt,
       const CmpiObjectPath& op, const char* name) {
   return CmpiStatus(CMPI_RC_ERR_NOT_SUPPORTED);
}


//---------------------------------------------------
//--
//	C to C++ indication provider function drivers
//--
//---------------------------------------------------

CmpiIndicationMI::CmpiIndicationMI(const CmpiBroker &mbp, const CmpiContext& ctx)
   : CmpiBaseMI (mbp,ctx) {
}

CMPIStatus CmpiIndicationMI::driveAuthorizeFilter
      (CMPIIndicationMI* mi, const CMPIContext* eCtx, const CMPIResult* eRslt,
       const CMPISelectExp* eSe, const char* ns, const CMPIObjectPath* eCop, 
       const char* user){
  try {
   const CmpiContext ctx((CMPIContext*)eCtx);
   CmpiResult rslt((CMPIResult*)eRslt);
   const CmpiObjectPath cop((CMPIObjectPath*)eCop);
   const CmpiSelectExp se(eSe);
   CmpiBaseMI* cmi = reinterpret_cast<CmpiBaseMI*> (mi->hdl);
   CmpiIndicationMI* nmi = dynamic_cast<CmpiIndicationMI*>(cmi);
   return nmi->authorizeFilter
      (ctx,rslt,se,ns,cop,user).status();
  } catch (const CmpiStatus& stat) {
#ifdef PEGASUS_DEBUG
    cerr << "caught status :" << stat.rc() << " "  << stat.msg() << endl;
#endif
    return stat.status();
  }
}

CMPIStatus CmpiIndicationMI::driveMustPoll
      (CMPIIndicationMI* mi, const CMPIContext* eCtx, const CMPIResult* eRslt,
       const CMPISelectExp* eSe, const char* ns, const CMPIObjectPath* eCop){
  try {
   const CmpiContext ctx((CMPIContext*)eCtx);
   CmpiResult rslt((CMPIResult*)eRslt);
   const CmpiObjectPath cop((CMPIObjectPath*)eCop);
   const CmpiSelectExp se(eSe);
   CmpiBaseMI* cmi = reinterpret_cast<CmpiBaseMI*> (mi->hdl);
   CmpiIndicationMI* nmi = dynamic_cast<CmpiIndicationMI*>(cmi);
   return nmi->mustPoll
      (ctx,rslt,se,ns,cop).status();
  } catch (const CmpiStatus& stat) {
#ifdef PEGASUS_DEBUG
    cerr << "caught status :" << stat.rc() << " "  << stat.msg() << endl;
#endif
    return stat.status();
  }
}

CMPIStatus CmpiIndicationMI::driveActivateFilter
      (CMPIIndicationMI* mi, const CMPIContext* eCtx, const CMPIResult* eRslt,
       const CMPISelectExp* eSe, const char* ns, const CMPIObjectPath* eCop, 
       CMPIBoolean first){
   const CmpiContext ctx((CMPIContext*)eCtx);
  try {
   CmpiResult rslt((CMPIResult*)eRslt);
   const CmpiObjectPath cop((CMPIObjectPath*)eCop);
   const CmpiSelectExp se(eSe);
   CmpiBaseMI* cmi = reinterpret_cast<CmpiBaseMI*> (mi->hdl);
   CmpiIndicationMI* nmi = dynamic_cast<CmpiIndicationMI*>(cmi);
   return nmi->activateFilter
      (ctx,rslt,se,ns,cop,first).status();
  } catch (const CmpiStatus& stat) {
#ifdef PEGASUS_DEBUG
    cerr << "caught status :" << stat.rc() << " "  << stat.msg() << endl;
#endif
    return stat.status();
  }
}

CMPIStatus CmpiIndicationMI::driveDeActivateFilter
      (CMPIIndicationMI* mi, const CMPIContext* eCtx, const CMPIResult* eRslt,
       const CMPISelectExp* eSe, const char* ns, const CMPIObjectPath* eCop, 
       const CMPIBoolean last){
  try {
   const CmpiContext ctx((CMPIContext*)eCtx);
   CmpiResult rslt((CMPIResult*)eRslt);
   const CmpiObjectPath cop((CMPIObjectPath*)eCop);
   const CmpiSelectExp se(eSe);
   CmpiBaseMI* cmi = reinterpret_cast<CmpiBaseMI*> (mi->hdl);
   CmpiIndicationMI* nmi = dynamic_cast<CmpiIndicationMI*>(cmi);
   return nmi->deActivateFilter
      (ctx,rslt,se,ns,cop,last).status();
  } catch (const CmpiStatus& stat) {
#ifdef PEGASUS_DEBUG
    cerr << "caught status :" << stat.rc() << " "  << stat.msg() << endl;
#endif
    return stat.status();
  }
}

void CmpiIndicationMI::driveEnableIndications
      (CMPIIndicationMI* mi)
{
  try {
   CmpiBaseMI* cmi = reinterpret_cast<CmpiBaseMI*> (mi->hdl);
   CmpiIndicationMI* nmi = dynamic_cast<CmpiIndicationMI*>(cmi);
   nmi->enableIndications
     ();
  } catch (const CmpiStatus& stat) {
#ifdef PEGASUS_DEBUG
    cerr << "caught status :" << stat.rc() << " "  << stat.msg() << endl;
#endif
  }
}

void CmpiIndicationMI::driveDisableIndications
      (CMPIIndicationMI* mi)
{
  try {
   CmpiBaseMI* cmi = reinterpret_cast<CmpiBaseMI*> (mi->hdl);
   CmpiIndicationMI* nmi = dynamic_cast<CmpiIndicationMI*>(cmi);
   nmi->disableIndications
     ();
  } catch (const CmpiStatus& stat) {
#ifdef PEGASUS_DEBUG
    cerr << "caught status :" << stat.rc() << " "  << stat.msg() << endl;
#endif
  }
}


//---------------------------------------------------
//--
//	Default indication provider functions
//--
//---------------------------------------------------

CmpiStatus CmpiIndicationMI::authorizeFilter
      (const CmpiContext& ctx, CmpiResult& rslt,
       const CmpiSelectExp& se, const char* ns, const CmpiObjectPath& op, const char* user) {
   return CmpiStatus(CMPI_RC_ERR_NOT_SUPPORTED);
}

CmpiStatus CmpiIndicationMI::mustPoll
      (const CmpiContext& ctx, CmpiResult& rslt,
       const CmpiSelectExp& se, const char* ns, const CmpiObjectPath& op) {
   return CmpiStatus(CMPI_RC_ERR_NOT_SUPPORTED);
}

CmpiStatus CmpiIndicationMI::activateFilter
      (const CmpiContext& ctx, CmpiResult& rslt,
       const CmpiSelectExp& se, const char* ns, const CmpiObjectPath& op,
       CMPIBoolean first) {
   return CmpiStatus(CMPI_RC_ERR_NOT_SUPPORTED);
}

CmpiStatus CmpiIndicationMI::deActivateFilter
      (const CmpiContext& ctx, CmpiResult& rslt,
       const CmpiSelectExp& se, const char* ns, const CmpiObjectPath& op,
       CMPIBoolean last) {
   return CmpiStatus(CMPI_RC_ERR_NOT_SUPPORTED);
}

void CmpiIndicationMI::enableIndications()
{
}

void CmpiIndicationMI::disableIndications()
{
}



//---------------------------------------------------
//--
//	CmpiArray member functions
//--
//---------------------------------------------------

CMPIArray *CmpiArray::getEnc() const {
   return (CMPIArray*)enc;
}

CmpiArray::CmpiArray(CMPIArray *arr) {
   enc=arr;
}

CmpiArray::CmpiArray(CMPICount max, CMPIType type) {
   enc=makeArray(CmpiProviderBase::getBroker(),max,type);
}

CmpiArray::CmpiArray() {
}

CmpiArrayIdx CmpiArray::operator[](int idx) const {
   return CmpiArrayIdx(*this,idx);
}

void *CmpiArray::makeArray(CMPIBroker *mb, CMPICount max, CMPIType type) {
   CMPIStatus rc={CMPI_RC_OK,NULL};
   void *array=mb->eft->newArray(mb,max,type,&rc);
   if (rc.rc!=CMPI_RC_OK) throw CmpiStatus(rc);
   return array;
}

CMPICount CmpiArray::size() const {
   CMPIStatus rc={CMPI_RC_OK,NULL};
   CMPICount c=getEnc()?getEnc()->ft->getSize(getEnc(),&rc):0;
   if (rc.rc!=CMPI_RC_OK) throw CmpiStatus(rc);
   return c;
}

//---------------------------------------------------
//--
//	CmpiArrayIdx member functions
//--
//---------------------------------------------------


CmpiArrayIdx::CmpiArrayIdx(const CmpiArray &a, CMPICount i)
         : ar(a), idx(i)
{
}

#ifdef PEGASUS_CMPI_DATA_NEED_IMPLICIT_CONVERTERS

CmpiArrayIdx& CmpiArrayIdx::operator=(const CmpiData& v) {
   CMPIStatus rc={CMPI_RC_OK,NULL};
   if (ar.getEnc()->ft->getSimpleType(ar.getEnc(),&rc)!=v._data.type)
      throw CmpiStatus(CMPI_RC_ERR_TYPE_MISMATCH);
   rc=ar.getEnc()->ft->setElementAt(ar.getEnc(),idx,(CMPIValue*)&v._data.value,
				    v._data.type);
   if (rc.rc!=CMPI_RC_OK) throw CmpiStatus(rc);
   return *this;
}

#endif

CmpiData CmpiArrayIdx::getData() const{
   CMPIStatus rc={CMPI_RC_OK,NULL};
   CMPIData d;
   d=ar.getEnc()->ft->getElementAt(ar.getEnc(),idx,&rc);
   if (rc.rc!=CMPI_RC_OK) throw CmpiStatus(rc);
   return CmpiData (d);
}

#ifdef PEGASUS_CMPI_DATA_NEED_IMPLICIT_CONVERTERS

CmpiArrayIdx::operator CmpiString() const{
   return getData().getString();
}

CmpiArrayIdx::operator const char* () const{
   return getData().getCString();
}

CmpiArrayIdx::operator CmpiDateTime() const{
   return getData().getDateTime();
}

CmpiArrayIdx::operator CmpiObjectPath() const{
   return getData().getObjectPath();
}

CmpiArrayIdx::operator CmpiInstance() const{
   return getData().getInstance();
}

CmpiArrayIdx::operator CMPIUint8() const{
   return getData().getUint8();
}

CmpiArrayIdx::operator CMPIUint16() const{
   return getData().getUint16();
}

CmpiArrayIdx::operator CMPIUint32() const{
   return getData().getUint32();
}

CmpiArrayIdx::operator CMPIUint64() const{
   return getData().getUint64();
}

CmpiArrayIdx::operator CMPISint8() const{
   return getData().getSint8();
}

CmpiArrayIdx::operator CMPISint16() const{
   return getData().getSint16();
}

CmpiArrayIdx::operator CMPISint32() const{
   return getData().getSint32();
}

CmpiArrayIdx::operator CMPISint64() const{
   return getData().getSint64();
}

CmpiArrayIdx::operator CMPIReal32() const{
   return getData().getReal32();
}

CmpiArrayIdx::operator CMPIReal64() const{
   return getData().getReal64();
}

#endif /* PEGASUS_CMPI_DATA_NEED_IMPLICIT_CONVERTERS */

CMPIBoolean CmpiArrayIdx::getBoolean() const
{
    return getData().getBoolean();
}

CMPIUint8 CmpiArrayIdx::getUint8() const
{
    return getData().getUint8();
}

CMPISint8 CmpiArrayIdx::getSint8() const
{
    return getData().getSint8();
}

CMPIUint16 CmpiArrayIdx::getUint16() const
{
    return getData().getUint16();
}

CMPISint16 CmpiArrayIdx::getSint16() const
{
    return getData().getSint16();
}

CMPIUint32 CmpiArrayIdx::getUint32() const
{
    return getData().getUint32();
}

CMPISint32 CmpiArrayIdx::getSint32() const
{
    return getData().getSint32();
}

CMPIUint64 CmpiArrayIdx::getUint64() const
{
    return getData().getUint64();
}

CMPISint64 CmpiArrayIdx::getSint64() const
{
    return getData().getSint64();
}

CMPIReal32 CmpiArrayIdx::getReal32() const
{
    return getData().getReal32();
}

CMPIReal64 CmpiArrayIdx::getReal64() const
{
    return getData().getReal64();
}

CMPIChar16 CmpiArrayIdx::getChar16() const
{
    return getData().getChar16();
}

CmpiString CmpiArrayIdx::getString() const
{
    return getData().getString();
}

CmpiDateTime CmpiArrayIdx::getDateTime() const
{
    return getData().getDateTime();
}

//---------------------------------------------------
//--
//	CmpiData member functions
//--
//---------------------------------------------------

CmpiData::CmpiData(const CMPIData& data) {
   this->_data=data;
}

CmpiData::CmpiData() {
   _data.state=CMPI_nullValue;
   _data.value.uint64=0;
   _data.type=CMPI_null;
}

CmpiData::CmpiData(CMPISint8 d) {
   _data.state=CMPI_goodValue;
   _data.value.sint8=d;
   _data.type=CMPI_sint8;
}

CmpiData::CmpiData(CMPISint16 d) {
   _data.state=CMPI_goodValue;
   _data.value.sint16=d;
   _data.type=CMPI_sint16;
}

CmpiData::CmpiData(CMPISint32 d) {
   _data.state=CMPI_goodValue;
   _data.value.sint32=d;
   _data.type=CMPI_sint32;
}

CmpiData::CmpiData(CMPISint64 d) {
   _data.state=CMPI_goodValue;
   _data.value.sint64=d;
   _data.type=CMPI_sint64;
}

CmpiData::CmpiData(CMPIUint8 d) {
   _data.state=CMPI_goodValue;
   _data.value.uint8=d;
   _data.type=CMPI_uint8;
}

CmpiData::CmpiData(CMPIUint16 d) {
   _data.state=CMPI_goodValue;
   _data.value.uint16=d;
   _data.type=CMPI_uint16;
}

CmpiData::CmpiData(CMPIUint32 d) {
   _data.state=CMPI_goodValue;
   _data.value.uint32=d;
   _data.type=CMPI_uint32;
}

CmpiData::CmpiData(CMPIUint64 d) {
   _data.state=CMPI_goodValue;
   _data.value.uint64=d;
   _data.type=CMPI_uint64;
}

CmpiData::CmpiData(CMPIReal32 d) {
   _data.state=CMPI_goodValue;
   _data.value.real32=d;
   _data.type=CMPI_real32;
}

CmpiData::CmpiData(CMPIReal64 d) {
   _data.state=CMPI_goodValue;
   _data.value.real64=d;
   _data.type=CMPI_real64;
}

CmpiData::CmpiData(const CmpiString& d) {
   _data.state=CMPI_goodValue;
   _data.value.chars=(char*)d.charPtr();
   _data.type=CMPI_chars;
}

CmpiData::CmpiData(const char* d) {
  _data.state=CMPI_goodValue;
  _data.value.chars=(char*)d;
  _data.type=CMPI_chars;
}

CmpiData::CmpiData(const CmpiDateTime& d) {
   _data.state=CMPI_goodValue;
   _data.value.dateTime=d.getEnc();
   _data.type=CMPI_dateTime;
}

CmpiData::CmpiData(const CmpiArray& d) {
   _data.state=CMPI_goodValue;
   _data.value.array=d.getEnc();
   _data.type=((CMPIArrayFT*)d.getEnc()->ft)->getSimpleType(d.getEnc(),0) | CMPI_ARRAY;
}

CmpiData::CmpiData(const CmpiObjectPath& d) {
  _data.state=d.getEnc()==0?CMPI_nullValue:CMPI_goodValue;
  _data.value.ref=(CMPIObjectPath*)d.getEnc();
  _data.type=CMPI_ref;
}

CmpiData::CmpiData(const CmpiInstance& d) {
   _data.state=d.getEnc()==0?CMPI_nullValue:CMPI_goodValue;
   _data.value.inst=(CMPIInstance*)d.getEnc();
   _data.type=CMPI_instance;
}

CmpiData::CmpiData(const CmpiData& d) {
   _data=d._data;
}

CmpiData::~CmpiData() {
}

CmpiData& CmpiData::operator= (const CmpiData& rhs) {
   if (this == &rhs)
   {
      return *this;
   }

   _data=rhs._data;

   return *this;
}

#ifdef PEGASUS_CMPI_DATA_NEED_IMPLICIT_CONVERTERS

CmpiData::operator CmpiString() const {
   if (_data.type!=CMPI_string)
     throw CmpiStatus(CMPI_RC_ERR_TYPE_MISMATCH);
   else
      return CmpiString(_data.value.string);
}

CmpiData::operator const char* () const {
   if (_data.type!=CMPI_string)
      throw CmpiStatus(CMPI_RC_ERR_TYPE_MISMATCH);
   else
      return CmpiString(_data.value.string).charPtr();
}

CmpiData::operator CmpiDateTime() const {
   if (_data.type!=CMPI_dateTime)
      throw CmpiStatus(CMPI_RC_ERR_TYPE_MISMATCH);
   else
      return CmpiDateTime(_data.value.dateTime);
}

CmpiData::operator CMPISint8() const {
   if (_data.type!=CMPI_sint8)
      throw CmpiStatus(CMPI_RC_ERR_TYPE_MISMATCH);
   else
      return _data.value.sint8;
}
CmpiData::operator CMPISint16() const {
   if (_data.type!=CMPI_sint16)
      throw CmpiStatus(CMPI_RC_ERR_TYPE_MISMATCH);
   else
      return _data.value.sint16;
}

CmpiData::operator CMPISint32() const {
   if (_data.type!=CMPI_sint32)
      throw CmpiStatus(CMPI_RC_ERR_TYPE_MISMATCH);
   else
      return _data.value.sint32;
}

CmpiData::operator CMPISint64() const {
   if (_data.type!=CMPI_sint64)
      throw CmpiStatus(CMPI_RC_ERR_TYPE_MISMATCH);
   else
      return _data.value.sint64;
}

CmpiData::operator unsigned char() const {
   if (_data.type!=CMPI_uint8 && _data.type!=CMPI_boolean)
      throw CmpiStatus(CMPI_RC_ERR_TYPE_MISMATCH);
   if (_data.type==CMPI_uint8)
      return _data.value.uint8;
   else
      return _data.value.boolean;
}

CmpiData::operator unsigned short() const {
   if (_data.type!=CMPI_uint16 && _data.type!=CMPI_char16)
      throw CmpiStatus(CMPI_RC_ERR_TYPE_MISMATCH);
   if (_data.type==CMPI_uint16)
      return _data.value.uint16;
   else
      return _data.value.char16;
}

CmpiData::operator CMPIUint32() const {
   if (_data.type!=CMPI_uint32)
      throw CmpiStatus(CMPI_RC_ERR_TYPE_MISMATCH);
   else
      return _data.value.uint32;
}

CmpiData::operator CMPIUint64() const {
   if (_data.type!=CMPI_uint64)
      throw CmpiStatus(CMPI_RC_ERR_TYPE_MISMATCH);
   else
      return _data.value.uint64;
}

CmpiData::operator CMPIReal32() const {
   if (_data.type!=CMPI_real32)
      throw CmpiStatus(CMPI_RC_ERR_TYPE_MISMATCH);
   else
      return _data.value.real32;
}

CmpiData::operator CMPIReal64() const {
   if (_data.type!=CMPI_real64)
      throw CmpiStatus(CMPI_RC_ERR_TYPE_MISMATCH);
   else
      return _data.value.real64;
}

CmpiData::operator CmpiInstance() const{
   if (_data.type!=CMPI_instance)
      throw CmpiStatus(CMPI_RC_ERR_TYPE_MISMATCH);
   else return CmpiInstance(_data.value.inst);
}

CmpiData::operator CmpiObjectPath() const {
   if (_data.type!=CMPI_ref)
      throw CmpiStatus(CMPI_RC_ERR_TYPE_MISMATCH);
   else return CmpiObjectPath(_data.value.ref);
}

CmpiData::operator CmpiArray() const {
   if (!(_data.type&CMPI_ARRAY))
      throw CmpiStatus(CMPI_RC_ERR_TYPE_MISMATCH);
   else return CmpiArray(_data.value.array);
}

#endif /* PEGASUS_CMPI_DATA_NEED_IMPLICIT_CONVERTERS */

//==============================================================================
//
// Getters:
//
//==============================================================================

CMPIBoolean CmpiData::getBoolean() const
{
   if (_data.type != CMPI_boolean)
      throw CmpiStatus(CMPI_RC_ERR_TYPE_MISMATCH);
   else
      return _data.value.boolean;
}

CMPIUint8 CmpiData::getUint8() const
{
   if (_data.type != CMPI_uint8)
      throw CmpiStatus(CMPI_RC_ERR_TYPE_MISMATCH);
   else
      return _data.value.uint8;
}

CMPISint8 CmpiData::getSint8() const
{
   if (_data.type != CMPI_sint8)
      throw CmpiStatus(CMPI_RC_ERR_TYPE_MISMATCH);
   else
      return _data.value.sint8;
}

CMPIUint16 CmpiData::getUint16() const
{
   if (_data.type != CMPI_uint16)
      throw CmpiStatus(CMPI_RC_ERR_TYPE_MISMATCH);
   else
      return _data.value.uint16;
}

CMPISint16 CmpiData::getSint16() const
{
   if (_data.type != CMPI_sint16)
      throw CmpiStatus(CMPI_RC_ERR_TYPE_MISMATCH);
   else
      return _data.value.sint16;
}

CMPIUint32 CmpiData::getUint32() const
{
   if (_data.type != CMPI_uint32)
      throw CmpiStatus(CMPI_RC_ERR_TYPE_MISMATCH);
   else
      return _data.value.uint32;
}

CMPISint32 CmpiData::getSint32() const
{
   if (_data.type != CMPI_sint32)
      throw CmpiStatus(CMPI_RC_ERR_TYPE_MISMATCH);
   else
      return _data.value.sint32;
}

CMPIUint64 CmpiData::getUint64() const
{
   if (_data.type != CMPI_uint64)
      throw CmpiStatus(CMPI_RC_ERR_TYPE_MISMATCH);
   else
      return _data.value.uint64;
}

CMPISint64 CmpiData::getSint64() const
{
   if (_data.type != CMPI_sint64)
      throw CmpiStatus(CMPI_RC_ERR_TYPE_MISMATCH);
   else
      return _data.value.sint64;
}

CMPIReal32 CmpiData::getReal32() const
{
   if (_data.type != CMPI_real32)
      throw CmpiStatus(CMPI_RC_ERR_TYPE_MISMATCH);
   else
      return _data.value.real32;
}

CMPIReal64 CmpiData::getReal64() const
{
   if (_data.type != CMPI_real64)
      throw CmpiStatus(CMPI_RC_ERR_TYPE_MISMATCH);
   else
      return _data.value.real64;
}

CMPIChar16 CmpiData::getChar16() const
{
   if (_data.type != CMPI_char16)
      throw CmpiStatus(CMPI_RC_ERR_TYPE_MISMATCH);
   else
      return _data.value.char16;
}

CmpiString CmpiData::getString() const
{
   if (_data.type != CMPI_string)
      throw CmpiStatus(CMPI_RC_ERR_TYPE_MISMATCH);
   else
      return CmpiString(_data.value.string);
}

const char* CmpiData::getCString() const
{
   if (_data.type!=CMPI_string)
      throw CmpiStatus(CMPI_RC_ERR_TYPE_MISMATCH);
   else
      return CMGetCharPtr(_data.value.string);
}

CmpiDateTime CmpiData::getDateTime() const
{
   if (_data.type != CMPI_dateTime)
      throw CmpiStatus(CMPI_RC_ERR_TYPE_MISMATCH);
   else
      return CmpiDateTime(_data.value.dateTime);
}

CmpiArray CmpiData::getArray() const
{
   if (!(_data.type & CMPI_ARRAY))
      throw CmpiStatus(CMPI_RC_ERR_TYPE_MISMATCH);
   else
       return CmpiArray(_data.value.array);
}

CmpiInstance CmpiData::getInstance() const
{
   if (_data.type != CMPI_instance)
      throw CmpiStatus(CMPI_RC_ERR_TYPE_MISMATCH);
   else
       return CmpiInstance(_data.value.inst);
}

CmpiObjectPath CmpiData::getObjectPath() const
{
   if (_data.type != CMPI_ref)
      throw CmpiStatus(CMPI_RC_ERR_TYPE_MISMATCH);
   else
       return CmpiObjectPath(_data.value.ref);
}

//==============================================================================
//
// Setters:
//
//==============================================================================

void CmpiData::setBoolean (const CmpiBoolean d)
{
   _data.state=CMPI_goodValue;
   _data.value.boolean=d;
   _data.type=CMPI_boolean;
}

void CmpiData::setSint8 (const CMPISint8 d)
{
   _data.state=CMPI_goodValue;
   _data.value.sint8=d;
   _data.type=CMPI_sint8;
}

void CmpiData::setUint8 (const CMPIUint8 d)
{
   _data.state=CMPI_goodValue;
   _data.value.uint8=d;
   _data.type=CMPI_uint8;
}

void CmpiData::setSint16 (const CMPISint16 d)
{
   _data.state=CMPI_goodValue;
   _data.value.sint16=d;
   _data.type=CMPI_sint16;
}

void CmpiData::setUint16 (const CMPIUint16 d)
{
   _data.state=CMPI_goodValue;
   _data.value.uint16=d;
   _data.type=CMPI_uint16;
}

void CmpiData::setSint32 (const CMPISint32 d)
{
   _data.state=CMPI_goodValue;
   _data.value.sint32=d;
   _data.type=CMPI_sint32;
}

void CmpiData::setUint32 (const CMPIUint32 d)
{
   _data.state=CMPI_goodValue;
   _data.value.uint32=d;
   _data.type=CMPI_uint32;
}

void CmpiData::setSint64 (const CMPISint64 d)
{
   _data.state=CMPI_goodValue;
   _data.value.sint64=d;
   _data.type=CMPI_sint64;
}

void CmpiData::setReal32 (const CMPIReal32 d)
{
   _data.state=CMPI_goodValue;
   _data.value.real32=d;
   _data.type=CMPI_real32;
}

void CmpiData::setReal64 (const CMPIReal64 d)
{
   _data.state=CMPI_goodValue;
   _data.value.real64=d;
   _data.type=CMPI_real64;
}

void CmpiData::setChar16 (const CMPIChar16 d)
{
   _data.state=CMPI_goodValue;
   _data.value.char16=d;
   _data.type=CMPI_char16;
}

void CmpiData::setString (const CmpiString d)
{
   _data.state=CMPI_goodValue;
   _data.value.chars=(char*)d.charPtr();
   _data.type=CMPI_chars;
}

void CmpiData::setCString (const char* d)
{
   _data.state=CMPI_goodValue;
   _data.value.chars=(char*)d;
   _data.type=CMPI_chars;
}

void CmpiData::setDateTime (const CmpiDateTime d)
{
   _data.state=CMPI_goodValue;
   _data.value.dateTime=d.getEnc();
   _data.type=CMPI_dateTime;
}

void CmpiData::setArray (const CmpiArray d)
{
   _data.state=CMPI_goodValue;
   _data.value.array=d.getEnc();
   _data.type=((CMPIArrayFT*)d.getEnc()->ft)->getSimpleType(d.getEnc(),0) | CMPI_ARRAY;
}

void CmpiData::setInstance (const CmpiInstance d)
{
   _data.state=CMPI_goodValue;
   _data.value.inst=d.getEnc();
   _data.type=CMPI_instance;
}

void CmpiData::setObjectPath (const CmpiObjectPath d)
{
   _data.state=CMPI_goodValue;
   _data.value.ref=d.getEnc();
   _data.type=CMPI_ref;
}

////////////////////////////////////////////////////////////////////////////////

int CmpiData::isNullValue() const {
  return (_data.state & CMPI_nullValue);
}

int CmpiData::isNotFound() const {
  return (_data.state & CMPI_notFound);
}


//---------------------------------------------------
//--
//	CmpiBooleanData member functions
//--
//---------------------------------------------------

CmpiBooleanData::CmpiBooleanData(CMPIBoolean d) {
   _data.state=CMPI_goodValue;
   _data.value.boolean=d;
   _data.type=CMPI_boolean;
}


//---------------------------------------------------
//--
//	CmpiCharData member functions
//--
//---------------------------------------------------

CmpiCharData::CmpiCharData(CMPIChar16 d) {
   _data.state=CMPI_goodValue;
   _data.value.char16=d;
   _data.type=CMPI_char16;
}


//---------------------------------------------------
//--
//	CmpiInstance member functions
//--
//---------------------------------------------------

CmpiInstance::CmpiInstance(const CMPIInstance* newEnc) {
   this->enc=(void*)newEnc;
}

CMPIInstance *CmpiInstance::getEnc() const {
   return (CMPIInstance*)this->enc;
}

CmpiInstance::CmpiInstance() {
}

CmpiInstance::CmpiInstance(const CmpiObjectPath& op) {
   enc=makeInstance(CmpiProviderBase::getBroker(),op);
}

CmpiBoolean CmpiInstance::instanceIsA(const char *className) {
   return doInstanceIsA(CmpiProviderBase::getBroker(),className);
}

void *CmpiInstance::makeInstance(CMPIBroker *mb, const CmpiObjectPath& cop) {
   CMPIStatus rc={CMPI_RC_OK,NULL};


   void *inst=mb->eft->newInstance(mb,((CmpiObjectPath&)cop).getEnc(),&rc);
   if (rc.rc!=CMPI_RC_OK) throw CmpiStatus(rc);

   return inst;
}

CmpiBoolean CmpiInstance::doInstanceIsA(CMPIBroker *mb, const char *className) {
   CmpiObjectPath cop=getObjectPath();
   return cop.doClassPathIsA(mb,className);
}

CmpiData CmpiInstance::getProperty(const char* name) const{
   CmpiData d;
   CMPIStatus rc={CMPI_RC_OK,NULL};
   d._data=getEnc()->ft->getProperty(getEnc(),name,&rc);
   if (rc.rc!=CMPI_RC_OK && rc.rc!=CMPI_RC_ERR_NOT_FOUND) {
     if (rc.msg)
       throw CmpiStatus(rc);
     else
       throw CmpiStatus(rc.rc,name);
   }
   return CmpiData (d);
}

CmpiData CmpiInstance::getProperty(const int pos, CmpiString *name) {
   CmpiData d;
   CMPIStatus rc={CMPI_RC_OK,NULL};
   CMPIString *s;
   d._data=getEnc()->ft->getPropertyAt(getEnc(),pos,&s,&rc);
   if (rc.rc!=CMPI_RC_OK && rc.rc!=CMPI_RC_ERR_NOT_FOUND) {
     if (rc.msg)
     throw CmpiStatus(rc);
     else
       throw CmpiStatus(rc.rc,name->charPtr());
   }
   if (name) *name=CmpiString(s);
   return CmpiData (d);
};

unsigned int CmpiInstance::getPropertyCount() {
   CMPIStatus rc={CMPI_RC_OK,NULL};
   unsigned int c=getEnc()->ft->getPropertyCount(getEnc(),&rc);
   if (rc.rc!=CMPI_RC_OK) throw CmpiStatus(rc);
   return c;
}

void CmpiInstance::setProperty(const char* name, const CmpiData data) {
   CmpiData dt=CmpiData(data);
   CMPIStatus rc=getEnc()->ft->setProperty(getEnc(),name,
      dt._data.type!=CMPI_chars ? &dt._data.value : (CMPIValue*)dt._data.value.chars,
      dt._data.type);
   if (rc.rc!=CMPI_RC_OK) throw CmpiStatus(rc);
}


static const char * _nullkeys[] = {0};

void CmpiInstance::setPropertyFilter(const char** properties, const char** keys) {
  if (keys==0) keys = _nullkeys;
  CMPIStatus rc=getEnc()->ft->setPropertyFilter(getEnc(),properties,
						 keys);
  if (rc.rc!=CMPI_RC_OK) throw CmpiStatus(rc);
}

CmpiObjectPath CmpiInstance::getObjectPath() const {
   CMPIStatus rc={CMPI_RC_OK,NULL};
   CmpiObjectPath cop((CMPIObjectPath*)getEnc()->ft->getObjectPath(getEnc(),&rc));
   if (rc.rc!=CMPI_RC_OK) throw CmpiStatus(rc);
   return cop;
}


//---------------------------------------------------
//--
//	CmpiStatus member functions
//--
//---------------------------------------------------

CMPIStatus CmpiStatus::status() const {
   return st;
}
CmpiStatus::CmpiStatus(const CMPIrc rcp, const char *msg) {
   st.rc=rcp;
   st.msg=CMNewString(CmpiProviderBase::getBroker(),(char*)msg,NULL);
}

CMPIrc CmpiStatus::rc() const {
   return st.rc;
}

const char*  CmpiStatus::msg() const {
   return st.msg ? CMGetCharPtr(st.msg) : 0;
}

CmpiStatus::CmpiStatus() {
   st.rc=CMPI_RC_OK;
   st.msg=NULL;
}

CmpiStatus::CmpiStatus(const CMPIrc rcp) {
   st.rc=rcp;
   st.msg=NULL;
}

CmpiStatus::CmpiStatus(const CMPIStatus stat) {
   st=stat;
}

//---------------------------------------------------
//--
//	CmpiObjectPath member functions
//--
//---------------------------------------------------

CmpiObjectPath::CmpiObjectPath(const char *ns, const char *cls) {
   enc=makeObjectPath(CmpiProviderBase::getBroker(),ns,cls);
}

CmpiObjectPath::CmpiObjectPath(const CmpiString &ns, const char *cls) {
   enc=makeObjectPath(CmpiProviderBase::getBroker(),ns,cls);
}

CmpiObjectPath::CmpiObjectPath(CMPIObjectPath* c)
     : CmpiObject((void*)c) {
}

CMPIObjectPath *CmpiObjectPath::getEnc() const {
   return (CMPIObjectPath*)enc;
}

CmpiBoolean CmpiObjectPath::classPathIsA(const char *className) const {
   return doClassPathIsA(CmpiProviderBase::getBroker(),className);
}

void CmpiObjectPath::setHostname(CmpiString hn) {
   setHostname(hn.charPtr());
}

void CmpiObjectPath::setNameSpace(CmpiString ns) {
   setNameSpace(ns.charPtr());
}

void CmpiObjectPath::setClassName(CmpiString hn) {
   setClassName(hn.charPtr());
}

void *CmpiObjectPath::makeObjectPath(CMPIBroker *mb, const char *ns, const char *cls) {
   CMPIStatus rc={CMPI_RC_OK,NULL};
   void *op=mb->eft->newObjectPath(mb,ns,cls,&rc);
   if (rc.rc!=CMPI_RC_OK) throw CmpiStatus(rc);
   return op;
}

void *CmpiObjectPath::makeObjectPath(CMPIBroker *mb, const CmpiString& ns, const char *cls) {
   CMPIStatus rc={CMPI_RC_OK,NULL};
   void *op=mb->eft->newObjectPath(mb,CMGetCharPtr(ns.getEnc()),cls,&rc);
   if (rc.rc!=CMPI_RC_OK) throw CmpiStatus(rc);
   return op;
}

CmpiBoolean CmpiObjectPath::doClassPathIsA(CMPIBroker *mb, const char *className) const {
   CMPIStatus rc = {CMPI_RC_OK,NULL};
   CmpiBoolean bv=mb->eft->classPathIsA(mb,getEnc(),className,&rc);
   if (rc.rc!=CMPI_RC_OK) throw CmpiStatus(rc);
   return bv;
}

CmpiString CmpiObjectPath::getNameSpace() const{
   CMPIStatus rc={CMPI_RC_OK,NULL};
   CMPIString *s=getEnc()->ft->getNameSpace(getEnc(),&rc);
   if (rc.rc!=CMPI_RC_OK) throw CmpiStatus(rc);
   return CmpiString(s);
}

void CmpiObjectPath::setNameSpace(const char* ns) {
   CMPIStatus rc=getEnc()->ft->setNameSpace(getEnc(),ns);
   if (rc.rc!=CMPI_RC_OK) throw CmpiStatus(rc);
}

CmpiString CmpiObjectPath::getHostname() const {
   CMPIStatus rc={CMPI_RC_OK,NULL};
   CMPIString *s=getEnc()->ft->getHostname(getEnc(),&rc);
   if (rc.rc!=CMPI_RC_OK) throw CmpiStatus(rc);
   return CmpiString(s);
}

void CmpiObjectPath::setHostname(const char* hn) {
   CMPIStatus rc=getEnc()->ft->setHostname(getEnc(),hn);
   if (rc.rc!=CMPI_RC_OK) throw CmpiStatus(rc);
}

CmpiString CmpiObjectPath::getClassName() const {
   CMPIStatus rc={CMPI_RC_OK,NULL};
   CMPIString *s=getEnc()->ft->getClassName(getEnc(),&rc);
   if (rc.rc!=CMPI_RC_OK) throw CmpiStatus(rc);
   return CmpiString(s);
}

void CmpiObjectPath::setClassName(const char* cn) {
   CMPIStatus rc=getEnc()->ft->setClassName(getEnc(),cn);
   if (rc.rc!=CMPI_RC_OK) throw CmpiStatus(rc);
}

CmpiData CmpiObjectPath::getKey(const char* name) const {
   CmpiData d;
   CMPIStatus rc={CMPI_RC_OK,NULL};
   d._data=getEnc()->ft->getKey(getEnc(),name,&rc);
   if (rc.rc!=CMPI_RC_OK) throw CmpiStatus(rc);
   return CmpiData (d);
}

unsigned int CmpiObjectPath::getKeyCount() const {
   CMPIStatus rc={CMPI_RC_OK,NULL};
   unsigned int c=getEnc()->ft->getKeyCount(getEnc(),&rc);
   if (rc.rc!=CMPI_RC_OK) throw CmpiStatus(rc);
   return c;
}

CmpiData CmpiObjectPath::getKey(const int pos, CmpiString *name) const{
   CmpiData d;
   CMPIStatus rc={CMPI_RC_OK,NULL};
   CMPIString *s;
   d._data=getEnc()->ft->getKeyAt(getEnc(),(int)pos,&s,&rc);
   if (rc.rc!=CMPI_RC_OK) throw CmpiStatus(rc);
   if (name) *name=CmpiString(s);
   return CmpiData (d);
}

void CmpiObjectPath::setKey(const char* name, const CmpiData data) {
   CmpiData dt=CmpiData(data);
   CMPIStatus rc=getEnc()->ft->addKey(
      getEnc(),name,
         dt._data.type!=CMPI_chars ? &dt._data.value : (CMPIValue*)dt._data.value.chars,
         dt._data.type);
   if (rc.rc!=CMPI_RC_OK) throw CmpiStatus(rc);
}


//---------------------------------------------------
//--
//	CmpiResult member functions
//--
//---------------------------------------------------

CmpiResult::CmpiResult() {
}

CmpiResult::CmpiResult(CMPIResult* r)
      : CmpiObject((void*)r) {
}

CMPIResult *CmpiResult::getEnc() const {
   return (CMPIResult*)enc;
}

void CmpiResult::returnData(const CmpiData& d) {
  CMPIStatus rc=getEnc()->ft->returnData(getEnc(),
   d._data.type!=CMPI_chars ? &d._data.value : (CMPIValue*)d._data.value.chars,
   d._data.type);
  if (rc.rc!=CMPI_RC_OK) throw CmpiStatus(rc);
}

void CmpiResult::returnData(const CmpiInstance& d) {
   CMPIStatus rc=getEnc()->ft->returnInstance(getEnc(),d.getEnc());
   if (rc.rc!=CMPI_RC_OK) throw CmpiStatus(rc);
}

void CmpiResult::returnData(const CmpiObjectPath& d) {
   CMPIStatus rc=getEnc()->ft->returnObjectPath(getEnc(),d.getEnc());
   if (rc.rc!=CMPI_RC_OK) throw CmpiStatus(rc);
}

void CmpiResult::returnDone() {
   CMPIStatus rc=getEnc()->ft->returnDone(getEnc());
   if (rc.rc!=CMPI_RC_OK) throw CmpiStatus(rc);
}



//---------------------------------------------------
//--
//	CmpiBroker member functions
//--
//---------------------------------------------------

CmpiBroker::CmpiBroker(CMPIBroker* b)
         : CmpiObject((void*)b) {
}

CMPIBroker *CmpiBroker::getEnc() const {
   return (CMPIBroker*)enc;
}

CmpiContext CmpiBroker::prepareAttachThread(const CmpiContext& ctx)
{
  CMPIContext* cctx=
    getEnc()->bft->prepareAttachThread(getEnc(),ctx.getEnc());
  return CmpiContext(cctx);
}

void CmpiBroker::attachThread(const CmpiContext& ctx)
{
  CMPIStatus rc=getEnc()->bft->attachThread(getEnc(),ctx.getEnc());
  if (rc.rc!=CMPI_RC_OK) throw CmpiStatus(rc);
}

void CmpiBroker::detachThread(const CmpiContext& ctx)
{
  CMPIStatus rc=getEnc()->bft->detachThread(getEnc(),ctx.getEnc());
  if (rc.rc!=CMPI_RC_OK) throw CmpiStatus(rc);
}


void CmpiBroker::deliverIndication(const CmpiContext& ctx, const char* ns,
                                   const CmpiInstance& inst)
{
  CMPIStatus rc=
    getEnc()->bft->deliverIndication(getEnc(),ctx.getEnc(),ns,inst.getEnc());
  if (rc.rc!=CMPI_RC_OK) throw CmpiStatus(rc);
}

     // class 1 services
CmpiEnumeration CmpiBroker::enumInstanceNames(const CmpiContext& ctx,
                                              const CmpiObjectPath& cop)
{
   CMPIStatus rc={CMPI_RC_OK,NULL};
   CMPIEnumeration* en=getEnc()->bft->enumInstanceNames
      (getEnc(),ctx.getEnc(),cop.getEnc(),&rc);
   if (rc.rc!=CMPI_RC_OK) throw CmpiStatus(rc);
   return CmpiEnumeration(en);
}

CmpiInstance CmpiBroker::getInstance(const CmpiContext& ctx,
                         const CmpiObjectPath& cop,
                         const char** properties)
{
   CMPIStatus rc={CMPI_RC_OK,NULL};
   CMPIInstance* ci=getEnc()->bft->getInstance
     (getEnc(),ctx.getEnc(),cop.getEnc(),properties,&rc);
   if (rc.rc!=CMPI_RC_OK) throw CmpiStatus(rc);
   return CmpiInstance(ci);
}


     // class 2 services
CmpiObjectPath CmpiBroker::createInstance(const CmpiContext& ctx,
                              const CmpiObjectPath& cop,
                              const CmpiInstance& inst)
{
   CMPIStatus rc={CMPI_RC_OK,NULL};
   CMPIObjectPath* co=getEnc()->bft->createInstance
     (getEnc(),ctx.getEnc(),cop.getEnc(),inst.getEnc(),&rc);
   if (rc.rc!=CMPI_RC_OK) throw CmpiStatus(rc);
   return CmpiObjectPath(co);
}

void CmpiBroker::setInstance(const CmpiContext& ctx, const CmpiObjectPath& cop,
                             const CmpiInstance& inst, const char** properties)
{
#ifdef CMPI_VER_100
   CMPIStatus rc=getEnc()->bft->modifyInstance
     (getEnc(),ctx.getEnc(),cop.getEnc(),inst.getEnc(), properties);
#else
   CMPIStatus rc=getEnc()->bft->setInstance
     (getEnc(),ctx.getEnc(),cop.getEnc(),inst.getEnc(), properties);
#endif
   if (rc.rc!=CMPI_RC_OK) throw CmpiStatus(rc);
}

void CmpiBroker::deleteInstance(const CmpiContext& ctx, const CmpiObjectPath& cop)
{
   CMPIStatus rc=getEnc()->bft->deleteInstance
     (getEnc(),ctx.getEnc(),cop.getEnc());
   if (rc.rc!=CMPI_RC_OK) throw CmpiStatus(rc);
}

CmpiEnumeration CmpiBroker::execQuery(const CmpiContext& ctx,
                          const  CmpiObjectPath& cop,
                          const char* query, const char* language)
{
   throw CmpiStatus(CMPI_RC_ERR_NOT_SUPPORTED);
   return NULL;
}


CmpiEnumeration CmpiBroker::enumInstances(const CmpiContext& ctx,
                              const CmpiObjectPath& cop,
                              const char** properties)
{
   CMPIStatus rc={CMPI_RC_OK,NULL};
   CMPIEnumeration* en=getEnc()->bft->enumInstances
      (getEnc(),ctx.getEnc(),cop.getEnc(),properties,&rc);
   if (rc.rc!=CMPI_RC_OK) throw CmpiStatus(rc);
   return CmpiEnumeration(en);
}

CmpiEnumeration CmpiBroker::associators(const CmpiContext& ctx,
                            const CmpiObjectPath& cop,
                            const char* assocClass, const char* resultClass,
		            const char* role, const char* resultRole,
			    const char** properties)
{
   throw CmpiStatus(CMPI_RC_ERR_NOT_SUPPORTED);
   return NULL;
}

CmpiEnumeration CmpiBroker::associatorNames(const CmpiContext& ctx,
                                const CmpiObjectPath& cop,
                                const char* assocClass, const char* resultClass,
		                const char* role, const char* resultRole)
{
   throw CmpiStatus(CMPI_RC_ERR_NOT_SUPPORTED);
   return NULL;
}

CmpiEnumeration CmpiBroker::references(const CmpiContext& ctx,
                           const CmpiObjectPath& cop,
                           const char* resultClass, const char* role,
			   const char** properties)
{
   throw CmpiStatus(CMPI_RC_ERR_NOT_SUPPORTED);
   return NULL;
}

CmpiEnumeration CmpiBroker::referenceNames(const CmpiContext& ctx,
                               const CmpiObjectPath& cop,
                               const char* resultClass, const char* role)
{
   throw CmpiStatus(CMPI_RC_ERR_NOT_SUPPORTED);
   return NULL;
}

CmpiData CmpiBroker::invokeMethod(const CmpiContext& ctx, const CmpiObjectPath& cop,
                 const char* methName, const CmpiArgs& in, CmpiArgs& out)
{
   throw CmpiStatus(CMPI_RC_ERR_NOT_SUPPORTED);
   return CmpiData();
}

void CmpiBroker::setProperty(const CmpiContext& ctx, const CmpiObjectPath& cop,
                 const char* name, const CmpiData& data)
{
   throw CmpiStatus(CMPI_RC_ERR_NOT_SUPPORTED);
}

CmpiData CmpiBroker::getProperty(const CmpiContext& ctx, const CmpiObjectPath& cop,
                  const char* name)
{
   throw CmpiStatus(CMPI_RC_ERR_NOT_SUPPORTED);
   return CmpiData();
}




//---------------------------------------------------
//--
//	CmpiString member functions
//--
//---------------------------------------------------




CmpiString::CmpiString(const CmpiString& s) {
  enc=CMNewString(CmpiProviderBase::getBroker(),(char*)s.charPtr(),NULL);
}

CmpiString::CmpiString(CMPIString* c) {
   enc=c;
}

CMPIString *CmpiString::getEnc() const {
   return (CMPIString*)enc;
}

CmpiString::CmpiString() {
   enc=NULL;
}
const char* CmpiString::charPtr() const {
   if (getEnc())
      return (const char*)getEnc()->hdl;
   else
      return NULL;
}

CmpiBoolean CmpiString::equals(const char *str) const {
   return (strcmp(charPtr(),str)==0);
}

CmpiBoolean CmpiString::equals(const CmpiString& str) const {
   return (strcmp(charPtr(),str.charPtr())==0);
}

CmpiBoolean CmpiString::equalsIgnoreCase(const char *str) const {
   return (strcasecmp(charPtr(),str)==0);
}

CmpiBoolean CmpiString::equalsIgnoreCase(const CmpiString& str) const {
   return (strcasecmp(charPtr(),str.charPtr())==0);
}


//---------------------------------------------------
//--
//	CmpiArgs member functions
//--
//---------------------------------------------------


CmpiArgs::CmpiArgs(CMPIArgs* newEnc) {
   this->enc=newEnc;
}

CmpiArgs::CmpiArgs() {
   this->enc=makeArgs(CmpiProviderBase::getBroker());
}

CMPIArgs *CmpiArgs::getEnc() const {
   return (CMPIArgs*)enc;
}

void *CmpiArgs::makeArgs(CMPIBroker *mb) {
   CMPIStatus rc={CMPI_RC_OK,NULL};
   void *args=mb->eft->newArgs(mb,&rc);
   if (rc.rc!=CMPI_RC_OK) throw CmpiStatus(rc);
   return args;
}

void CmpiArgs::setArg(const char* name, const CmpiData& data) {
   CMPIStatus rc=getEnc()->ft->addArg(getEnc(),name,
         data._data.type!=CMPI_chars ? (CMPIValue*)&data._data.value
	                            : (CMPIValue*)data._data.value.chars,
         data._data.type);
   if (rc.rc!=CMPI_RC_OK) throw CmpiStatus(rc);
}

CmpiData CmpiArgs::getArg(const int pos, CmpiString *name) const {
   CmpiData d;
   CMPIStatus rc={CMPI_RC_OK,NULL};
   CMPIString *s;
   d._data=getEnc()->ft->getArgAt(getEnc(),(int)pos,&s,&rc);
   if (rc.rc!=CMPI_RC_OK && rc.rc!=CMPI_RC_ERR_NOT_FOUND) {
     if (rc.msg)
       throw CmpiStatus(rc);
     else
       throw CmpiStatus(rc.rc,name->charPtr());
   }
   if (name) *name=CmpiString(s);
   return CmpiData (d);
}

CmpiData CmpiArgs::getArg(const char* name) const {
   CmpiData d;
   CMPIStatus rc={CMPI_RC_OK,NULL};
   d._data=getEnc()->ft->getArg(getEnc(),name,&rc);
   if (rc.rc!=CMPI_RC_OK && rc.rc!=CMPI_RC_ERR_NOT_FOUND) {
     if (rc.msg)
       throw CmpiStatus(rc);
     else
       throw CmpiStatus(rc.rc,name);
   }
   return CmpiData (d);
}

unsigned int CmpiArgs::getArgCount() const {
   CMPIStatus rc={CMPI_RC_OK,NULL};
   unsigned int c=getEnc()->ft->getArgCount(getEnc(),&rc);
   if (rc.rc!=CMPI_RC_OK) throw CmpiStatus(rc);
   return c;
}



//---------------------------------------------------
//--
//	CmpiObject member functions
//--
//---------------------------------------------------


CmpiObject::CmpiObject()
   : enc(0) {
 }

CmpiObject::CmpiObject(const void* newEnc) {
   this->enc=(void*)newEnc;
}

CmpiBoolean CmpiObject::isNull() const {
   return (this->enc==NULL);
}

CmpiString CmpiObject::toString() {
   return doToString(CmpiProviderBase::getBroker());
}

CmpiBoolean CmpiObject::isA(const char *typeName) const  {
   return doIsA(CmpiProviderBase::getBroker(),typeName);
}

CmpiString CmpiObject::doToString(CMPIBroker *mb) {
   CMPIStatus rc={CMPI_RC_OK,NULL};
   CMPIString *str=mb->eft->toString(mb,enc,&rc);
   if (rc.rc!=CMPI_RC_OK) throw CmpiStatus(rc);
   return CmpiString(str);
}

CmpiBoolean CmpiObject::doIsA(CMPIBroker *mb, const char *typeName) const {
   CMPIStatus rc={CMPI_RC_OK,NULL};
   CmpiBoolean bv=mb->eft->isOfType(mb,enc,typeName,&rc);
   if (rc.rc!=CMPI_RC_OK) throw CmpiStatus(rc);
   return bv;
}

//---------------------------------------------------
//--
//	CmpiEnumeration member functions
//--
//---------------------------------------------------

CmpiEnumeration::CmpiEnumeration(CMPIEnumeration* newEnc) {
   this->enc=newEnc;
}

CMPIEnumeration *CmpiEnumeration::getEnc() const {
   return (CMPIEnumeration*)this->enc;
}

CmpiEnumeration::CmpiEnumeration() {
}

CmpiBoolean CmpiEnumeration::hasNext() {
   CMPIStatus rc={CMPI_RC_OK,NULL};
   CmpiBoolean bv=getEnc()->ft->hasNext(getEnc(),&rc);
   if (rc.rc!=CMPI_RC_OK) throw CmpiStatus(rc);
   return bv;
}

CmpiData CmpiEnumeration::getNext() {
   CMPIStatus rc={CMPI_RC_OK,NULL};
   CMPIData d=getEnc()->ft->getNext(getEnc(),&rc);
   if (rc.rc!=CMPI_RC_OK) throw CmpiStatus(rc);
   return CmpiData(d);
}

CmpiData CmpiEnumeration::toArray() {
   CMPIStatus rc={CMPI_RC_OK,NULL};
   CMPIArray* a=getEnc()->ft->toArray(getEnc(),&rc);
   if (rc.rc!=CMPI_RC_OK) throw CmpiStatus(rc);
   return CmpiData(CmpiArray(a));
}


//---------------------------------------------------
//--
//	CmpiContext member functions
//--
//---------------------------------------------------



const char *CmpiContext::invocationFlags=CMPIInvocationFlags;

CmpiContext::CmpiContext() {
}

CmpiContext::CmpiContext(CMPIContext* c)
         : CmpiObject((void*)c) {
}

CMPIContext *CmpiContext::getEnc() const {
   return (CMPIContext*)enc;
}

CmpiData CmpiContext::getEntry(const char* name) const{
   CmpiData d;
   CMPIStatus rc={CMPI_RC_OK,NULL};
   d._data=getEnc()->ft->getEntry(getEnc(),name,&rc);
   if (rc.rc!=CMPI_RC_OK) throw CmpiStatus(rc);
   return CmpiData (d);
}


//---------------------------------------------------
//--
//	CmpiSelectExp member functions
//--
//---------------------------------------------------


CmpiSelectExp::CmpiSelectExp(const CMPISelectExp* newEnc) {
   this->enc=(void*)newEnc;
}

CMPISelectExp *CmpiSelectExp::getEnc() const {
   return (CMPISelectExp*)this->enc;
}

CmpiSelectExp::CmpiSelectExp() {
}



//---------------------------------------------------
//--
//	CmpiDateTime member functions
//--
//---------------------------------------------------

   /** Constructor from CMPI type
   */
CmpiDateTime::CmpiDateTime(const CMPIDateTime* newEnc) {
   this->enc=(void*)newEnc;
}

CmpiDateTime::CmpiDateTime() {
   this->enc=makeDateTime(CmpiProviderBase::getBroker());
}

CmpiDateTime::CmpiDateTime(const CmpiDateTime& original)
    : CmpiObject(0) {
   enc=makeDateTime(CmpiProviderBase::getBroker(),
                    ((CmpiDateTime&)original).getDateTime(),
                    ((CmpiDateTime&)original).isInterval());
}

CmpiDateTime::CmpiDateTime(const char* utcTime) {
   enc=makeDateTime(CmpiProviderBase::getBroker(),utcTime);
}

CmpiDateTime::CmpiDateTime(const CMPIUint64 binTime, const CmpiBoolean interval) {
   enc=makeDateTime(CmpiProviderBase::getBroker(),binTime,interval);
}

CMPIDateTime *CmpiDateTime::getEnc() const {
   return (CMPIDateTime*)enc;
}

void *CmpiDateTime::makeDateTime(CMPIBroker *mb) {
   CMPIStatus rc={CMPI_RC_OK,NULL};
   void *dt=mb->eft->newDateTime(mb,&rc);
   if (rc.rc!=CMPI_RC_OK) throw CmpiStatus(rc);
   return dt;
}

void *CmpiDateTime::makeDateTime(CMPIBroker *mb, const char* utcTime) {
   CMPIStatus rc={CMPI_RC_OK,NULL};
   void *dt=mb->eft->newDateTimeFromChars(mb,(char*)utcTime,&rc);
   if (rc.rc!=CMPI_RC_OK) throw CmpiStatus(rc);
   return dt;
}

void *CmpiDateTime::makeDateTime(CMPIBroker *mb, const CMPIUint64 binTime,
                                 const CmpiBoolean interval) {
   CMPIStatus rc={CMPI_RC_OK,NULL};
   void *dt=mb->eft->newDateTimeFromBinary(mb,binTime,interval,&rc);
   if (rc.rc!=CMPI_RC_OK) throw CmpiStatus(rc);
   return dt;
}

CmpiBoolean CmpiDateTime::isInterval() const{
   CMPIStatus rc={CMPI_RC_OK,NULL};
   CmpiBoolean bv=getEnc()->ft->isInterval(getEnc(),&rc);
   if (rc.rc!=CMPI_RC_OK) throw CmpiStatus(rc);
   return bv;
}

CMPIUint64 CmpiDateTime::getDateTime() const{
   CMPIStatus rc={CMPI_RC_OK,NULL};
   CMPIUint64 rv=getEnc()->ft->getBinaryFormat(getEnc(),&rc);
   if (rc.rc!=CMPI_RC_OK) throw CmpiStatus(rc);
   return rv;
};


CmpiBooleanData CmpiTrue(true);
CmpiBooleanData CmpiFalse(false);

//-----------------------------------------------------------
//--
//      ProviderBase
//--
//-----------------------------------------------------------

#ifdef CMPI_VER_100
static  CMPIBroker __providerBaseBroker = {0,0,0,0};
#else
static CMPIBroker __providerBaseBroker = {0,0,0};
#endif

CmpiProviderBase::CmpiProviderBase() {
  useCount=0;
  baseMI=0;
}

CmpiProviderBase::~CmpiProviderBase() {
}

void CmpiProviderBase::
  incUseCount()
{
  useCount++;
}

int CmpiProviderBase::
  decUseCount()
{
  return --useCount;
}

void CmpiProviderBase::
  setBaseMI(CmpiBaseMI* aBaseMI)
{
  baseMI = aBaseMI;
}

CmpiBaseMI* CmpiProviderBase::
   getBaseMI()
{
  return baseMI;
}

CMPIBroker* CmpiProviderBase::
   getBroker()
{
  return &__providerBaseBroker;
}

void CmpiProviderBase::
    setBroker(const CMPIBroker *mb)
{
  if (mb) {
    __providerBaseBroker.hdl = mb->hdl;
    __providerBaseBroker.bft = mb->bft;
    __providerBaseBroker.eft = mb->eft;
  }
}

No CVS admin address has been configured
Powered by
ViewCVS 0.9.2