/* * Copyright (c) 2001-2007 * DecisionSoft Limited. All rights reserved. * Copyright (c) 2004-2007 * 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: FunctionName.hpp,v 1.11 2007/11/28 13:13:23 jpcs Exp $ */ /* Name function */ #ifndef _FUNCTIONNAME_HPP #define _FUNCTIONNAME_HPP #include #include #include /** Name function */ class XQILLA_API FunctionName : public XQFunction { public: static const XMLCh name[]; static const unsigned int minArgs; static const unsigned int maxArgs; FunctionName(const VectorOfASTNodes &args, XPath2MemoryManager* memMgr); /** * Called during static analysis to determine if statically correct. * Performs constant folding if the function has an argument, and it * is constant. */ virtual ASTNode* staticResolution(StaticContext *context); virtual ASTNode *staticTyping(StaticContext *context); /** Returns the namespace unaware name of the node. Takes an optional nodelist, and returns an empty string if the node has no name. Uses the current context if a nodelist is not specified. */ Sequence createSequence(DynamicContext* context, int flags=0) const; }; #endif // _FUNCTIONNAME_HPP