Continued implementing Windows lifetime code. Now for uiTab.
This commit is contained in:
parent
8dcdbd0878
commit
efd94b2528
|
@ -102,6 +102,7 @@ struct parent {
|
||||||
intmax_t marginTop;
|
intmax_t marginTop;
|
||||||
intmax_t marginRight;
|
intmax_t marginRight;
|
||||||
intmax_t marginBottom;
|
intmax_t marginBottom;
|
||||||
|
BOOL canDestroy;
|
||||||
};
|
};
|
||||||
|
|
||||||
static LRESULT CALLBACK parentWndProc(HWND hwnd, UINT uMsg, WPARAM wParam, LPARAM lParam)
|
static LRESULT CALLBACK parentWndProc(HWND hwnd, UINT uMsg, WPARAM wParam, LPARAM lParam)
|
||||||
|
@ -158,7 +159,8 @@ static LRESULT CALLBACK parentWndProc(HWND hwnd, UINT uMsg, WPARAM wParam, LPARA
|
||||||
pp = (struct parent *) (p->Internal);
|
pp = (struct parent *) (p->Internal);
|
||||||
switch (uMsg) {
|
switch (uMsg) {
|
||||||
case WM_NCDESTROY:
|
case WM_NCDESTROY:
|
||||||
// no need to explicitly destroy children; they're already gone by this point (and so are their data structures; they clean up after themselves)
|
if (!pp->canDestroy)
|
||||||
|
complain("attempt to destroy uiParent at %p before uiParentDestroy()", p);
|
||||||
uiFree(p->Internal);
|
uiFree(p->Internal);
|
||||||
uiFree(p);
|
uiFree(p);
|
||||||
break; // fall through to DefWindowPocW()
|
break; // fall through to DefWindowPocW()
|
||||||
|
@ -215,6 +217,14 @@ static void parentDestroy(uiParent *pp)
|
||||||
{
|
{
|
||||||
struct parent *p = (struct parent *) (pp->Internal);
|
struct parent *p = (struct parent *) (pp->Internal);
|
||||||
|
|
||||||
|
// first destroy the main control, if any
|
||||||
|
if (p->mainControl != NULL) {
|
||||||
|
uiControlDestroy(p->mainControl);
|
||||||
|
p->mainControl = NULL;
|
||||||
|
}
|
||||||
|
// then mark that we are ready to destroy
|
||||||
|
p->canDestroy = TRUE;
|
||||||
|
// and finally destroy
|
||||||
if (DestroyWindow(p->hwnd) == 0)
|
if (DestroyWindow(p->hwnd) == 0)
|
||||||
logLastError("error destroying uiParent window in parentDestroy()");
|
logLastError("error destroying uiParent window in parentDestroy()");
|
||||||
}
|
}
|
||||||
|
|
|
@ -9,6 +9,7 @@ struct window {
|
||||||
int (*onClosing)(uiWindow *, void *);
|
int (*onClosing)(uiWindow *, void *);
|
||||||
void *onClosingData;
|
void *onClosingData;
|
||||||
int margined;
|
int margined;
|
||||||
|
BOOL canDestroy;
|
||||||
};
|
};
|
||||||
|
|
||||||
#define uiWindowClass L"uiWindowClass"
|
#define uiWindowClass L"uiWindowClass"
|
||||||
|
@ -42,10 +43,11 @@ static LRESULT CALLBACK uiWindowWndProc(HWND hwnd, UINT uMsg, WPARAM wParam, LPA
|
||||||
return 0;
|
return 0;
|
||||||
case WM_CLOSE:
|
case WM_CLOSE:
|
||||||
if (!(*(w->onClosing))(uiWindow(w), w->onClosingData))
|
if (!(*(w->onClosing))(uiWindow(w), w->onClosingData))
|
||||||
return 0;
|
uiWindowDestroy(uiWindow(w));
|
||||||
break; // fall through to DefWindowProcW()
|
return 0; // we destroyed it already
|
||||||
case WM_DESTROY:
|
case WM_DESTROY:
|
||||||
// no need to free the child ourselves; it'll destroy itself after we leave this handler
|
if (!w->canDestroy)
|
||||||
|
complain("attempt to destroy uiWindow at %p before uiWindowDestroy()", w);
|
||||||
uiFree(w);
|
uiFree(w);
|
||||||
break; // fall through to DefWindowProcW()
|
break; // fall through to DefWindowProcW()
|
||||||
}
|
}
|
||||||
|
@ -78,6 +80,12 @@ static void windowDestroy(uiWindow *ww)
|
||||||
{
|
{
|
||||||
struct window *w = (struct window *) ww;
|
struct window *w = (struct window *) ww;
|
||||||
|
|
||||||
|
// first destroy the content
|
||||||
|
uiParentDestroy(w->content);
|
||||||
|
// then mark that we're ready to destroy
|
||||||
|
w->canDestroy = TRUE;
|
||||||
|
// and finally destroy
|
||||||
|
// TODO check for errors
|
||||||
DestroyWindow(w->hwnd);
|
DestroyWindow(w->hwnd);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue