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

File: [Pegasus] / pegasus / src / Pegasus / Provider / CMPI / CmpiObjectPath.h (download)
Revision: 1.13, Tue Dec 16 18:56:48 2008 UTC (15 years, 5 months ago) by kumpf
Branch: MAIN
CVS Tags: preBug9676, postBug9676, TASK_PEP317_1JUNE_2013, TASK-TASK_PEP362_RestfulService_branch-root, TASK-TASK_PEP362_RestfulService_branch-merged_out_from_trunk, TASK-TASK_PEP362_RestfulService_branch-merged_in_to_trunk, TASK-TASK_PEP362_RestfulService_branch-merged_in_from_branch, TASK-TASK_PEP362_RestfulService_branch-branch, TASK-PEP362_RestfulService-root, TASK-PEP362_RestfulService-merged_out_to_branch, TASK-PEP362_RestfulService-merged_out_from_trunk, TASK-PEP362_RestfulService-merged_in_to_trunk, TASK-PEP362_RestfulService-merged_in_from_branch, TASK-PEP362_RestfulService-branch, TASK-PEP348_SCMO-root, TASK-PEP348_SCMO-merged_out_to_branch, TASK-PEP348_SCMO-merged_out_from_trunk, TASK-PEP348_SCMO-merged_in_to_trunk, TASK-PEP348_SCMO-merged_in_from_branch, TASK-PEP348_SCMO-branch, TASK-PEP317_pullop-root, TASK-PEP317_pullop-merged_out_to_branch, TASK-PEP317_pullop-merged_out_from_trunk, TASK-PEP317_pullop-merged_in_to_trunk, TASK-PEP317_pullop-merged_in_from_branch, TASK-PEP317_pullop-branch, RELEASE_2_9_2-RC2, RELEASE_2_9_2-RC1, RELEASE_2_9_2, RELEASE_2_9_1-RC1, RELEASE_2_9_1, RELEASE_2_9_0-RC1, RELEASE_2_9_0, RELEASE_2_9-root, RELEASE_2_9-branch, 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, RELEASE_2_13_0-RC2, RELEASE_2_13_0-RC1, RELEASE_2_13_0-FC, RELEASE_2_13_0, RELEASE_2_13-root, RELEASE_2_13-branch, RELEASE_2_12_1-RC1, RELEASE_2_12_1, RELEASE_2_12_0-RC1, RELEASE_2_12_0-FC, RELEASE_2_12_0, RELEASE_2_12-root, RELEASE_2_12-branch, RELEASE_2_11_2-RC1, RELEASE_2_11_2, RELEASE_2_11_1-RC1, RELEASE_2_11_1, RELEASE_2_11_0-RC1, RELEASE_2_11_0-FC, RELEASE_2_11_0, RELEASE_2_11-root, RELEASE_2_11-branch, RELEASE_2_10_1-RC1, RELEASE_2_10_1, RELEASE_2_10_0-RC2, RELEASE_2_10_0-RC1, RELEASE_2_10_0, RELEASE_2_10-root, RELEASE_2_10-branch, PREAUG25UPDATE, POSTAUG25UPDATE, HPUX_TEST, HEAD, CIMRS_WORK_20130824, BeforeUpdateToHeadOct82011
Changes since 1.12: +9 -9 lines
BUG#: 8273
TITLE: Remove trailing space characters
DESCRIPTION: Remove meaningless whitespace.

//%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.
//
//////////////////////////////////////////////////////////////////////////
//
//%////////////////////////////////////////////////////////////////////////////

#ifndef _CmpiObjectPath_h_
#define _CmpiObjectPath_h_

#include "cmpidt.h"
#include "cmpift.h"

#include "CmpiObject.h"
#include "CmpiBroker.h"
#include "CmpiStatus.h"
#include "CmpiData.h"
#include "CmpiBaseMI.h"
#include "Linkage.h"

/**
    The ObjectPath class represents the value of a Instance reference. It
    constains the namespace, classname and key properties.
    ObjectPath can also be used to represent a class reference.
    In that case key properties will be ignored.
*/

class PEGASUS_CMPI_PROVIDER_LINKAGE CmpiObjectPath : public CmpiObject
{
    friend class CmpiBroker;
    friend class CmpiResult;
    friend class CmpiInstance;
    friend class CmpiInstanceMI;
    friend class CmpiMethodMI;
    friend class CmpiAssociationMI;
    friend class CmpiPropertyMI;
    friend class CmpiIndicationMI;
    friend class CmpiData;
protected:

private:

    /**
        Constructor - Should not be called.
    */
    //CmpiObjectPath() {}
    void *makeObjectPath(CMPIBroker *mb, const char *ns, const char *cls);
    void *makeObjectPath(
        CMPIBroker *mb,
        const CmpiString& ns,
        const char *cls);
    CmpiBoolean doClassPathIsA(CMPIBroker *mb, const char *className) const;
public:

    /**
        Constructor - Creates an ObjectPath object with the classname
        from the input parameter.
        @param ns defining namespace or NULL
        @param cls defining classname or NULL
        @return The new ObjectPath object
    */
    CmpiObjectPath(const char *ns, const char *cls);
    CmpiObjectPath(const CmpiString &ns, const char *cls);

    /**
        Constructor used by MIDrivers to encapsulate CMPIObjectPathes.
    */
    CmpiObjectPath(CMPIObjectPath* c);

    /**
        Gets the encapsulated CMPIObjectPath.
    */
    CMPIObjectPath *getEnc() const;

    /**
        classPathIsA - Tests whether this CIM ObjectPath is a reference
        to a CIM class is of type <className>.
        @param className CIM classname to be tested for.
        @return True or False
    */
    CmpiBoolean classPathIsA(const char *className) const;

    /**
        getHostname - returns the hostname component of the
        ObjectPath
        @return CmpiString containing the hostname.
    */
    CmpiString getHostname() const;

    /**
        setHostname - Sets the hostname component.
        @param hn representing the hostname.
    */
    void setHostname(const char* hn);
    void setHostname(CmpiString hn);

    /**
        getNameSpace - returns the namespace component of the
        ObjectPath
        @return CmpiString containing the namespace.
    */
    CmpiString getNameSpace() const;

    /**
        setNameSpace - Sets the namespace component.
        @param ns representing the namespace.
    */
    void setNameSpace(const char* ns);
    void setNameSpace(CmpiString ns);

    /**
        getClassName - returns the classname component of the
        ObjectPath
        @return CmpiString containing the namespace.
    */
    CmpiString getClassName() const;

    /**
        setClassName - Sets the classname component.
        @param hn representing the hostname.
    */
    void setClassName(const char* hn);
    void setClassName(CmpiString hn);

    /**
        getKeyCount - Gets the number of key properties
        defined for this ObjectPath.
        @return Number of key properties of this ObjectPath.
    */
    unsigned int getKeyCount() const;

    /**
        getKey - Gets the CmpiData object representing the value
        associated with the key
        @param name key name.
        @return CmpiData value object associated with the key.
    */
    CmpiData getKey(const char* name) const;

    /**
        getKey - Gets the CmpiData object defined
        by the input index parameter.
        @param index Index into the key property array.
        @param name Optional output parameter returning the key name.
        @return CmpiData value object corresponding to the index.
    */
    CmpiData getKey(const int index, CmpiString *name=NULL) const;

    /**
        setKey - adds/replaces a key value defined by the input
        parameter to the ObjectPath
        @param name key name.
        @param data Type and Value to be added.
    */
    void setKey(const char* name, const CmpiData data);
};

#endif



No CVS admin address has been configured
Powered by
ViewCVS 0.9.2