(file) Return to CIMName.h CVS log (file) (dir) Up to [Pegasus] / pegasus / src / Pegasus / Common

File: [Pegasus] / pegasus / src / Pegasus / Common / CIMName.h (download)
Revision: 1.38, Fri Feb 17 19:30:37 2006 UTC (18 years, 4 months ago) by kumpf
Branch: MAIN
CVS Tags: TASK_PEP233_EmbeddedInstSupport-merge_out_trunk, TASK_BUG_5314_IPC_REFACTORING_ROOT, TASK_BUG_5314_IPC_REFACTORING_BRANCH, TASK_BUG_5314_IPC_REFACTORING-V1, TASK_BUG_5191_QUEUE_CONSOLIDATION_ROOT, TASK_BUG_5191_QUEUE_CONSOLIDATION_BRANCH, 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-PEP305_VXWORKS-root, TASK-PEP305_VXWORKS-branch-pre-solaris-port, TASK-PEP305_VXWORKS-branch-post-solaris-port, TASK-PEP305_VXWORKS-branch-beta2, TASK-PEP305_VXWORKS-branch, TASK-PEP305_VXWORKS-2008-10-23, TASK-PEP291_IPV6-root, TASK-PEP291_IPV6-branch, TASK-PEP286_PRIVILEGE_SEPARATION-root, TASK-PEP286_PRIVILEGE_SEPARATION-branch, TASK-PEP274_dacim-root, TASK-PEP274_dacim-merged_out_to_branch, TASK-PEP274_dacim-merged_out_from_trunk, TASK-PEP274_dacim-merged_in_to_trunk, TASK-PEP274_dacim-merged_in_from_branch, TASK-PEP274_dacim-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-merging_out_from_trunk, 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-PEP250_RPMProvider-root, TASK-PEP250_RPMProvider-merged_out_to_branch, TASK-PEP250_RPMProvider-merged_out_from_trunk, TASK-PEP250_RPMProvider-merged_in_to_trunk, TASK-PEP250_RPMProvider-merged_in_from_branch, TASK-PEP250_RPMProvider-branch, TASK-PEP245_CimErrorInfrastructure-root, TASK-PEP245_CimErrorInfrastructure-merged_out_to_branch, TASK-PEP245_CimErrorInfrastructure-merged_out_from_trunk, TASK-PEP245_CimErrorInfrastructure-merged_in_to_trunk, TASK-PEP245_CimErrorInfrastructure-merged_in_from_branch, TASK-PEP245_CimErrorInfrastructure-branch, TASK-PEP241_OpenPegasusStressTests-root, TASK-PEP241_OpenPegasusStressTests-merged_out_to_branch, TASK-PEP241_OpenPegasusStressTests-merged_out_from_trunk, TASK-PEP241_OpenPegasusStressTests-merged_in_to_trunk, TASK-PEP241_OpenPegasusStressTests-merged_in_from_branch, TASK-PEP241_OpenPegasusStressTests-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-Bug2102_RCMPIWindows-root, TASK-Bug2102_RCMPIWindows-merged_out_to_branch, TASK-Bug2102_RCMPIWindows-merged_out_from_trunk, TASK-Bug2102_RCMPIWindows-merged_in_to_trunk, TASK-Bug2102_RCMPIWindows-merged_in_from_branch, TASK-Bug2102_RCMPIWindows-branch, TASK-Bug2102Final-root, TASK-Bug2102Final-merged_out_to_branch, TASK-Bug2102Final-merged_out_from_trunk, TASK-Bug2102Final-merged_in_to_trunk, TASK-Bug2102Final-merged_in_from_branch, TASK-Bug2102Final-branch, 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-Bug2021_RCMPIonWindows-root, TASK-Bug2021_RCMPIonWindows-merged_out_to_branch, TASK-Bug2021_RCMPIonWindows-merged_out_from_trunk, TASK-Bug2021_RCMPIonWindows-merged_in_to_trunk, TASK-Bug2021_RCMPIonWindows-merged_in_from_branch, TASK-Bug2021_RCMPIonWindows-branch, TASK-BUG7240-root, TASK-BUG7240-branch, TASK-BUG4011_WinLocalConnect-root, TASK-BUG4011_WinLocalConnect-merged_out_to_branch, TASK-BUG4011_WinLocalConnect-merged_out_from_trunk, TASK-BUG4011_WinLocalConnect-merged_in_to_trunk, TASK-BUG4011_WinLocalConnect-merged_in_from_branch, TASK-BUG4011_WinLocalConnect-branch-New, TASK-BUG4011_WinLocalConnect-branch, RELEASE_2_7_0-BETA, RELEASE_2_6_3-RC2, RELEASE_2_6_3-RC1, RELEASE_2_6_3, RELEASE_2_6_2-RC1, RELEASE_2_6_2, RELEASE_2_6_1-RC1, RELEASE_2_6_1, RELEASE_2_6_0-RC1, RELEASE_2_6_0-FC, RELEASE_2_6_0, RELEASE_2_6-root, RELEASE_2_6-branch-clean, RELEASE_2_6-branch, RELEASE_2_5_5-RC2, RELEASE_2_5_5-RC1, RELEASE_2_5_5, RELEASE_2_5_4-RC2, RELEASE_2_5_4-RC1, RELEASE_2_5_4, RELEASE_2_5_3-RC1, RELEASE_2_5_3, RELEASE_2_5_2-RC1, RELEASE_2_5_2, RELEASE_2_5_1-RC1, RELEASE_2_5_1, RELEASE_2_5-root, RELEASE_2_5-branch, PEP286_PRIVILEGE_SEPARATION_ROOT, PEP286_PRIVILEGE_SEPARATION_CODE_FREEZE, PEP286_PRIVILEGE_SEPARATION_BRANCH, PEP286_PRIVILEGE_SEPARATION_1
Changes since 1.37: +211 -214 lines
BUG#: 4796
TITLE: Complete and correct the documentation for the CIM interfaces
DESCRIPTION: Updated the doc++ to more completely and correctly document the interfaces.

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

