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

File: [Pegasus] / pegasus / src / Pegasus / Common / CIMScope.h (download)
Revision: 1.14, Wed Aug 14 21:32:23 2002 UTC (21 years, 10 months ago) by kumpf
Branch: MAIN
CVS Tags: mday-2-0-patches, VERSION_2_1_RELEASE_HEAD, VERSION_2_1_RELEASE_BRANCH, VERSION_2_1_RELEASE, VERSION_2_1_1_RELEASE, LOCAL_ASSOCPROV-ROOT, LOCAL_ASSOCPROV-BRANCH
Changes since 1.13: +28 -31 lines
HP-RK Remove use of Uint32 in CIMScope.  Added an operator+ method to use instead of | to add CIMScopes together.

//%/////////////////////////////////////////////////////////////////////////////
//
// Copyright (c) 2000, 2001, 2002 BMC Software, Hewlett-Packard Company, IBM,
// The Open Group, Tivoli Systems
//
// Permission is hereby granted, free of charge, to any person obtaining a copy
// of this software and associated documentation files (the "Software"), to
// deal in the Software without restriction, including without limitation the
// rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
// sell copies of the Software, and to permit persons to whom the Software is
// furnished to do so, subject to the following conditions:
// 
// THE ABOVE COPYRIGHT NOTICE AND THIS PERMISSION NOTICE SHALL BE INCLUDED IN
// ALL COPIES OR SUBSTANTIAL PORTIONS OF THE SOFTWARE. THE SOFTWARE IS PROVIDED
// "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT
// LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
// PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
// HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
// ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
//
//==============================================================================
//
// Author: Mike Brasher (mbrasher@bmc.com)
//
// Modified By: Carol Ann Krug Graves, Hewlett-Packard Company
//                (carolann_graves@hp.com)
//              Roger Kumpf, Hewlett-Packard Company (roger_kumpf@hp.com)
//
//%/////////////////////////////////////////////////////////////////////////////

#ifndef Pegasus_Scope_h
#define Pegasus_Scope_h

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

PEGASUS_NAMESPACE_BEGIN

/**
    The CIMScope class implements the concept of the scope of a CIM qualifier 
    object.  The scope of a qualifier defines the set of types of CIM objects 
    with which the qualifier may be used.  The possible values are:
    NONE, CLASS, ASSOCIATION, INDICATION, PROPERTY, REFERENCE, METHOD, 
    PARAMETER, ANY.
    The scope is a set of one or more of these possible values.
    The value "NONE" implies a CIMScope object that has not yet been assigned a
    value (uninitialized).  It is not a valid value for the scope of a 
    qualifier object.
    The value "ANY" means that the qualifier may be used with any of the CIM 
    object types, and is equivalent to listing each of the object types in the 
    scope.
*/
class PEGASUS_COMMON_LINKAGE CIMScope
{
public:

    /**
        Constructs a CIMScope object with no value set (default constructor).
     */
    CIMScope ();

    /**
        Constructs a CIMScope object from an existing CIMScope object (copy 
        constructor).

        @param   scope                 another CIMScope object
     */
    CIMScope (const CIMScope & scope);

    /**
        Assigns the value of one CIMScope object to another (assignment 
        operator).

        @param   scope                 a CIMScope object

        @return  the CIMScope object
     */
    CIMScope & operator= (const CIMScope & scope);

    /**
        Determines if every value in the specified CIMScope object is included 
        in this CIMScope object.

        @param   scope                 a CIMScope object

        @return  True if every value in the specified CIMScope object is 
                   included in the CIMScope object,
                 False otherwise
     */
    Boolean hasScope (const CIMScope & scope) const;

    /**
        Adds the specified scope value to the CIMScope object.

        @param   scope                 a scope value

        @exception InvalidScope  if the scope value is invalid
     */
    void addScope (const CIMScope & scope);

    /** 
        Compares two CIMScope objects.

        @param   scope                 a CIMScope object

        @return True if the two CIMScope objects are equal, 
                False otherwise
     */
    Boolean equal (const CIMScope & scope) const;

    /**
        Combines two CIMScope objects.

        @param   scope                 a CIMScope object to add

        @return A new CIMScope object that represents the combination of this
                scope with the specified scope.
     */
    CIMScope operator+ (const CIMScope & scope) const;

    /** 
        Returns a String representation of the CIMScope object.
        This method is for diagnostic purposes.  The format of the output
        is subject to change.
     */
    String toString () const;

    /** 
        Indicates that the CIMScope object has no value (is uninitialized)
     */
    static const CIMScope NONE;

    /** 
        Indicates that the qualifier may be used with classes
     */
    static const CIMScope CLASS;

    /** 
        Indicates that the qualifier may be used with associations
     */
    static const CIMScope ASSOCIATION;

    /** 
        Indicates that the qualifier may be used with indications
     */
    static const CIMScope INDICATION;

    /** 
        Indicates that the qualifier may be used with properties
     */
    static const CIMScope PROPERTY;

    /** 
        Indicates that the qualifier may be used with references
     */
    static const CIMScope REFERENCE;

    /** 
        Indicates that the qualifier may be used with methods
     */
    static const CIMScope METHOD;

    /** 
        Indicates that the qualifier may be used with parameters
     */
    static const CIMScope PARAMETER;

    /** 
        Indicates that the qualifier may be used with any of the types
        of objects (classes, associations, indications, properties, references,
        methods, parameters)
     */
    static const CIMScope ANY;

private:

    /**
        Constructs a CIMScope object with the specified value.

        @param   scope                 a Uint32 scope value to initialize with
     */
    CIMScope (const Uint32 scope);

    Uint32 cimScope;
};

PEGASUS_NAMESPACE_END

#endif /* Pegasus_Scope_h */

No CVS admin address has been configured
Powered by
ViewCVS 0.9.2