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

File: [Pegasus] / pegasus / src / Pegasus / CQL / CQLIdentifier.h (download)
Revision: 1.1.2.7, Fri Nov 5 17:24:55 2004 UTC (19 years, 8 months ago) by humberto
Branch: CQL_2_5_BRANCH
Changes since 1.1.2.6: +3 -1 lines
PEP#: 193

TITLE: Added #ifdef PEGASUS_USE_EXPERIMENTAL_INTERFACES to all CQL parts

DESCRIPTION: CQL implementation

//%2003////////////////////////////////////////////////////////////////////////
//
// 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.
//
// 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.
//
//==============================================================================
//
// Authors: David Rosckes (rosckes@us.ibm.com)
//          Bert Rivero (hurivero@us.ibm.com)
//          Chuck Carmack (carmack@us.ibm.com)
//          Brian Lucier (lucier@us.ibm.com)
//
// Modified By: 
//
//%/////////////////////////////////////////////////////////////////////////////

#ifndef Pegasus_CQLIdentifier_h
#define Pegasus_CQLIdentifier_h

#include <Pegasus/Common/Config.h>
#include <Pegasus/CQL/Linkage.h>
#include <Pegasus/Common/String.h>
#include <Pegasus/Common/Array.h>
#include <Pegasus/Common/CIMName.h>
#include <Pegasus/CQL/SubRange.h>

#ifdef PEGASUS_USE_EXPERIMENTAL_INTERFACES

PEGASUS_NAMESPACE_BEGIN

class PEGASUS_CQL_LINKAGE CQLIdentifierRep;

/** 
  The CQLIdentifier class encapsulates
  the different formats of the CQL property portion
  of a CQLChainedIdentifier. 

  For example, a CQLChainedIdentifier can have these parts:
 
    Class.EmbeddedObject.Property
    Class.Property


The "Property" portion of the CQLChainedIdentifier can be
in any of these 3 formats:
   (a)  property name
   (b)  property[3]     e.g. an array index
   (c)  property#'OK'    e.g. a symbolic constant
   (d)  *   (wildcard)

In the future, there may be support added for a set of indices (ranges).
  */
class PEGASUS_CQL_LINKAGE CQLIdentifier
{

/*
Exceptions:
        CQLIdentifierException - for example: "missing matching brackets"
				       - general case if logic falls through all previous cases
                                                                                                                           
*/


  public:
    CQLIdentifier();
    /**  The constructor for a CQLIdentifier object
          takes a string as input.  The string should contain the
          property portion of a CQLChainedIdentifier.
    
         The constructor parses the input string into the components of 
         the property identifier. 
    
         Throws parsing errors.
      */
    CQLIdentifier(String identifier);

    CQLIdentifier(const CQLIdentifier& id);

    ~CQLIdentifier();

    /**
      The getPropertyName method returns the property name portion of 
      a property.   For example, of the property string contained myProperty#'OK',
      the property name is the "myProperty" portion.  In that case, "myProperty"
    would
      be returned in the CIMName reference.
      */
    const CIMName& getName()const;
    
    void setName(CIMName);

    /**
      The getSymbolicConstantName method returns the symbolic name portion of 
      a property.   For example, of the property string contained property#'OK',
      the symbolic constant is the "OK" portion.  In that case, "OK" would
      be returned in the String reference.
      */
    const String& getSymbolicConstantName()const;

    /**  The getSubRanges method returns an array of SubRanges 
           which contain all the array index ranges from the property
           portion of a CQLChainedIdentifier.
           If the property is not an array (e.g. the property is just
           a property name or a symbolic constant), an empty 
           array is returned.
      */
    const  Array<SubRange>& getSubRanges()const;

    /** The isArray method returns TRUE if the 
         CQL property identifier is an array (e.g. the
         property is of the format "property[index]).
         Otherwise FALSE is returned.
      */
    Boolean isArray()const;

    /** The isSymbolicConstant method returns TRUE if the 
         CQL property identifier is a symbolic constant (e.g. the
         property is of the format property#'CONSTANT'.
         Otherwise FALSE is returned.
      */
    Boolean isSymbolicConstant()const;

    /** The isWildcard method returns TRUE if the 
         CQL property identifier is a wildcard (e.g. the
         property is of the format "*").
         Otherwise FALSE is returned.
      */
    Boolean isWildcard()const;

    const String& getScope()const;

    Boolean isScoped()const;

    void applyScope(String scope);

    CQLIdentifier& operator=(const CQLIdentifier& rhs);

    Boolean operator==(const CIMName &rhs)const;
                                                                                                                                       
    Boolean operator!=(const CIMName &rhs)const;

    Boolean operator==(const CQLIdentifier &rhs)const;

    Boolean operator!=(const CQLIdentifier &rhs)const;

    String toString()const;

  private:
	CQLIdentifierRep* _rep;

};


#ifndef PEGASUS_ARRAY_T
#define PEGASUS_ARRAY_T CQLIdentifier
#include <Pegasus/Common/ArrayInter.h>
#undef PEGASUS_ARRAY_T

PEGASUS_NAMESPACE_END
#endif
#endif
#endif /* Pegasus_CQLIdentifier_h */

No CVS admin address has been configured
Powered by
ViewCVS 0.9.2