#ifndef Pegasus_Name_h
#define Pegasus_Name_h

#include <Pegasus/Common/Config.h>
#include <Pegasus/Common/Linkage.h>
#include <Pegasus/Common/String.h>
#include <Pegasus/Common/Array.h>
#include <Pegasus/Common/Exception.h>

PEGASUS_NAMESPACE_BEGIN

////////////////////////////////////////////////////////////////////////////////
//
// CIMName
//
////////////////////////////////////////////////////////////////////////////////

/**
    The CIMName class represents the DMTF standard CIM name definition.
    The names of CIM classes, properties, qualifiers, and methods are all
    CIM names.

    <p>A CIM name must contain characters only from this set:
    <ul>
      <li>alphabetic (a-z and A-Z)
      <li>numeric (0-9)
      <li>underscore (_)
      <li>UCS-2 characters in the range 0x0080 to 0xFFEF
    </ul>
    The first character of a CIM name may not be numeric.
    A CIMName may be null, meaning that it has no value.
*/
class PEGASUS_COMMON_LINKAGE CIMName
{
public:

    /**
        Constructs a null CIMName.
    */
    CIMName();

    /**
        Constructs a non-null CIMName with the specified name.
        @param name A String containing the CIM name.
        @exception InvalidNameException If the String does not contain a
            valid CIM name.
    */
    CIMName(const String& name);

    /**
        Constructs a non-null CIMName with the specified name.
        @param name A character string containing the CIM name.
        @exception InvalidNameException If the character string does not
            contain a valid CIM name.
    */
    CIMName(const char* name);

    /**
        Assigns the value of the specified CIMName object to this object.
        @param name The CIMName object from which to assign this
            CIMName object.
    */
    CIMName& operator=(const CIMName& name);

    /**
        Sets the CIMName with a String name.  The resulting CIMName object
        is non-null.
        <p><b>Example:</b>
        <pre>
        CIMName n;
        String type = "type";
        n = type;
        </pre>
        @param name A String containing the CIM name to set.
        @return A reference to this CIMName object.
        @exception InvalidNameException If the String does not contain a
            valid CIM name.
    */
    CIMName& operator=(const String& name);

    /**
        Gets a String form of the CIM name.
        <p><b>Example:</b>
        <pre>
        CIMName n("name");
        String s = n.getString();
        </pre>
        @return A reference to a String containing the CIM name.
    */
    const String& getString() const;

    /**
        Determines whether the CIM name is null.
        <p><b>Example:</b>
        <pre>
        CIMName n;
        assert(n.isNull());
        n = "name";
        assert(!n.isNull());
        </pre>
        @return True if the CIM name is null, false otherwise.
    */
    Boolean isNull() const;

