//%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. // //============================================================================== // // 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: David Dillard, VERITAS Software Corp. // (david.dillard@veritas.com) // Aruran, IBM(ashanmug@in.ibm.com) for Bug# 3589 // //%///////////////////////////////////////////////////////////////////////////// #ifndef Pegasus_CQLIdentifier_h #define Pegasus_CQLIdentifier_h #ifdef PEGASUS_USE_EXPERIMENTAL_INTERFACES #include //#include #include #include PEGASUS_NAMESPACE_BEGIN class 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: public QueryIdentifier { public: /** Default constructor @param - None. @return - None. @throws - None. Experimental Interface
*/ 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. @param - identifier. The raw string to be parsed into a CQLIdentifier @return - None. @throws - CQLIdentifierParseException Experimental Interface
*/ CQLIdentifier(const String& identifier); /** Copy constructor @param - id. The CQLIdentifier to copy construct from @return - None. @throws - None. Experimental Interface
*/ CQLIdentifier(const CQLIdentifier& id); /** Constructs a CQLIdentifier from its base class @param - identifier. The raw string to be parsed into a CQLIdentifier @return - None. @throws - None. Experimental Interface
*/ CQLIdentifier(const QueryIdentifier& id); /** Destructor @param - None. @return - None. @throws - None. Experimental Interface
*/ ~CQLIdentifier(); /** Assignment operator @param - rhs. The right hand side of the assignment operator @return - None. @throws - None. Experimental Interface
*/ CQLIdentifier& operator=(const CQLIdentifier& rhs); private: }; /* #ifndef PEGASUS_ARRAY_T #define PEGASUS_ARRAY_T CQLIdentifier #include #undef PEGASUS_ARRAY_T */ PEGASUS_NAMESPACE_END //#endif #endif #endif /* Pegasus_CQLIdentifier_h */