diff options
Diffstat (limited to 'src/gui/painting/qfixed_p.h')
-rw-r--r-- | src/gui/painting/qfixed_p.h | 129 |
1 files changed, 50 insertions, 79 deletions
diff --git a/src/gui/painting/qfixed_p.h b/src/gui/painting/qfixed_p.h index 7580069153..c0a13d057f 100644 --- a/src/gui/painting/qfixed_p.h +++ b/src/gui/painting/qfixed_p.h @@ -1,41 +1,5 @@ -/**************************************************************************** -** -** Copyright (C) 2016 The Qt Company Ltd. -** Contact: https://www.qt.io/licensing/ -** -** This file is part of the QtGui 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$ -** -****************************************************************************/ +// Copyright (C) 2016 The Qt Company Ltd. +// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR LGPL-3.0-only OR GPL-2.0-only OR GPL-3.0-only #ifndef QFIXED_P_H #define QFIXED_P_H @@ -54,6 +18,7 @@ #include <QtGui/private/qtguiglobal_p.h> #include "QtCore/qdebug.h" #include "QtCore/qpoint.h" +#include "QtCore/qnumeric.h" #include "QtCore/qsize.h" QT_BEGIN_NAMESPACE @@ -65,8 +30,7 @@ public: constexpr QFixed() : val(0) {} constexpr QFixed(int i) : val(i * 64) {} constexpr QFixed(long i) : val(i * 64) {} - QFixed &operator=(int i) { val = i * 64; return *this; } - QFixed &operator=(long i) { val = i * 64; return *this; } + constexpr QFixed(long long i) : val(i * 64) {} constexpr static QFixed fromReal(qreal r) { return fromFixed((int)(r*qreal(64))); } constexpr static QFixed fromFixed(int fixed) { return QFixed(fixed,0); } // uses private ctor @@ -84,28 +48,33 @@ public: constexpr inline QFixed operator+(int i) const { return fromFixed(val + i * 64); } constexpr inline QFixed operator+(uint i) const { return fromFixed((val + (i<<6))); } - constexpr inline QFixed operator+(const QFixed &other) const { return fromFixed((val + other.val)); } + constexpr inline QFixed operator+(QFixed other) const { return fromFixed((val + other.val)); } inline QFixed &operator+=(int i) { val += i * 64; return *this; } inline QFixed &operator+=(uint i) { val += (i<<6); return *this; } - inline QFixed &operator+=(const QFixed &other) { val += other.val; return *this; } + inline QFixed &operator+=(QFixed other) { val += other.val; return *this; } constexpr inline QFixed operator-(int i) const { return fromFixed(val - i * 64); } constexpr inline QFixed operator-(uint i) const { return fromFixed((val - (i<<6))); } - constexpr inline QFixed operator-(const QFixed &other) const { return fromFixed((val - other.val)); } + constexpr inline QFixed operator-(QFixed other) const { return fromFixed((val - other.val)); } inline QFixed &operator-=(int i) { val -= i * 64; return *this; } inline QFixed &operator-=(uint i) { val -= (i<<6); return *this; } - inline QFixed &operator-=(const QFixed &other) { val -= other.val; return *this; } + inline QFixed &operator-=(QFixed other) { val -= other.val; return *this; } constexpr inline QFixed operator-() const { return fromFixed(-val); } - constexpr inline bool operator==(const QFixed &other) const { return val == other.val; } - constexpr inline bool operator!=(const QFixed &other) const { return val != other.val; } - constexpr inline bool operator<(const QFixed &other) const { return val < other.val; } - constexpr inline bool operator>(const QFixed &other) const { return val > other.val; } - constexpr inline bool operator<=(const QFixed &other) const { return val <= other.val; } - constexpr inline bool operator>=(const QFixed &other) const { return val >= other.val; } +#define REL_OP(op) \ + friend constexpr bool operator op(QFixed lhs, QFixed rhs) noexcept \ + { return lhs.val op rhs.val; } + REL_OP(==) + REL_OP(!=) + REL_OP(< ) + REL_OP(> ) + REL_OP(<=) + REL_OP(>=) +#undef REL_OP + constexpr inline bool operator!() const { return !val; } inline QFixed &operator/=(int x) { val /= x; return *this; } - inline QFixed &operator/=(const QFixed &o) { + inline QFixed &operator/=(QFixed o) { if (o.val == 0) { val = 0x7FFFFFFFL; } else { @@ -126,7 +95,7 @@ public: inline QFixed operator>>(int d) const { QFixed f = *this; f.val >>= d; return f; } inline QFixed &operator*=(int i) { val *= i; return *this; } inline QFixed &operator*=(uint i) { val *= i; return *this; } - inline QFixed &operator*=(const QFixed &o) { + inline QFixed &operator*=(QFixed o) { bool neg = false; qint64 a = val; qint64 b = o.val; @@ -139,11 +108,10 @@ public: } constexpr inline QFixed operator*(int i) const { return fromFixed(val * i); } constexpr inline QFixed operator*(uint i) const { return fromFixed(val * i); } - inline QFixed operator*(const QFixed &o) const { QFixed f = *this; return (f *= o); } + inline QFixed operator*(QFixed o) const { QFixed f = *this; return (f *= o); } private: constexpr QFixed(qreal i) : val((int)(i*qreal(64))) {} - QFixed &operator=(qreal i) { val = (int)(i*qreal(64)); return *this; } constexpr inline QFixed operator+(qreal i) const { return fromFixed((val + (int)(i*qreal(64)))); } inline QFixed &operator+=(qreal i) { val += (int)(i*64); return *this; } constexpr inline QFixed operator-(qreal i) const { return fromFixed((val - (int)(i*qreal(64)))); } @@ -158,32 +126,35 @@ Q_DECLARE_TYPEINFO(QFixed, Q_PRIMITIVE_TYPE); #define QFIXED_MAX (INT_MAX/256) -constexpr inline int qRound(const QFixed &f) { return f.toInt(); } -constexpr inline int qFloor(const QFixed &f) { return f.floor().truncate(); } - -constexpr inline QFixed operator*(int i, const QFixed &d) { return d*i; } -constexpr inline QFixed operator+(int i, const QFixed &d) { return d+i; } -constexpr inline QFixed operator-(int i, const QFixed &d) { return -(d-i); } -constexpr inline QFixed operator*(uint i, const QFixed &d) { return d*i; } -constexpr inline QFixed operator+(uint i, const QFixed &d) { return d+i; } -constexpr inline QFixed operator-(uint i, const QFixed &d) { return -(d-i); } -// constexpr inline QFixed operator*(qreal d, const QFixed &d2) { return d2*d; } - -constexpr inline bool operator==(const QFixed &f, int i) { return f.value() == i * 64; } -constexpr inline bool operator==(int i, const QFixed &f) { return f.value() == i * 64; } -constexpr inline bool operator!=(const QFixed &f, int i) { return f.value() != i * 64; } -constexpr inline bool operator!=(int i, const QFixed &f) { return f.value() != i * 64; } -constexpr inline bool operator<=(const QFixed &f, int i) { return f.value() <= i * 64; } -constexpr inline bool operator<=(int i, const QFixed &f) { return i * 64 <= f.value(); } -constexpr inline bool operator>=(const QFixed &f, int i) { return f.value() >= i * 64; } -constexpr inline bool operator>=(int i, const QFixed &f) { return i * 64 >= f.value(); } -constexpr inline bool operator<(const QFixed &f, int i) { return f.value() < i * 64; } -constexpr inline bool operator<(int i, const QFixed &f) { return i * 64 < f.value(); } -constexpr inline bool operator>(const QFixed &f, int i) { return f.value() > i * 64; } -constexpr inline bool operator>(int i, const QFixed &f) { return i * 64 > f.value(); } +constexpr inline int qRound(QFixed f) { return f.toInt(); } +constexpr inline int qFloor(QFixed f) { return f.floor().truncate(); } + +constexpr inline QFixed operator*(int i, QFixed d) { return d*i; } +constexpr inline QFixed operator+(int i, QFixed d) { return d+i; } +constexpr inline QFixed operator-(int i, QFixed d) { return -(d-i); } +constexpr inline QFixed operator*(uint i, QFixed d) { return d*i; } +constexpr inline QFixed operator+(uint i, QFixed d) { return d+i; } +constexpr inline QFixed operator-(uint i, QFixed d) { return -(d-i); } +// constexpr inline QFixed operator*(qreal d, QFixed d2) { return d2*d; } + +inline bool qAddOverflow(QFixed v1, QFixed v2, QFixed *r) +{ + int val; + bool result = qAddOverflow(v1.value(), v2.value(), &val); + r->setValue(val); + return result; +} + +inline bool qMulOverflow(QFixed v1, QFixed v2, QFixed *r) +{ + int val; + bool result = qMulOverflow(v1.value(), v2.value(), &val); + r->setValue(val); + return result; +} #ifndef QT_NO_DEBUG_STREAM -inline QDebug &operator<<(QDebug &dbg, const QFixed &f) +inline QDebug &operator<<(QDebug &dbg, QFixed f) { return dbg << f.toReal(); } #endif @@ -191,7 +162,7 @@ struct QFixedPoint { QFixed x; QFixed y; constexpr inline QFixedPoint() {} - constexpr inline QFixedPoint(const QFixed &_x, const QFixed &_y) : x(_x), y(_y) {} + constexpr inline QFixedPoint(QFixed _x, QFixed _y) : x(_x), y(_y) {} constexpr QPointF toPointF() const { return QPointF(x.toReal(), y.toReal()); } constexpr static QFixedPoint fromPointF(const QPointF &p) { return QFixedPoint(QFixed::fromReal(p.x()), QFixed::fromReal(p.y())); |