    /**
        Sets the CIM name to a null value.
        <p><b>Example:</b>
        <pre>
        CIMName n("name");
        n.clear();
        assert(n.isNull());
        </pre>
    */
    void clear();

    /**
        Compares the CIMName with a specified CIMName.  Comparisons of
        CIM names are case-insensitive.
        <p><b>Example:</b>
        <pre>
        CIMName n1("name");
        CIMName n2("Name");
        assert(n1.equal(n2));
        </pre>
        @param name The CIMName to be compared.
        @return True if this name is equivalent to the specified name,
            false otherwise.
    */
    Boolean equal(const CIMName& name) const;

    /**
        Determines whether a name is a valid CIM name.
        <p><b>Example:</b>
        <pre>
        assert(CIMName::legal("name"));
        assert(!CIMName::legal("3types"));
        </pre>
        @param name A String containing the name to test.
        @return True if the specified name is a valid CIM name,
            false otherwise.
    */
    static Boolean legal(const String& name);

#ifdef PEGASUS_USE_EXPERIMENTAL_INTERFACES

    /**
        Compares the CIMName with a specified character string.  Comparisons of
        CIM names are case-insensitive.
        @param name The name to be compared.
        @return True if this name is equivalent to the specified name,
            false otherwise.
    */
    Boolean equal(const char* name) const;

    /**
        Sets the CIMName with a character string name.  The resulting CIMName
        object is non-null.
        @param name A character string containing the CIM name to set.
        @return A reference to this CIMName object.
        @exception InvalidNameException If the character string does not
            contain a valid CIM name.
    */
    CIMName& operator=(const char* name);

#endif /* PEGASUS_USE_EXPERIMENTAL_INTERFACES */

private:
    String cimName;
    friend class CIMNameUnchecked;
};

/**
    Compares two CIM names for equality.
    <p><b>Example:</b>
    <pre>
    CIMName lowerCaseName("this_is_a_name");
    CIMName upperCaseName("THIS_IS_A_NAME");
    assert(lowerCaseName == upperCaseName);
    </pre>
    @param x The first CIMName to be compared.
    @param y The second CIMName to be compared.
    @return True if the CIM names are equivalent, false otherwise.
*/
PEGASUS_COMMON_LINKAGE Boolean operator==(
    const CIMName& name1,
    const CIMName& name2);

/**
    Compares two CIM names for inequality.
    @param x The first CIMName to be compared.
    @param y The second CIMName to be compared.
    @return False if the CIM names are equivalent, true otherwise.
*/
PEGASUS_COMMON_LINKAGE Boolean operator!=(
    const CIMName& name1,
    const CIMName& name2);

#define PEGASUS_ARRAY_T CIMName
# include "ArrayInter.h"
#undef PEGASUS_ARRAY_T


////////////////////////////////////////////////////////////////////////////////
//
// CIMNamespaceName
//
////////////////////////////////////////////////////////////////////////////////

/**
    The CIMNamespaceName class represents the DMTF standard CIM namespace
    name definition.

    <p>A CIM namespace name must match the following expression:
    <pre>
        &lt;CIMName&gt;[ / &lt;CIMName&gt; ]*
    </pre>
    A namespace name with a leading '/' character is accepted, but the
    leading character is removed.
    A CIMNamespaceName may be null, meaning that it has no value.
*/
class PEGASUS_COMMON_LINKAGE CIMNamespaceName
{
public:

    /**
        Constructs a null CIMName.
    */
    CIMNamespaceName();

    /**
        Constructs a non-null CIMNamespaceName with the specified name.
        @param name A String containing the CIM namespace name.
        @exception InvalidNameException If the String does not contain a
            valid CIM namespace name.
    */
    CIMNamespaceName(const String& name);

    /**
        Constructs a non-null CIMNamespaceName with the specified name.
        @param name A character string containing the CIM namespace name.
        @exception InvalidNameException If the character string does not
            contain a valid CIM namespace name.
    */
    CIMNamespaceName(const char* name);

    /**
        Assigns the value of the specified CIMNamespaceName object to this
        object.
        @param name The CIMNamespaceName object from which to assign this
            CIMNamespaceName object.
    */
    CIMNamespaceName& operator=(const CIMNamespaceName& name);

