/* * The Apache Software License, Version 1.1 * * Copyright (c) 2002 The Apache Software Foundation. All rights * reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in * the documentation and/or other materials provided with the * distribution. * * 3. The end-user documentation included with the redistribution, * if any, must include the following acknowledgment: * "This product includes software developed by the * Apache Software Foundation (http://www.apache.org/)." * Alternately, this acknowledgment may appear in the software itself, * if and wherever such third-party acknowledgments normally appear. * * 4. The names "Xerces" and "Apache Software Foundation" must * not be used to endorse or promote products derived from this * software without prior written permission. For written * permission, please contact apache\@apache.org. * * 5. Products derived from this software may not be called "Apache", * nor may "Apache" appear in their name, without prior written * permission of the Apache Software Foundation. * * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE * DISCLAIMED. IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. * ==================================================================== * * This software consists of voluntary contributions made by many * individuals on behalf of the Apache Software Foundation, and was * originally based on software copyright (c) 1999, International * Business Machines, Inc., http://www.ibm.com . For more information * on the Apache Software Foundation, please see * . */ /* * $Log: DOMLocatorImpl.hpp,v $ * Revision 1.5 2003/03/07 18:07:17 tng * Return a reference instead of void for operator= * * Revision 1.4 2002/11/04 15:07:34 tng * C++ Namespace Support. * * Revision 1.3 2002/05/30 19:26:00 knoaman * documentation update * * Revision 1.2 2002/05/27 18:25:41 tng * To get ready for 64 bit large file, use XMLSSize_t to represent line and column number. * * Revision 1.1 2002/05/23 15:47:24 knoaman * DOM L3 core - support for DOMError, DOMErrorHandler and DOMLocator * */ #ifndef DOMLOCATORIMPL_HPP #define DOMLOCATORIMPL_HPP #include XERCES_CPP_NAMESPACE_BEGIN /** * Introduced in DOM Level 3 * * Implementation of a DOMLocator interface. * * @see DOMLocator#DOMLocator */ class CDOM_EXPORT DOMLocatorImpl : public DOMLocator { public: /** @name Constructors and Destructor */ //@{ /** Constructor */ DOMLocatorImpl(); DOMLocatorImpl ( const XMLSSize_t lineNum , const XMLSSize_t columnNum , DOMNode* const errorNode , const XMLCh* const uri , const XMLSSize_t offset = -1 ); /** Desctructor */ virtual ~DOMLocatorImpl(); //@} /** @name Get function */ //@{ /** *

"Experimental - subject to change"

* * Get the line number where the error occured. The value is -1 if there is * no line number available. * * @see #setLineNumber */ virtual XMLSSize_t getLineNumber() const; /** *

"Experimental - subject to change"

* * Get the column number where the error occured. The value is -1 if there * is no column number available. * * @see #setColumnNumber */ virtual XMLSSize_t getColumnNumber() const; /** *

"Experimental - subject to change"

* * Get the byte or character offset into the input source, if we're parsing * a file or a byte stream then this will be the byte offset into that * stream, but if a character media is parsed then the offset will be the * character offset. The value is -1 if there is no offset available. * * @see #setOffset */ virtual XMLSSize_t getOffset() const; /** *

"Experimental - subject to change"

* * Get the DOM Node where the error occured, or null if there * is no node available. * * @see #setErrorNode */ virtual DOMNode* getErrorNode() const; /** *

"Experimental - subject to change"

* * Get the URI where the error occured, or null if there is no * URI available. * * @see #setURI */ virtual const XMLCh* getURI() const; //@} /** @name Set function */ //@{ /** *

"Experimental - subject to change"

* * Set the line number of the error * * @param lineNumber the line number to set * * @see #getLinNumner */ virtual void setLineNumber(const XMLSSize_t lineNumber); /** *

"Experimental - subject to change"

* * Set the column number of the error * * @param columnNumber the column number to set. * * @see #getColumnNumner */ virtual void setColumnNumber(const XMLSSize_t columnNumber); /** *

"Experimental - subject to change"

* * Set the byte/character offset. * * @param offset the byte/characte offset to set. * * @see #getOffset */ virtual void setOffset(const XMLSSize_t offset); /** *

"Experimental - subject to change"

* * Set the DOM Node where the error occured * * @param errorNode the DOM Node to set * * @see #getErrorNode */ virtual void setErrorNode(DOMNode* const errorNode); /** *

"Experimental - subject to change"

* * Set the URI where the error occured * * @param uri the URI to set. * * @see #getURI */ virtual void setURI(const XMLCh* const uri); //@} private : /* Unimplemented constructors and operators */ /* Copy constructor */ DOMLocatorImpl(const DOMLocatorImpl&); /* Assignment operator */ DOMLocatorImpl& operator=(const DOMLocatorImpl&); // ----------------------------------------------------------------------- // Private data members // // fLineNum // fColumnNum // Track line/column number of where the error occured // // fOffset // Track character/byte offset in the input source where the error // occured // // fErrorNode // Current error node where the error occured // // fURI // The uri where the error occured // ----------------------------------------------------------------------- XMLSSize_t fLineNum; XMLSSize_t fColumnNum; XMLSSize_t fOffset; DOMNode* fErrorNode; const XMLCh* fURI; }; // --------------------------------------------------------------------------- // DOMLocatorImpl: Getter methods // --------------------------------------------------------------------------- inline XMLSSize_t DOMLocatorImpl::getLineNumber() const { return fLineNum; } inline XMLSSize_t DOMLocatorImpl::getColumnNumber() const { return fColumnNum; } inline XMLSSize_t DOMLocatorImpl::getOffset() const { return fOffset; } inline DOMNode* DOMLocatorImpl::getErrorNode() const { return fErrorNode; } inline const XMLCh* DOMLocatorImpl::getURI() const { return fURI; } // --------------------------------------------------------------------------- // DOMLocatorImpl: Setter methods // --------------------------------------------------------------------------- inline void DOMLocatorImpl::setLineNumber(const XMLSSize_t lineNumber) { fLineNum = lineNumber; } inline void DOMLocatorImpl::setColumnNumber(const XMLSSize_t columnNumber) { fColumnNum = columnNumber; } inline void DOMLocatorImpl::setOffset(const XMLSSize_t offset) { fOffset = offset; } inline void DOMLocatorImpl::setErrorNode(DOMNode* const errorNode) { fErrorNode = errorNode; } inline void DOMLocatorImpl::setURI(const XMLCh* const uri) { fURI = uri; } XERCES_CPP_NAMESPACE_END #endif