(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.60, Tue Sep 30 10:04:32 2014 UTC (9 years, 8 months ago) by karl
Branch: MAIN
CVS Tags: RELEASE_2_14_1, RELEASE_2_14_0-RC2, RELEASE_2_14_0-RC1, RELEASE_2_14_0, RELEASE_2_14-root, RELEASE_2_14-branch, HEAD
Changes since 1.59: +4 -3 lines
BUG#: 9721
TITLE: CIMOM refuses EmbeddedObject with unknown class

DESCRIPTION: Modify NewInstance to ignore nonexistent classes and create a new type of property the user-defined property. This allows
instances to be created without requiring that a class exist.

//%LICENSE////////////////////////////////////////////////////////////////
//
// Licensed to The Open Group (TOG) under one or more contributor license
// agreements.  Refer to the OpenPegasusNOTICE.txt file distributed with
// this work for additional information regarding copyright ownership.
// Each contributor licenses this file to you under the OpenPegasus Open
// Source License; you may not use this file except in compliance with the
// License.
//
// 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 "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 terminating)
{
    try
    {
        CMPIInstanceMI *mi=( CMPIInstanceMI*)vi;
        CmpiContext ctx((CMPIContext*)eCtx);
        CmpiStatus rc(CMPI_RC_OK);
        CmpiBaseMI* cmi = reinterpret_cast<CmpiBaseMI*>(mi->hdl);
        if (!terminating)
        {
            if (cmi->isUnloadable())
            {
                if (cmi->getProviderBase() &&
                    cmi->getProviderBase()->decUseCount()==0)
                {
                    rc=cmi->cleanup(ctx);
                    if (rc.rc() == CMPI_RC_OK)
                    {
                        cmi->getProviderBase()->setBaseMI(0);
                        cmi->setProviderBase(0);
                        delete cmi;
                    }
                    else
                    {
                        /* some error occured, do NOT delete the MI
                           increase MI count again
                        */
                        cmi->getProviderBase()->incUseCount();
                    }
                }
            }
            else
            {
                rc = CmpiStatus(CMPI_RC_ERR_NOT_SUPPORTED);
            }
        }
        else
        {
            if (cmi->getProviderBase() &&
                cmi->getProviderBase()->decUseCount()==0)
            {
                rc=cmi->cleanup(ctx);
                /* the CMPI 2.0 spec says that cleanup function can return
                   the following errors:
                   CMPI_RC_OK - Operation successful.
                   CMPI_RC_ERR_FAILED - Unspecific error occurred.
                   CMPI_RC_DO_NOT_UNLOAD and CMPI_RC_NEVER_UNLOAD - need to be
                   ignored in the terminating case, CIM server is going down
                   anyway
                */
                if (rc.rc() != CMPI_RC_ERR_FAILED)
                {
                    cmi->getProviderBase()->setBaseMI(0);
                    cmi->setProviderBase(0);
                    delete cmi;
                    rc = CmpiStatus(CMPI_RC_OK);
                }
                else
                {
                    /* give the provider some grace on shutdown,
                    the MI will not be cleaned up in this case, but as the CIM
                    Server is shutting down anyway, that does not hurt */
                    cmi->getProviderBase()->incUseCount();
                }
            }
        }
        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)
    {
    // KS_FUTURE these are pretty worthless.  Should not be trace??
#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 CMPISelectExp* eSe,
    const char* ns,
    const CMPIObjectPath* eCop,
    const char* user)
{
    try
    {
        const CmpiContext ctx((CMPIContext*)eCtx);
        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,
            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 CMPISelectExp* eSe,
    const char* ns,
    const CMPIObjectPath* eCop)
{
    try
    {
        const CmpiContext ctx((CMPIContext*)eCtx);
        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,
            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 CMPISelectExp* eSe,
    const char* clsName,
    const CMPIObjectPath* eCop,
    CMPIBoolean first)
{
    try
    {
        const CmpiContext ctx((CMPIContext*)eCtx);
        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,
            se,
            clsName,
            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 CMPISelectExp* eSe,
    const char* clsName,
    const CMPIObjectPath* eCop,
    CMPIBoolean last)
{
    try
    {
        const CmpiContext ctx((CMPIContext*)eCtx);
        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,
            se,
            clsName,
            cop,
            last).status();
    }
    catch (const CmpiStatus& stat)
    {
#ifdef PEGASUS_DEBUG
        cerr << "caught status :" << stat.rc() << " "  << stat.msg() << endl;
#endif
        return stat.status();
    }
}

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

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


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

CmpiStatus CmpiIndicationMI::authorizeFilter(
    const CmpiContext& ctx,
    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,
    const CmpiSelectExp& se,
    const char* ns,
    const CmpiObjectPath& op)
{
    return CmpiStatus(CMPI_RC_ERR_NOT_SUPPORTED);
}

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

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

CmpiStatus CmpiIndicationMI::enableIndications
      (const CmpiContext& ctx)
{
  return CmpiStatus(CMPI_RC_ERR_NOT_SUPPORTED);
}

CmpiStatus CmpiIndicationMI::disableIndications
      (const CmpiContext& ctx)
{
  return CmpiStatus(CMPI_RC_ERR_NOT_SUPPORTED);
}

//---------------------------------------------------
//--
//  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[](CMPICount idx) const
{
    if (idx >= size())
    {
        throw CmpiStatus(CMPI_RC_ERR_NO_SUCH_PROPERTY);
    }
    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};
    CMPIType arType=CMPI_null;
    arType = ar.getEnc()->ft->getSimpleType(ar.getEnc(),&rc);
    if (arType != v._data.type)
    {
        if (!(  ((arType == CMPI_boolean) && (v._data.type == CMPI_uint8))
            || ((arType == CMPI_char16)  && (v._data.type == CMPI_uint16))
            )
            )
        {
            throw CmpiStatus(CMPI_RC_ERR_TYPE_MISMATCH);
        }
    }
    if (arType == CMPI_chars)
    {
        rc=ar.getEnc()->ft->setElementAt(
            ar.getEnc(),
            idx,
            (CMPIValue*)v._data.value.chars,
            arType);
    }
    else
    {
    rc=ar.getEnc()->ft->setElementAt(
        ar.getEnc(),
        idx,
        (CMPIValue*)&v._data.value,
        arType);
    }
    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();
}

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

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

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

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

//---------------------------------------------------
//--
//  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.string=d.getEnc();
    _data.type=CMPI_string;
}

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)
{
    CMPIArray *array = d.getEnc();

    if (array)
    {
        _data.state=CMPI_goodValue;
        _data.value.array=array;
        _data.type=(array->ft)->getSimpleType(array,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_chars)
    {
        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) &&( _data.type != CMPI_uint8))
    {
        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) && (_data.type != CMPI_uint16))
    {
        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_chars)
    {
        throw CmpiStatus(CMPI_RC_ERR_TYPE_MISMATCH);
    }
    else
    {
        return _data.value.chars;
    }
}

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::setUint64(const CMPIUint64 d)
{
    _data.state=CMPI_goodValue;
    _data.value.uint64=d;
    _data.type=CMPI_uint64;
}

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.string=d.getEnc();
    _data.type=CMPI_string;
}

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);
}

