XQuilla/include/xqilla/ast/XQOperator.hpp
2020-02-17 22:13:50 +01:00

58 lines
1.8 KiB
C++

/*
* Copyright (c) 2001-2008
* DecisionSoft Limited. All rights reserved.
* Copyright (c) 2004-2008
* Oracle. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
* $Id: XQOperator.hpp,v 1.10 2008/01/08 18:47:29 jpcs Exp $
*/
#ifndef _XQOPERATOR_HPP
#define _XQOPERATOR_HPP
#include <xqilla/ast/ASTNodeImpl.hpp>
#include <xqilla/runtime/Sequence.hpp>
#include <xqilla/items/Node.hpp>
#include <xercesc/util/XMLUniDefs.hpp> // because every implementation will use these to define the function name
class Node;
/** Virtual interface class for operator */
class XQILLA_API XQOperator : public ASTNodeImpl
{
public:
/// constructor, checks for the correct number of arguments.
XQOperator(const XMLCh* opName, const VectorOfASTNodes &args, XPath2MemoryManager* memMgr);
/** used to manipulate arguments */
void addArgument(ASTNode* arg);
void removeArgument(unsigned int index);
ASTNode* getArgument(unsigned int index) const;
void setArgument(unsigned int index, ASTNode *arg);
/** returns the number of parameters passed into the operator */
unsigned int getNumArgs() const;
virtual const XMLCh* getOperatorName() const;
const VectorOfASTNodes &getArguments() const;
protected:
VectorOfASTNodes _args; // The real store for arguments
const XMLCh* _opName;
};
#endif // _XQOPERATOR_HPP