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

File: [Pegasus] / pegasus / src / Pegasus / CQL / CQLSelectStatement.h (download)
Revision: 1.9, Mon Jun 19 18:37:28 2006 UTC (18 years ago) by mike
Branch: MAIN
CVS Tags: 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-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-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-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-branch-New, 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, PEP286_PRIVILEGE_SEPARATION_ROOT, PEP286_PRIVILEGE_SEPARATION_CODE_FREEZE, PEP286_PRIVILEGE_SEPARATION_BRANCH, PEP286_PRIVILEGE_SEPARATION_1
Changes since 1.8: +1 -1 lines
BUG#: 5126
TITLE: Hidden default visibility for shared-library symbols (GCC 4.0 only)

DESCRIPTION: This patch introduces symbol exportation for GCC (similar to that used in Windows that requires the PEGASUS_???_LINKAGE macro).

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

#ifndef Pegasus_CQLSelectStatement_h
#define Pegasus_CQLSelectStatement_h

#include <Pegasus/CQL/Linkage.h>
#include <Pegasus/Common/AutoPtr.h>
#include <Pegasus/Query/QueryCommon/SelectStatement.h>
#include <Pegasus/CQL/CQLChainedIdentifier.h>
#include <Pegasus/CQL/CQLPredicate.h>
#include <Pegasus/CQL/CQLIdentifier.h>


#ifdef PEGASUS_USE_EXPERIMENTAL_INTERFACES

PEGASUS_NAMESPACE_BEGIN

class CQLSelectStatementRep;

/**
This class is derived from the SelectStatement base class.
The purpose of this class is to perform the select statement operations for
CIM Query Language (CQL).
*/
class PEGASUS_CQL_LINKAGE CQLSelectStatement : public SelectStatement
{
  public:

    /**
      Constructs a CQLSelectStatement default object.

      @param  - None.
      @return - None.
      @throw  - None.

      <I><B>Experimental Interface</B></I><BR>
    */
    CQLSelectStatement();

    /**
      Constructs a CQLSelectStatement object.

      @param  inQlang - String containing the language of the query.
      @param  inQuery - String containing the query.
      @param  inCtx - Context in which the select statement is running.
      @return - None.
      @throw  - None.

      <I><B>Experimental Interface</B></I><BR>
    */
    CQLSelectStatement(String& inQlang,
                       String& inQuery,
                       QueryContext& inCtx);

    /**
      Constructs a CQLSelectStatement object.

      @param  inQlang - String containing the language of the query.
      @param  inQuery - String containing the query.
      @return - None.
      @throw  - None.

      <I><B>Experimental Interface</B></I><BR>
    */
    CQLSelectStatement(String& inQLang, String& inQuery);

    /**
      Copy constructs a CQLSelectStatement object.

      @param  statement - CQLSelectStatement to be copied.
      @return - None.
      @throw  - None.

      <I><B>Experimental Interface</B></I><BR>
    */
    CQLSelectStatement(const CQLSelectStatement& statement);

    /**
      Destructs a CQLSelectStatement object.

      @param  - None.
      @return - None.
      @throw  - None.

      <I><B>Experimental Interface</B></I><BR>
    */
    ~CQLSelectStatement();

    /**
      Assigns a CQLSelectStatement to this object.

      @param rhs - CQLSelectStatement to be assigned to this object.
      @return - Updated this object.
      @throw  - None.

      <I><B>Experimental Interface</B></I><BR>
    */
    CQLSelectStatement& operator=(const CQLSelectStatement& rhs);

    /**
      Applies the class contexts from the FROM list to the
      chained identifiers in the statement. This will transform
      each chained identifier into a normalized form.  The FROM
      classname is prepended if needed, and all class aliases are resolved.

      Note: there are cases where the FROM classname is not prepended.
      This can occur for the classname on the right side of ISA,
      or the classname at the beginning of a symbolic constant chained
      identifier.  Neither of these classnames need to be the FROM class.

      This function also validates that each chained identifier
      is well-formed.  It is possible for a chained identifier
      to be syntactically correct in the CQL language, but
      cannot be processed by the CQL engine.

      Pre-condition: QueryContext has been set into this object.
      Post-condition: Chained identifiers have been normalized.

      @param None.
      @return None
      @throw CQLRuntimeException if the QueryContext had not been set.
      @throw CQLValidationException if a chained identifier is not well formed.
      @throw CQLSyntaxErrorException if a chained identifier is not well formed.

      <I><B>Experimental Interface</B></I><BR>
     */
    void applyContext();

    /**
      Evaluates the WHERE clause of the select statement using
      a CIM instance as the source of properties.

      Pre-condition: QueryContext has been set into this object.
      Post-condition: Chained identifiers have been normalized
      ie.applyContext has been called.  See the applyContext function.

      @param inCI - The instance to be evaluated.
      @return True, if the WHERE clause evaluates to true based on
              the type of the instance and its properties.
      @throw CQLRuntimeException if the instance cannot be evaluated
      @throw CQLValidationException for applyContext error.
      @throw CQLSyntaxErrorException for applyContext error.

      <I><B>Experimental Interface</B></I><BR>
    */
    Boolean evaluate(const CIMInstance& inCI);

