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

File: [Pegasus] / pegasus / src / Pegasus / CQL / CQLExpressionRep.cpp (download)
Revision: 1.9, Wed Apr 18 19:14:35 2007 UTC (17 years, 2 months ago) by karl
Branch: MAIN
CVS Tags: TASK_PEP328_SOLARIS_NEVADA_PORT, TASK-PEP328_SOLARIS_NEVADA_PORT_v2-root, TASK-PEP328_SOLARIS_NEVADA_PORT_v2-branch, TASK-PEP328_SOLARIS_NEVADA_PORT-root, TASK-PEP328_SOLARIS_NEVADA_PORT-branch, TASK-PEP328_SOLARIS_IX86_CC_PORT-root, TASK-PEP328_SOLARIS_IX86_CC_PORT-branch-v2, TASK-PEP328_SOLARIS_IX86_CC_PORT-branch, TASK-PEP311_WSMan-root, TASK-PEP311_WSMan-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-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-BUG7146_SqlRepositoryPrototype-root, TASK-BUG7146_SqlRepositoryPrototype-merged_out_to_branch, TASK-BUG7146_SqlRepositoryPrototype-merged_out_from_trunk, TASK-BUG7146_SqlRepositoryPrototype-merged_in_to_trunk, TASK-BUG7146_SqlRepositoryPrototype-merged_in_from_branch, TASK-BUG7146_SqlRepositoryPrototype-branch, RELEASE_2_8_2-RC1, RELEASE_2_8_2, RELEASE_2_8_1-RC1, RELEASE_2_8_1, RELEASE_2_8_0_BETA, RELEASE_2_8_0-RC2, RELEASE_2_8_0-RC1, RELEASE_2_8_0-FC, RELEASE_2_8_0, RELEASE_2_8-root, RELEASE_2_8-branch, RELEASE_2_7_3-RC1, RELEASE_2_7_3, RELEASE_2_7_2-RC1, RELEASE_2_7_2, RELEASE_2_7_1-RC1, RELEASE_2_7_1, RELEASE_2_7_0-RC1, RELEASE_2_7_0-BETA, RELEASE_2_7_0, RELEASE_2_7-root, RELEASE_2_7-branch, Makefile
Changes since 1.8: +55 -52 lines
BUG#: 6340
TITLE: chksrc cleanup of all files in Pegasus/CQL directory

DESCRIPTION: Remove tabs, shorten lines, move to 4 char tabs, and some
other cleanup for style guide consistency.

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

#include <Pegasus/CQL/CQLExpression.h>
#include <Pegasus/CQL/CQLExpressionRep.h>
#include <Pegasus/CQL/CQLFactory.h>
#include <Pegasus/Query/QueryCommon/QueryContext.h>
#include <Pegasus/Common/Tracer.h>

PEGASUS_NAMESPACE_BEGIN

CQLExpressionRep::CQLExpressionRep(const CQLTerm& theTerm)
{
  PEG_METHOD_ENTER(TRC_CQL,
      "CQLExpressionRep::CQLExpressionRep(const CQLTerm& theTerm)");
  _CQLTerms.append(theTerm);
  PEG_METHOD_EXIT();
}

CQLExpressionRep::CQLExpressionRep(const CQLExpressionRep* rep) 
{
  PEG_METHOD_ENTER(TRC_CQL,
      "CQLExpressionRep::CQLExpressionRep(const CQLExpressionRep* rep)");

  _TermOperators = rep->_TermOperators;
  _CQLTerms = rep->_CQLTerms;

  PEG_METHOD_EXIT();
}

CQLExpressionRep::~CQLExpressionRep()
{

}
CQLValue CQLExpressionRep::resolveValue(const CIMInstance& CI,
                                        const QueryContext& QueryCtx)
{
  PEG_METHOD_ENTER(TRC_CQL,"CQLExpressionRep::resolveValue()");

  CQLValue returnVal = _CQLTerms[0].resolveValue(CI,QueryCtx);
  
  /*
    for(Uint32 i = 0; i < _TermOperators.size(); ++i)
    {
      switch(_TermOperators[i])
        {
           case TERM_ADD:
               returnVal = returnVal + 
               _CQLTerms[i+1].resolveValue(CI,QueryCtx);
           break;
               case TERM_SUBTRACT:
               returnVal = returnVal - 
               _CQLTerms[i+1].resolveValue(CI,QueryCtx);
               break;
        default:
            throw(1);
        }
    }
*/
  
  PEG_METHOD_EXIT();
  return returnVal;
}

void CQLExpressionRep::appendOperation(const TermOpType theTermOpType,
                                       const CQLTerm& theTerm)
{
    PEG_METHOD_ENTER(TRC_CQL,"CQLExpressionRep::appendOperation()");
    
    _TermOperators.append(theTermOpType);
    _CQLTerms.append(theTerm);
    
    PEG_METHOD_EXIT();
}

String CQLExpressionRep::toString()const
{
    PEG_METHOD_ENTER(TRC_CQL,"CQLExpressionRep::toString()");
    
    String returnStr;
    
    if(_CQLTerms.size() > 0)
    {
        returnStr.append(_CQLTerms[0].toString());
        /* for(Uint32 i = 0; i < _TermOperators.size(); ++i)
          {
            returnStr.append(_TermOperators[i] == 
                TERM_ADD ? String(" + ") : String(" - "));
        returnStr.append(_CQLTerms[i+1].toString());
          }
        */
    }
    
    PEG_METHOD_EXIT();
    return returnStr;
    }


Boolean CQLExpressionRep::isSimple()const
{
   return (_CQLTerms.size() == 1);
}

Boolean CQLExpressionRep::isSimpleValue()const
{
  PEG_METHOD_ENTER(TRC_CQL,"CQLExpressionRep::isSimpleValue()");

  if(_CQLTerms.size() == 1) 
    {
      PEG_METHOD_EXIT();
      return _CQLTerms[0].isSimpleValue();
    }
  
  PEG_METHOD_EXIT();
  
  return false;
}

Array<CQLTerm> CQLExpressionRep::getTerms()const
{
   return _CQLTerms;
}

Array<TermOpType> CQLExpressionRep::getOperators()const
{
   return _TermOperators;
}

void CQLExpressionRep::applyContext(const QueryContext& inContext,
                                    const CQLChainedIdentifier& inCid)
{
  PEG_METHOD_ENTER(TRC_CQL,"CQLExpressionRep::applyContext()");

  for(Uint32 i = 0; i < _CQLTerms.size(); ++i)
  {
    _CQLTerms[i].applyContext(inContext, inCid);
  }

  PEG_METHOD_EXIT();
}
/*
Boolean CQLExpressionRep::operator==(const CQLExpressionRep& rep)const
{
  PEG_METHOD_ENTER(TRC_CQL,"CQLExpressionRep::operator==()");

  if(_isSimple != rep._isSimple)
    {
      PEG_METHOD_EXIT();
      return false;
    }

  for(Uint32 i = 0; i < _TermOperators.size(); ++i)
    {
      if(_TermOperators[i] != rep._TermOperators[i])
    {
      PEG_METHOD_EXIT();
      return false;
    }
    }

  for(Uint32 i = 0; i < _CQLTerms.size(); ++i)
    {
      if(_CQLTerms[i] != rep._CQLTerms[i])
    {
      PEG_METHOD_EXIT();
      return false;
    }
    }
  
  PEG_METHOD_EXIT();
  return true;
}

Boolean CQLExpressionRep::operator!=(const CQLExpressionRep& rep)const
{
  return (!operator==(rep));
}
*/
PEGASUS_NAMESPACE_END


No CVS admin address has been configured
Powered by
ViewCVS 0.9.2