#ifndef ARABICA_LOCATOR_IMPL_H #define ARABICA_LOCATOR_IMPL_H // LocatorImpl.h // $Id$ #include #include #include namespace Arabica { namespace SAX { /** * Provide an optional convenience implementation of Locator. * *

This class is available mainly for application writers, who * can use it to make a persistent snapshot of a locator at any * point during a document parse:

* *
 * Locator locator;
 * LocatorImpl startloc;
 *
 * void setLocator(const Locator& locator)
 * {
 *   // note the locator
 *   this.locator = &locator;
 * }
 *
 * void startDocument ()
 * {
 *   // save the location of the start of the document
 *   // for future use.
 *   startloc = locator;
 * }
 *
* *

Normally, parser writers will not use this class, since it * is more efficient to provide location information only when * requested, rather than constantly updating a Locator object.

* * @since SAX 1.0 * @author Jez Higgins, * jez@jezuk.co.uk * @version 2.0 * @see basic_Locator Locator */ template class basic_LocatorImpl : public basic_Locator { public: typedef string_type stringT; typedef basic_Locator LocatorT; basic_LocatorImpl() : publicId_(), systemId_(), lineNumber_(-1), columnNumber_(-1) { } // basic_LocatorImpl basic_LocatorImpl(const LocatorT& rhs) : publicId_(rhs.getPublicId()), systemId_(rhs.getSystemId()), lineNumber_(rhs.getLineNumber()), columnNumber_(rhs.getColumnNumber()) { } // basic_LocatorImpl virtual ~basic_LocatorImpl() { } basic_LocatorImpl& operator=(const LocatorT& rhs) { publicId_ = rhs.getPublicId(); systemId_ = rhs.getSystemId(); lineNumber_ = rhs.getLineNumber(); columnNumber_ = rhs.getColumnNumber(); } // operator= ////////////////////////////////////////////////////////////////////// // Implementation of Locator /** * Return the saved public identifier. * * @return The public identifier as a string, or an empty string if none * is available. * @see basic_Locator#getPublicId * @see #setPublicId */ virtual stringT getPublicId() const { return publicId_; } /** * Return the saved system identifier. * * @return The system identifier as a string, or an empty string if none * is available. * @see basic_Locator#getSystemId * @see #setSystemId */ virtual stringT getSystemId() const { return systemId_; } /** * Return the saved line number (1-based). * * @return The line number as an integer, or -1 if none is available. * @see basic_Locator#getLineNumber * @see #setLineNumber */ virtual int getLineNumber() const { return lineNumber_; } /** * Return the saved column number (1-based). * * @return The column number as an integer, or -1 if none is available. * @see basic_Locator#getColumnNumber * @see #setColumnNumber */ virtual int getColumnNumber() const { return columnNumber_; } ////////////////////////////////////////////////////////////////////// // Setters for the properties (not in Locator) /** * Set the public identifier for this locator. * * @param publicId The new public identifier, or an empty string * if none is available. * @see #getPublicId */ void setPublicId(const stringT& publicId) { publicId_ = publicId; } /** * Set the system identifier for this locator. * * @param systemId The new system identifier, or an empty string * if none is available. * @see #getSystemId */ void setSystemId(const stringT& systemId) { systemId_ = systemId; } /** * Set the line number for this locator (1-based). * * @param lineNumber The line number, or -1 if none is available. * @see #getLineNumber */ void setLineNumber(int lineNumber) { lineNumber_ = lineNumber; } /** * Set the column number for this locator (1-based). * * @param columnNumber The column number, or -1 if none is available. * @see #getColumnNumber */ void setColumnNumber(int columnNumber) { columnNumber_ = columnNumber; } private: ////////////////////////////////////////////////////////////////////// // Internal state. stringT publicId_; stringT systemId_; int lineNumber_; int columnNumber_; bool operator==(const LocatorT& rhs) const; }; // class LocatorImpl typedef basic_LocatorImpl LocatorImpl; #ifndef ARABICA_NO_WCHAR_T typedef basic_LocatorImpl wLocatorImpl; #endif } // namespace SAX } // namespace Arabica #endif //end of file