    /**
      Projects the properties in the SELECT list of the select
      statement onto the instance.  This involves checking that
      all required properties exist on the instance passed in,
      and removing any unneeded properties from that instance.

      Pre-condition: QueryContext has been set into this object.
      Post-condition: Chained identifiers have been normalized
      ie.applyContext has been called.  See the applyContext function.

      @param inCI - The instance to be projected.
      @param allowMissing indicates whether missing project properties are
                          allowed
      @return None
      @throw  CQLRuntimeException if the instance cannot be projected
      @throw CQLValidationException for applyContext error.
      @throw CQLSyntaxErrorException for applyContext error.

      <I><B>Experimental Interface</B></I><BR>
    */
    void applyProjection(CIMInstance& inCI, Boolean allowMissing);

    /**
      Validates the classes and properties used in the select statement
      against the class schema.  The existence of classes and properties
      are checked, along with class relationships defined in the CQL
      specification.

      Pre-condition: QueryContext has been set into this object.
      Post-condition: Chained identifiers have been normalized
      ie.applyContext has been called.  See the applyContext function.

      @param None
      @return None
      @throw CQLValidationException for applyContext error, the select
      statement is invalid against the schema, or the QueryContext has
      not been set.
      @throw CQLSyntaxErrorException for applyContext error.

      <I><B>Experimental Interface</B></I><BR>
    */
    void validate();

    /**
      Normalizes the predicates in the WHERE clause to a
      disjunction of conjunctions.

      Post-condition: Chained identifiers have been normalized
      ie.applyContext has been called.  See the applyContext function.

      @param None
      @return None
      @throw None

      <I><B>Experimental Interface</B></I><BR>
     */
    void normalizeToDOC();

    /**
      Returns an array of CIMObjectPath objects that are the
      class paths in the FROM list of the select statement.

      Note:  Currently CQL only supports one class path in the
      FROM list.  This class path does not support WBEM-URI, so that
      only the namespace and classname parts are filled in.

      Pre-condition: QueryContext has been set into this object.

      @param None
      @return Array of FROM list class paths.
      @throw CQLRuntimeException if the QueryContext had not been set.

      <I><B>Experimental Interface</B></I><BR>
     */
    Array<CIMObjectPath> getClassPathList();

    /**
      Returns the required properties from the combined SELECT and WHERE
      clauses for the classname passed in.  The classname parameter is
      needed in case scoping operators are used in the select statement.
      This function does not return properties for the classname if they
      are required on embedded objects.  This function does not return
      required array indices.

      Pre-condition: QueryContext has been set into this object.
      Post-condition: Chained identifiers have been normalized
      ie.applyContext has been called.  See the applyContext function.

      @param inClassName - class to determine the required properties.  Defaults
      to the FROM class.
      @return CIMPropertyList containing the required properties for the class.
      If all the properties are required, a null CIMPropertyList is returned.
      If no properties are required, an empty CIMPropertyList is returned.
      @throw CQLRuntimeException if the QueryContext had not been set.
      @throw CQLValidationException for applyContext error.
      @throw CQLSyntaxErrorException for applyContext error.

      <I><B>Experimental Interface</B></I><BR>
    */
    CIMPropertyList getPropertyList(const CIMObjectPath& inClassName = CIMObjectPath());

    /**
      Returns the required properties from the SELECT clause for the
      classname passed in.  The classname parameter is needed in case
      scoping operators are used in the select statement.  This function
      does not return properties for the classname if they are required
      on embedded objects. This function does not return required array indices.

      Pre-condition: QueryContext has been set into this object.
      Post-condition: Chained identifiers have been normalized
      ie.applyContext has been called.  See the applyContext function.

      @param inClassName - class to determine the required properties.  Defaults
      to the FROM class.
      @return CIMPropertyList containing the required properties for the class.
      If all the properties are required, a null CIMPropertyList is returned.
      If no properties are required, an empty CIMPropertyList is returned.
      @throw CQLRuntimeException if the QueryContext had not been set.
      @throw CQLValidationException for applyContext error.
      @throw CQLSyntaxErrorException for applyContext error.

      <I><B>Experimental Interface</B></I><BR>
    */
    CIMPropertyList getSelectPropertyList(const CIMObjectPath& inClassName = CIMObjectPath());

    /**
      Returns the required properties from the WHERE clause for the
      classname passed in.  The classname parameter is needed in case
      scoping operators are used in the select statement.  This function
      does not return properties for the classname if they are required
      on embedded objects.  This function does not return required array indices.

      Pre-condition: QueryContext has been set into this object.
      Post-condition: Chained identifiers have been normalized
      ie.applyContext has been called.  See the applyContext function.

      @param inClassName - class to determine the required properties.  Defaults
      to the FROM class.
      @return CIMPropertyList containing the required properties for the class.
      If all the properties are required, a null CIMPropertyList is returned.
      If no properties are required, an empty CIMPropertyList is returned.
      @throw CQLRuntimeException if the QueryContext had not been set.
      @throw CQLValidationException for applyContext error.
      @throw CQLSyntaxErrorException for applyContext error.

      <I><B>Experimental Interface</B></I><BR>
    */
    CIMPropertyList getWherePropertyList(const CIMObjectPath& inClassName = CIMObjectPath());

