From f041cd599f2ba58906958f6886b9cd25e180d0af Mon Sep 17 00:00:00 2001
From: Yuhang Zhao <zhaoyuhang@rankyee.com>
Date: 周三, 06 12月 2023 10:28:34 +0800
Subject: [PATCH] add more const

---
 src/widgets/widgetitemdelegate.cpp |   37 +++++++++++++++++++++++++++----------
 1 files changed, 27 insertions(+), 10 deletions(-)

diff --git a/src/widgets/widgetitemdelegate.cpp b/src/widgets/widgetitemdelegate.cpp
index 9d338c1..6378f36 100644
--- a/src/widgets/widgetitemdelegate.cpp
+++ b/src/widgets/widgetitemdelegate.cpp
@@ -12,16 +12,16 @@
 
     WidgetItemDelegate::~WidgetItemDelegate() = default;
 
-    QWindow *WidgetItemDelegate::window(QObject *obj) const {
-        return static_cast<QWidget *>(obj)->windowHandle();
+    QWindow *WidgetItemDelegate::window(const QObject *obj) const {
+        return static_cast<const QWidget *>(obj)->windowHandle();
     }
 
-    bool WidgetItemDelegate::isEnabled(QObject *obj) const {
-        return static_cast<QWidget *>(obj)->isEnabled();
+    bool WidgetItemDelegate::isEnabled(const QObject *obj) const {
+        return static_cast<const QWidget *>(obj)->isEnabled();
     }
 
-    bool WidgetItemDelegate::isVisible(QObject *obj) const {
-        return static_cast<QWidget *>(obj)->isVisible();
+    bool WidgetItemDelegate::isVisible(const QObject *obj) const {
+        return static_cast<const QWidget *>(obj)->isVisible();
     }
 
     QRect WidgetItemDelegate::mapGeometryToScene(const QObject *obj) const {
@@ -31,17 +31,34 @@
         return {originPoint, size};
     }
 
-    QWindow *WidgetItemDelegate::hostWindow(QObject *host) const {
-        return static_cast<QWidget *>(host)->windowHandle();
+    QWindow *WidgetItemDelegate::hostWindow(const QObject *host) const {
+        return static_cast<const QWidget *>(host)->windowHandle();
     }
 
-    bool WidgetItemDelegate::isHostSizeFixed(QObject *host) const {
+    bool WidgetItemDelegate::isHostSizeFixed(const QObject *host) const {
+        const auto widget = static_cast<const QWidget *>(host);
+        // "Qt::MSWindowsFixedSizeDialogHint" is used cross-platform actually.
+        if (widget->windowFlags() & Qt::MSWindowsFixedSizeDialogHint) {
+            return true;
+        }
+        // Caused by setFixedWidth/Height/Size().
+        const QSize minSize = widget->minimumSize();
+        const QSize maxSize = widget->maximumSize();
+        if (!minSize.isEmpty() && !maxSize.isEmpty() && (minSize == maxSize)) {
+            return true;
+        }
+        // Usually set by the user.
+        const QSizePolicy sizePolicy = widget->sizePolicy();
+        if ((sizePolicy.horizontalPolicy() == QSizePolicy::Fixed)
+            && (sizePolicy.verticalPolicy() == QSizePolicy::Fixed)) {
+            return true;
+        }
         return false;
     }
 
     bool WidgetItemDelegate::resetQtGrabbedControl() const {
         if (qt_button_down) {
-            static constexpr const auto invalidPos = QPoint{-99999, -99999};
+            static constexpr const auto invalidPos = QPoint{std::numeric_limits<int>::lowest(), std::numeric_limits<int>::lowest()};
             const auto event =
                 new QMouseEvent(QEvent::MouseButtonRelease, invalidPos, invalidPos, invalidPos,
                                 Qt::LeftButton, QGuiApplication::mouseButtons() ^ Qt::LeftButton,

--
Gitblit v1.9.1