/**************************************************************************** ** ** Copyright (C) 2016 The Qt Company Ltd. ** Contact: https://www.qt.io/licensing/ ** ** This file is part of the QtXmlPatterns module of the Qt Toolkit. ** ** $QT_BEGIN_LICENSE:LGPL$ ** Commercial License Usage ** Licensees holding valid commercial Qt licenses may use this file in ** accordance with the commercial license agreement provided with the ** Software or, alternatively, in accordance with the terms contained in ** a written agreement between you and The Qt Company. For licensing terms ** and conditions see https://www.qt.io/terms-conditions. For further ** information use the contact form at https://www.qt.io/contact-us. ** ** GNU Lesser General Public License Usage ** Alternatively, this file may be used under the terms of the GNU Lesser ** General Public License version 3 as published by the Free Software ** Foundation and appearing in the file LICENSE.LGPL3 included in the ** packaging of this file. Please review the following information to ** ensure the GNU Lesser General Public License version 3 requirements ** will be met: https://www.gnu.org/licenses/lgpl-3.0.html. ** ** GNU General Public License Usage ** Alternatively, this file may be used under the terms of the GNU ** General Public License version 2.0 or (at your option) the GNU General ** Public license version 3 or any later version approved by the KDE Free ** Qt Foundation. The licenses are as published by the Free Software ** Foundation and appearing in the file LICENSE.GPL2 and LICENSE.GPL3 ** included in the packaging of this file. Please review the following ** information to ensure the GNU General Public License requirements will ** be met: https://www.gnu.org/licenses/gpl-2.0.html and ** https://www.gnu.org/licenses/gpl-3.0.html. ** ** $QT_END_LICENSE$ ** ****************************************************************************/ #include "qxmldebug_p.h" #include "qsourcelocation.h" QT_BEGIN_NAMESPACE /*! \class QSourceLocation \reentrant \since 4.4 \brief The QSourceLocation class identifies a location in a resource by URI, line, and column. \ingroup xml-tools \inmodule QtXmlPatterns QSourceLocation is a simple value based class that has three properties, uri(), line(), and column(), that, taken together, identify a certain point in a resource, e.g., a file or an in-memory document. line() and column() refer to character counts (not byte counts), and they both start from 1, as opposed to 0. */ /*! Construct a QSourceLocation that doesn't identify anything at all. For a default constructed QSourceLocation(), isNull() returns \c true. */ QSourceLocation::QSourceLocation() : m_line(-1), m_column(-1) { } /*! Constructs a QSourceLocation that is a copy of \a other. */ QSourceLocation::QSourceLocation(const QSourceLocation &other) : m_line(other.m_line), m_column(other.m_column), m_uri(other.m_uri) { } /*! Constructs a QSourceLocation with URI \a u, line \a l and column \a c. */ QSourceLocation::QSourceLocation(const QUrl &u, int l, int c) : m_line(l), m_column(c), m_uri(u) { } /*! Destructor. */ QSourceLocation::~QSourceLocation() { } /*! Returns \c true if this QSourceLocation is equal to \a other; \c false otherwise. Two QSourceLocation instances are equal if their uri(), line() and column() are equal. QSourceLocation instances for which isNull() returns true are considered equal. */ bool QSourceLocation::operator==(const QSourceLocation &other) const { return m_line == other.m_line && m_column == other.m_column && m_uri == other.m_uri; } /*! Returns \c true if this QSourceLocation is not equal to \a other; \c false otherwise. */ bool QSourceLocation::operator!=(const QSourceLocation &other) const { return !operator==(other); } /*! Assigns this QSourceLocation instance to \a other. */ QSourceLocation &QSourceLocation::operator=(const QSourceLocation &other) { if(this != &other) { m_line = other.m_line; m_column = other.m_column; m_uri = other.m_uri; } return *this; } /*! Returns the current column number. The column number refers to the count of characters, not bytes. The first column is column 1, not 0. The default value is -1, indicating the column number is unknown. */ qint64 QSourceLocation::column() const { return m_column; } /*! Sets the column number to \a newColumn. 0 is an invalid column number. The first column number is 1. */ void QSourceLocation::setColumn(qint64 newColumn) { Q_ASSERT_X(newColumn != 0, Q_FUNC_INFO, "0 is an invalid column number. The first column number is 1."); m_column = newColumn; } /*! Returns the current line number. The first line number is 1, not 0. The default value is -1, indicating the line number is unknown. */ qint64 QSourceLocation::line() const { return m_line; } /*! Sets the line number to \a newLine. 0 is an invalid line number. The first line number is 1. */ void QSourceLocation::setLine(qint64 newLine) { m_line = newLine; } /*! Returns the resource that this QSourceLocation refers to. For example, the resource could be a file in the local file system, if the URI scheme is \c file. */ QUrl QSourceLocation::uri() const { return m_uri; } /*! Sets the URI to \a newUri. */ void QSourceLocation::setUri(const QUrl &newUri) { m_uri = newUri; } /*! \relates QSourceLocation \since 4.4 Prints \a sourceLocation to the debug stream \a debug. */ #ifndef QT_NO_DEBUG_STREAM QDebug operator<<(QDebug debug, const QSourceLocation &sourceLocation) { debug << "QSourceLocation(" << sourceLocation.uri() << ", line:" << sourceLocation.line() << ", column:" << sourceLocation.column() << ')'; return debug; } #endif /*! Returns \c true if this QSourceLocation doesn't identify anything. For a default constructed QSourceLocation, this function returns \c true. The same applies for any other QSourceLocation whose uri() is invalid. */ bool QSourceLocation::isNull() const { return !m_uri.isValid(); } /*! \since 4.4 Computes a hash key for the QSourceLocation \a location. \relates QSourceLocation */ uint qHash(const QSourceLocation &location) { /* Not the world's best hash function exactly. */ return qHash(location.uri().toString()) + location.line() + location.column(); } QT_END_NAMESPACE