    /**
      Returns the chained identifiers from the SELECT clause.  These chained
      identifiers contain the fully qualified property names, including embedded
      objects, array indices, scoping operators, and symbolic constants.

      Post-condition: Chained identifiers have been normalized
      ie.applyContext has been called.  See the applyContext function.

      @param None
      @return Array of chained identifiers.
      @throw CQLValidationException for applyContext error.
      @throw CQLSyntaxErrorException for applyContext error.

      <I><B>Experimental Interface</B></I><BR>
     */
    Array<CQLChainedIdentifier> getSelectChainedIdentifiers();

    /**
      Returns the chained identifiers from the WHERE clause.  These chained
      identifiers contain the fully qualified property names, including embedded
      objects, array indices, scoping operators, and symbolic constants.

      Pre-condition: QueryContext has been set into this object.
      Post-condition: Chained identifiers have been normalized
      ie.applyContext has been called.  See the applyContext function.

      @param None
      @return Array of chained identifiers.
      @throw CQLRuntimeException if the QueryContext had not been set.
      @throw CQLValidationException for applyContext error.
      @throw CQLSyntaxErrorException for applyContext error.

      <I><B>Experimental Interface</B></I><BR>
     */
    Array<CQLChainedIdentifier> getWhereChainedIdentifiers();

    /**
      Gets the top-level CQLPredicate of this object.
      This is the predicate that contains the top-level
      of any nested boolean operations in the WHERE clause.

      @param None.
      @return Top-level predicate
      @throw None.

      <I><B>Experimental Interface</B></I><BR>
    */
    CQLPredicate getPredicate() const;

    /**
      Determines whether the select statement has a WHERE clause.

      @param None
      @return True if there is a WHERE clause.
      @throw None

      <I><B>Experimental Interface</B></I><BR>
    */
    Boolean hasWhereClause();

    /**
      Returns the select statement in string form.
      Note that this can be different than the original
      statement after it has been parsed, and applyContext
      has been called.

      Pre-condition: QueryContext has been set into this object.

      @param None
      @return String containing the select statement.
      @throw

      <I><B>Experimental Interface</B></I><BR>
    */
    String toString();

    /*
       ATTN - the following methods should only be set by CQLParser.
       These should be made private, and CQLParser made a friend.
    */

    /**
      Appends a CQLIdentifier/alias combination into the FROM list of the
      statement. This method should only be called by the CQL parser.

      @param inIdentifier - CQLIdentifier to append.
      @param inAlias - Alias of the identifier.
      @return None
      @throw QueryException if the identifier/alias cannot be appended.

      <I><B>Experimental Interface</B></I><BR>
    */
    void insertClassPathAlias(const CQLIdentifier& inIdentifier,
                              String inAlias);

    /**
      Appends a CQLIdentifier into the FROM list of the statement.
      This method should only be called by the CQL parser.

      @param inIdentifier - CQLIdentifier to append.
      @return None
      @throw QueryException if the identifier cannot be appended.

      <I><B>Experimental Interface</B></I><BR>
    */
    void appendClassPath(const CQLIdentifier& inIdentifier);

    /**
      Appends a CQLChainedIdentifier to the select list.
      This method should only be called by the CQL parser.

      @param x - CQLChainedIdentifier to append.
      @return None
      @throw None

      <I><B>Experimental Interface</B></I><BR>
    */
    void appendSelectIdentifier(const CQLChainedIdentifier& x);

    /** Sets a predicate into this object. This method should only
            be called by Bison.
        */
    /**
      Sets the top-level CQLPredicate into this object.
      This method should only be called by the CQL parser.

      @param Predicate to set into this object.
      @return None
      @throw None.

      <I><B>Experimental Interface</B></I><BR>
    */
    void setPredicate(const CQLPredicate& inPredicate);

    /**
      Sets the select statement to have a WHERE clause.
      This method should only be called by the CQL parser.

      @param None
      @return None
      @throw None

      <I><B>Experimental Interface</B></I><BR>
    */
    void setHasWhereClause();

    /**
      Clears the internal data structures.
      This method should only be called by the CQL parser.

      Pre-condition: QueryContext has been set into this object.

      @param None
      @return None.
      @throw CQLRuntimeException if the QueryContext had not been set.

      <I><B>Experimental Interface</B></I><BR>
    */
    void clear();

  private:
    CQLSelectStatementRep* _rep;

};

PEGASUS_NAMESPACE_END
#endif
#endif

No CVS admin address has been configured
Powered by
ViewCVS 0.9.2