mirror of
https://github.com/jezhiggins/arabica
synced 2025-01-14 08:01:49 +01:00
171 lines
4.5 KiB
C++
171 lines
4.5 KiB
C++
#ifndef ARABICA_LOCATOR_IMPL_H
|
|
#define ARABICA_LOCATOR_IMPL_H
|
|
|
|
// LocatorImpl.h
|
|
// $Id$
|
|
|
|
#include <SAX/ArabicaConfig.h>
|
|
#include <string>
|
|
#include <Locator.h>
|
|
|
|
namespace SAX
|
|
{
|
|
|
|
/**
|
|
* Provide an optional convenience implementation of Locator.
|
|
*
|
|
* <p>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:</p>
|
|
*
|
|
* <pre>
|
|
* 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;
|
|
* }
|
|
*</pre>
|
|
*
|
|
* <p>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.</p>
|
|
*
|
|
* @since SAX 1.0
|
|
* @author Jez Higgins,
|
|
* <a href="mailto:jez@jezuk.co.uk">jez@jezuk.co.uk</a>
|
|
* @version 2.0
|
|
* @see basic_Locator Locator
|
|
*/
|
|
template<class string_type>
|
|
class basic_LocatorImpl : public basic_Locator<string_type>
|
|
{
|
|
public:
|
|
typedef string_type stringT;
|
|
typedef basic_Locator<stringT> 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<std::string> LocatorImpl;
|
|
#ifndef ARABICA_NO_WCHAR_T
|
|
typedef basic_LocatorImpl<std::wstring> wLocatorImpl;
|
|
#endif
|
|
|
|
}; // namespace SAX
|
|
|
|
#endif
|
|
//end of file
|