    /**
        Sets the CIMNamespaceName with a String name.  The resulting
        CIMNamespaceName object is non-null.
        <p><b>Example:</b>
        <pre>
        CIMNamespaceName n;
        String name = "root/cimv2";
        n = name;
        </pre>
        @param name A String containing the CIM namespace name to set.
        @return A reference to this CIMNamespaceName object.
        @exception InvalidNameException If the String does not contain a
            valid CIM namespace name.
    */
    CIMNamespaceName& operator=(const String& name);

    /**
        Gets a String form of the CIM namespace name.
        <p><b>Example:</b>
        <pre>
        CIMNamespaceName n("test/ns1");
        String s = n.getString();
        </pre>
        @return A reference to a String containing the CIM namespace name.
    */
    const String& getString() const;

    /**
        Determines whether the CIM namespace name is null.
        <p><b>Example:</b>
        <pre>
        CIMNamespaceName n;
        assert(n.isNull());
        n = "root/test";
        assert(!n.isNull());
        </pre>
        @return True if the CIM namespace name is null, false otherwise.
    */
    Boolean isNull() const;

    /**
        Sets the CIM namespace name to a null value.
        <p><b>Example:</b>
        <pre>
        CIMNamespaceName n("root/test");
        n.clear();
        assert(n.isNull());
        </pre>
    */
    void clear();

    /**
        Compares the CIMNamespaceName with a specified CIMNamespaceName.
        Comparisons of CIM namespace names are case-insensitive.
        <p><b>Example:</b>
        <pre>
        CIMNamespaceName n1("root/cimv2");
        CIMNamespaceName n2("Root/CimV2");
        assert(n1.equal(n2));
        </pre>
        @param name The CIMNamespaceName to be compared.
        @return True if this name is equivalent to the specified name,
            false otherwise.
    */
    Boolean equal(const CIMNamespaceName& name) const;

    /**
        Determines whether a name is a valid CIM namespace name.
        <p><b>Example:</b>
        <pre>
        assert(CIMNamespaceName::legal("root/test"));
        assert(!CIMNamespaceName::legal("Wrong!"));
        </pre>
        @param name A String containing the name to test.
        @return True if the specified name is a valid CIM namespace name,
            false otherwise.
    */
    static Boolean legal(const String& name);

#ifdef PEGASUS_USE_EXPERIMENTAL_INTERFACES

    /**
        Compares the CIMNamespaceName with a specified character string.
        Comparisons of CIM namespace names are case-insensitive.
        @param name The name to be compared.
        @return True if this name is equivalent to the specified name,
            false otherwise.
    */
    Boolean equal(const char* name) const;

    /**
        Sets the CIMNamespaceName with a character string name.  The
        resulting CIMNamespaceName object is non-null.
        @param name A character string containing the CIM namespace name
            to set.
        @return A reference to this CIMNamespaceName object.
        @exception InvalidNameException If the character string does not
            contain a valid CIM namespace name.
    */
    CIMNamespaceName& operator=(const char* name);

#endif /* PEGASUS_USE_EXPERIMENTAL_INTERFACES */

private:
    String cimNamespaceName;
};

/**
    Compares two CIM namespace names for equality.
    <p><b>Example:</b>
    <pre>
    CIMNamespaceName n1("root/test");
    CIMNamespaceName n2("Root/TEST");
    assert(n1 == n2);
    </pre>
    @param x The first CIMNamespaceName to be compared.
    @param y The second CIMNamespaceName to be compared.
    @return True if the CIM namespace names are equivalent, false otherwise.
*/
PEGASUS_COMMON_LINKAGE Boolean operator==(
    const CIMNamespaceName& name1,
    const CIMNamespaceName& name2);

/**
    Compares two CIM namespace names for inequality.
    @param x The first CIMNamespaceName to be compared.
    @param y The second CIMNamespaceName to be compared.
    @return False if the CIM namespace names are equivalent, true otherwise.
*/
PEGASUS_COMMON_LINKAGE Boolean operator!=(
    const CIMNamespaceName& name1,
    const CIMNamespaceName& name2);

#define PEGASUS_ARRAY_T CIMNamespaceName
# include "ArrayInter.h"
#undef PEGASUS_ARRAY_T

PEGASUS_NAMESPACE_END

#ifdef PEGASUS_INTERNALONLY
# include "CIMNameInline.h"
#endif

#endif /* Pegasus_Name_h */

No CVS admin address has been configured
Powered by
ViewCVS 0.9.2