From 1a1f26d9e4ab6a4fe51baa78e40c4cdf3f402bcf Mon Sep 17 00:00:00 2001 From: Sine Striker <trueful@163.com> Date: ćšć, 07 12æ 2023 14:27:00 +0800 Subject: [PATCH] Add context factory --- src/core/contexts/abstractwindowcontext.cpp | 22 +++++++++++++++++----- 1 files changed, 17 insertions(+), 5 deletions(-) diff --git a/src/core/contexts/abstractwindowcontext.cpp b/src/core/contexts/abstractwindowcontext.cpp index 654f918..679a9ee 100644 --- a/src/core/contexts/abstractwindowcontext.cpp +++ b/src/core/contexts/abstractwindowcontext.cpp @@ -2,14 +2,26 @@ namespace QWK { - AbstractWindowContext::AbstractWindowContext(const QObject *host, const WindowItemDelegate *delegate) - : m_host(host), m_delegate(delegate), m_windowHandle(delegate->hostWindow(host)) { + AbstractWindowContext::AbstractWindowContext() + : m_host(nullptr), m_delegate(nullptr), m_windowHandle(nullptr) { } - AbstractWindowContext::~AbstractWindowContext() { - if (m_delegate) { - delete m_delegate; + AbstractWindowContext::~AbstractWindowContext() = default; + + bool AbstractWindowContext::setup(QObject *host, WindowItemDelegate *delegate) { + if (!host || !delegate) { + return false; } + + auto windowHandle = delegate->hostWindow(host); + if (!windowHandle) { + return false; + } + + m_host = host; + m_delegate.reset(delegate); + m_windowHandle = windowHandle; + return true; } bool AbstractWindowContext::setHitTestVisible(const QObject *obj, bool visible) { -- Gitblit v1.9.1