CMPIType CmpiData::getType() const
{
    return _data.type;
}

//---------------------------------------------------
//--
//  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) const
{
    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) const
{
    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_NO_SUCH_PROPERTY))
    {
        if (rc.msg)
        {
            throw CmpiStatus(rc);
        }
        else
        {
            throw CmpiStatus(rc.rc,name);
        }
    }
    return CmpiData(d);
}

CmpiData CmpiInstance::getProperty(const int pos, CmpiString *name) const
{
    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() const
{
    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 ? CMGetCharsPtr(st.msg,NULL) : 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,CMGetCharsPtr(ns.getEnc(),NULL),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->enumerateInstanceNames(
        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->enumerateInstances(
        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(const char *s)
{
    enc=CMNewString(CmpiProviderBase::getBroker(),(char*)s,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()
{
    CMPIEnumeration *enc = getEnc ();
    if (!enc)
    {
        throw CmpiStatus(CMPI_RC_ERR_INVALID_HANDLE);
    }
    CMPIStatus rc={CMPI_RC_OK,NULL};
    CmpiBoolean bv=enc->ft->hasNext(enc,&rc);
    if (rc.rc != CMPI_RC_OK)
    {
        throw CmpiStatus(rc);
    }
    return bv;
}

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

CmpiData CmpiEnumeration::toArray()
{
    CMPIEnumeration *enc = getEnc ();
    if (!enc)
    {
        throw CmpiStatus(CMPI_RC_ERR_INVALID_HANDLE);
    }
    CMPIStatus rc={CMPI_RC_OK,NULL};
    CMPIArray* a=enc->ft->toArray(enc,&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(),
        original.getDateTime(),
        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
{
    if (!enc)
    {
        throw CmpiStatus(CMPI_RC_ERR_INVALID_HANDLE);
    }
    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
{
    if (!enc)
    {
        throw CmpiStatus(CMPI_RC_ERR_INVALID_HANDLE);
    }
    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_200
 static  CMPIBroker __providerBaseBroker = {0,0,0,0,0};
#elif defined(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