From 20d28e80a5c861a9d5f449ea911ab75b4f37ad0d Mon Sep 17 00:00:00 2001 From: Jef Date: Tue, 24 Sep 2024 14:54:57 +0200 Subject: Initial community commit --- Src/Wasabi/api/wnd/wndclass/svcwndhold.cpp | 53 ++++++++++++++++++++++++++++++ 1 file changed, 53 insertions(+) create mode 100644 Src/Wasabi/api/wnd/wndclass/svcwndhold.cpp (limited to 'Src/Wasabi/api/wnd/wndclass/svcwndhold.cpp') diff --git a/Src/Wasabi/api/wnd/wndclass/svcwndhold.cpp b/Src/Wasabi/api/wnd/wndclass/svcwndhold.cpp new file mode 100644 index 00000000..9620ce4d --- /dev/null +++ b/Src/Wasabi/api/wnd/wndclass/svcwndhold.cpp @@ -0,0 +1,53 @@ +#include + +#include "svcwndhold.h" + +#include + +#include + +#include + +ServiceWndHolder::ServiceWndHolder(ifc_window *_child, svc_windowCreate *_svc) : + child(NULL), svc(NULL) + { + setChild(_child, _svc); +} + +ServiceWndHolder::~ServiceWndHolder() +{ + if (svc != NULL) + { + svc->destroyWindow(child); + if (!svc->refcount()) + WASABI_API_SVC->service_release(svc); + } else { + delete static_cast(child); + } +} + +int ServiceWndHolder::setChild(ifc_window *_child, svc_windowCreate *_svc) +{ + if (child == _child && svc == _svc) return 0; + + if (child != NULL) { + if (svc != NULL) { + svc->destroyWindow(child); + if (!svc->refcount()) + WASABI_API_SVC->service_release(svc); + svc = NULL; + } else { + delete static_cast(child); + } + child = NULL; + } + + child = _child; + svc = _svc; + + return 1; +} + +ifc_window *ServiceWndHolder::rootwndholder_getRootWnd() { + return child ? child : SERVICEWNDHOLDER_PARENT::rootwndholder_getRootWnd(); +} -- cgit