| /**************************************************************************** |
| ** |
| ** Copyright (C) 2018 The Qt Company Ltd. |
| ** Contact: https://www.qt.io/licensing/ |
| ** |
| ** This file is part of the QtSCriptTools 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 "qscriptbreakpointdata_p.h" |
| |
| #include <QtCore/qdatastream.h> |
| #include <QtCore/qstring.h> |
| #include <QtCore/qvariant.h> |
| |
| QT_BEGIN_NAMESPACE |
| |
| /*! |
| \since 4.5 |
| \class QScriptBreakpointData |
| \internal |
| |
| \brief The QScriptBreakpointData class contains data associated with a breakpoint. |
| */ |
| |
| class QScriptBreakpointDataPrivate |
| { |
| public: |
| QScriptBreakpointDataPrivate(); |
| ~QScriptBreakpointDataPrivate(); |
| |
| void init(int ln); |
| |
| qint64 scriptId; |
| QString fileName; |
| int lineNumber; |
| bool enabled; |
| bool singleShot; |
| int ignoreCount; |
| QString condition; |
| QVariant data; |
| int hitCount; |
| }; |
| |
| QScriptBreakpointDataPrivate::QScriptBreakpointDataPrivate() |
| { |
| } |
| |
| QScriptBreakpointDataPrivate::~QScriptBreakpointDataPrivate() |
| { |
| } |
| |
| void QScriptBreakpointDataPrivate::init(int ln) |
| { |
| scriptId = -1; |
| lineNumber = ln; |
| enabled = true; |
| singleShot = false; |
| ignoreCount = 0; |
| hitCount = 0; |
| } |
| |
| /*! |
| Constructs an empty QScriptBreakpointData. |
| */ |
| QScriptBreakpointData::QScriptBreakpointData() |
| : d_ptr(new QScriptBreakpointDataPrivate) |
| { |
| d_ptr->init(/*lineNumber=*/-1); |
| } |
| |
| /*! |
| Constructs a QScriptBreakpointData with the given \a lineNumber. |
| */ |
| QScriptBreakpointData::QScriptBreakpointData(qint64 scriptId, int lineNumber) |
| : d_ptr(new QScriptBreakpointDataPrivate) |
| { |
| d_ptr->init(lineNumber); |
| d_ptr->scriptId = scriptId; |
| } |
| |
| /*! |
| Constructs a QScriptBreakpointData with the given \a lineNumber. |
| */ |
| QScriptBreakpointData::QScriptBreakpointData(const QString &fileName, int lineNumber) |
| : d_ptr(new QScriptBreakpointDataPrivate) |
| { |
| d_ptr->init(lineNumber); |
| d_ptr->fileName = fileName; |
| } |
| |
| /*! |
| Constructs a QScriptBreakpointData that is a copy of \a other. |
| */ |
| QScriptBreakpointData::QScriptBreakpointData(const QScriptBreakpointData &other) |
| : d_ptr(new QScriptBreakpointDataPrivate) |
| { |
| Q_ASSERT(other.d_ptr != 0); |
| *d_ptr = *other.d_ptr; |
| } |
| |
| /*! |
| Destroys this QScriptBreakpointData. |
| */ |
| QScriptBreakpointData::~QScriptBreakpointData() |
| { |
| } |
| |
| /*! |
| Assigns \a other to this QScriptBreakpointData. |
| */ |
| QScriptBreakpointData &QScriptBreakpointData::operator=(const QScriptBreakpointData &other) |
| { |
| Q_ASSERT(d_ptr != 0); |
| Q_ASSERT(other.d_ptr != 0); |
| *d_ptr = *other.d_ptr; |
| return *this; |
| } |
| |
| qint64 QScriptBreakpointData::scriptId() const |
| { |
| Q_D(const QScriptBreakpointData); |
| return d->scriptId; |
| } |
| |
| void QScriptBreakpointData::setScriptId(qint64 id) |
| { |
| Q_D(QScriptBreakpointData); |
| d->scriptId = id; |
| } |
| |
| QString QScriptBreakpointData::fileName() const |
| { |
| Q_D(const QScriptBreakpointData); |
| return d->fileName; |
| } |
| |
| void QScriptBreakpointData::setFileName(const QString &fileName) |
| { |
| Q_D(QScriptBreakpointData); |
| d->fileName = fileName; |
| } |
| |
| /*! |
| Returns the breakpoint line number. |
| */ |
| int QScriptBreakpointData::lineNumber() const |
| { |
| Q_D(const QScriptBreakpointData); |
| return d->lineNumber; |
| } |
| |
| /*! |
| Sets the breakpoint line number to \a lineNumber. |
| */ |
| void QScriptBreakpointData::setLineNumber(int lineNumber) |
| { |
| Q_D(QScriptBreakpointData); |
| d->lineNumber = lineNumber; |
| } |
| |
| /*! |
| Returns true if the breakpoint is enabled, false otherwise. |
| */ |
| bool QScriptBreakpointData::isEnabled() const |
| { |
| Q_D(const QScriptBreakpointData); |
| return d->enabled; |
| } |
| |
| /*! |
| Sets the \a enabled state of the breakpoint. |
| */ |
| void QScriptBreakpointData::setEnabled(bool enabled) |
| { |
| Q_D(QScriptBreakpointData); |
| d->enabled = enabled; |
| } |
| |
| /*! |
| Returns true if the breakpoint is single-shot, false otherwise. |
| */ |
| bool QScriptBreakpointData::isSingleShot() const |
| { |
| Q_D(const QScriptBreakpointData); |
| return d->singleShot; |
| } |
| |
| /*! |
| Sets the \a singleShot state of the breakpoint. |
| */ |
| void QScriptBreakpointData::setSingleShot(bool singleShot) |
| { |
| Q_D(QScriptBreakpointData); |
| d->singleShot = singleShot; |
| } |
| |
| /*! |
| Returns the ignore count of the breakpoint. |
| */ |
| int QScriptBreakpointData::ignoreCount() const |
| { |
| Q_D(const QScriptBreakpointData); |
| return d->ignoreCount; |
| } |
| |
| /*! |
| Sets the ignore \a count of the breakpoint. |
| */ |
| void QScriptBreakpointData::setIgnoreCount(int count) |
| { |
| Q_D(QScriptBreakpointData); |
| d->ignoreCount = count; |
| } |
| |
| /*! |
| If the ignore count is 0, this function increments the hit count and |
| returns true. Otherwise, it decrements the ignore count and returns |
| false. |
| */ |
| bool QScriptBreakpointData::hit() |
| { |
| Q_D(QScriptBreakpointData); |
| if (d->ignoreCount == 0) { |
| ++d->hitCount; |
| return true; |
| } |
| --d->ignoreCount; |
| return false; |
| } |
| |
| /*! |
| Returns the hit count of the breakpoint (the number of times the |
| breakpoint has been triggered). |
| */ |
| int QScriptBreakpointData::hitCount() const |
| { |
| Q_D(const QScriptBreakpointData); |
| return d->hitCount; |
| } |
| |
| /*! |
| Returns the condition of the breakpoint. |
| */ |
| QString QScriptBreakpointData::condition() const |
| { |
| Q_D(const QScriptBreakpointData); |
| return d->condition; |
| } |
| |
| /*! |
| Sets the \a condition of the breakpoint. |
| */ |
| void QScriptBreakpointData::setCondition(const QString &condition) |
| { |
| Q_D(QScriptBreakpointData); |
| d->condition = condition; |
| } |
| |
| /*! |
| Returns custom data associated with the breakpoint. |
| */ |
| QVariant QScriptBreakpointData::data() const |
| { |
| Q_D(const QScriptBreakpointData); |
| return d->data; |
| } |
| |
| /*! |
| Sets custom \a data associated with the breakpoint. |
| */ |
| void QScriptBreakpointData::setData(const QVariant &data) |
| { |
| Q_D(QScriptBreakpointData); |
| d->data = data; |
| } |
| |
| bool QScriptBreakpointData::isValid() const |
| { |
| Q_D(const QScriptBreakpointData); |
| return (((d->scriptId != -1) || !d->fileName.isEmpty()) |
| && (d->lineNumber != -1)); |
| } |
| |
| /*! |
| Returns true if this QScriptBreakpointData is equal to the \a other |
| data, otherwise returns false. |
| */ |
| bool QScriptBreakpointData::operator==(const QScriptBreakpointData &other) const |
| { |
| Q_D(const QScriptBreakpointData); |
| const QScriptBreakpointDataPrivate *od = other.d_func(); |
| if (d == od) |
| return true; |
| if (!d || !od) |
| return false; |
| return ((d->scriptId == od->scriptId) |
| && (d->fileName == od->fileName) |
| && (d->lineNumber == od->lineNumber) |
| && (d->enabled == od->enabled) |
| && (d->singleShot == od->singleShot) |
| && (d->condition == od->condition) |
| && (d->ignoreCount == od->ignoreCount) |
| && (d->data == od->data) |
| && (d->hitCount == od->hitCount)); |
| } |
| |
| /*! |
| Returns true if this QScriptBreakpointData is not equal to the \a |
| other data, otherwise returns false. |
| */ |
| bool QScriptBreakpointData::operator!=(const QScriptBreakpointData &other) const |
| { |
| return !(*this == other); |
| } |
| |
| /*! |
| \relates QScriptBreakpointData |
| |
| Writes the given \a data to the specified \a stream. |
| */ |
| QDataStream &operator<<(QDataStream &out, const QScriptBreakpointData &data) |
| { |
| const QScriptBreakpointDataPrivate *d = data.d_ptr.data(); |
| out << d->scriptId; |
| out << d->fileName; |
| out << d->lineNumber; |
| out << d->enabled; |
| out << d->singleShot; |
| out << d->ignoreCount; |
| out << d->condition; |
| out << d->data; |
| out << d->hitCount; |
| return out; |
| } |
| |
| /*! |
| \relates QScriptBreakpointData |
| |
| Reads a QScriptBreakpointData from the specified \a stream into the |
| given \a data. |
| */ |
| QDataStream &operator>>(QDataStream &in, QScriptBreakpointData &data) |
| { |
| QScriptBreakpointDataPrivate *d = data.d_ptr.data(); |
| in >> d->scriptId; |
| in >> d->fileName; |
| in >> d->lineNumber; |
| in >> d->enabled; |
| in >> d->singleShot; |
| in >> d->ignoreCount; |
| in >> d->condition; |
| in >> d->data; |
| in >> d->hitCount; |
| return in; |
| } |
| |
| QT_END_NAMESPACE |