/* * 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: XQContextItem.hpp,v 1.11 2007/11/28 13:13:20 jpcs Exp $ */ #ifndef _XQCONTEXTITEM_HPP #define _XQCONTEXTITEM_HPP #include #include #include /** Returns the context item. Raises [err:XP0002] if the context item is null. */ class XQILLA_API XQContextItem : public ASTNodeImpl { public: XQContextItem(XPath2MemoryManager* memMgr); ~XQContextItem(); /** * Called during static analysis of expression to determine is statically * correct. If not an appropriate error is thrown. */ virtual ASTNode* staticResolution(StaticContext *context); virtual ASTNode *staticTyping(StaticContext *context); virtual Result createResult(DynamicContext* context, int flags=0) const; class XQILLA_API ContextItemResult : public SingleResult { public: ContextItemResult(const LocationInfo *location); Item::Ptr getSingleResult(DynamicContext *context) const; std::string asString(DynamicContext *context, int indent) const; }; }; #endif