diff options
author | Joel Bodenmann <joel@unormal.org> | 2014-01-05 20:42:19 +0100 |
---|---|---|
committer | Joel Bodenmann <joel@unormal.org> | 2014-01-05 20:42:19 +0100 |
commit | 1778a7f3b1917fceb8bc6b5d48a5548d4e1ee7b9 (patch) | |
tree | faa4489158f4230f57af27e54ae27f9a9b7e8840 | |
parent | f3f3650ca9be377f20fb43159ce18d583f0705c4 (diff) | |
download | uGFX-1778a7f3b1917fceb8bc6b5d48a5548d4e1ee7b9.tar.gz uGFX-1778a7f3b1917fceb8bc6b5d48a5548d4e1ee7b9.tar.bz2 uGFX-1778a7f3b1917fceb8bc6b5d48a5548d4e1ee7b9.zip |
gwinDestroy() and gwinRemoveChild()
-rw-r--r-- | include/gwin/gwin.h | 22 | ||||
-rw-r--r-- | src/gwin/gwin.c | 50 |
2 files changed, 58 insertions, 14 deletions
diff --git a/include/gwin/gwin.h b/include/gwin/gwin.h index ded401d0..73f7ff82 100644 --- a/include/gwin/gwin.h +++ b/include/gwin/gwin.h @@ -389,15 +389,27 @@ extern "C" { /** * @brief Add a child widget to a parent one * - * @param[in] parent The parent widget (does not need to be parent yet) - * @param[in] child The child widget - * @param[in] last Should the child widget be added to the front or the back of the list? + * @param[in] parent The parent window (does not need to be parent yet) + * @param[in] child The child window + * @param[in] last Should the child window be added to the front or the back of the list? * * @api */ void gwinAddChild(GHandle parent, GHandle child, bool_t last); /** + * @brief Remove a child from a parent + * + * @note Other children of the same parent stay + * @note Children of the child are lost, they have to be reassigned manually if necessary. + * + * @param[in] child The child window + * + * @api + */ + void gwinRemoveChild(GHandle child); + + /** * @brief Get first child of a widget * * @return The first child or NULL if the widget has no children @@ -882,6 +894,10 @@ extern "C" { #include "gwin/image.h" #endif + #if GWIN_NEED_LAYOUT || defined(__DOXYGEN__) + #include "gwin/layout.h" + #endif + #endif /* GFX_USE_GWIN */ #endif /* _GWIN_H */ diff --git a/src/gwin/gwin.c b/src/gwin/gwin.c index 88be0c88..923567ef 100644 --- a/src/gwin/gwin.c +++ b/src/gwin/gwin.c @@ -180,18 +180,20 @@ GHandle gwinGWindowCreate(GDisplay *g, GWindowObject *pgw, const GWindowInit *pI } void gwinDestroy(GHandle gh) { + if (!gh) { + // should log a runtime error here + return; + } + #if GWIN_NEED_HIERARCHY - // fix hierarchy structure - if (gh->parent->child == gh) { - // we are the first child - gh->parent->child = gh->sibling; - } else { - // find our predecessor - GHandle tmp = gh->parent->child; - while (tmp->sibling != gh) - tmp = tmp->sibling; - tmp->sibling = gh->sibling; - } + GHandle tmp; + + // recursively destroy our children first + for(tmp = gh->child; tmp; tmp = tmp->sibling) + gwinDestroy(tmp); + + // remove myself from the hierarchy + gwinRemoveChild(gh); #endif // Make the window invisible @@ -332,6 +334,32 @@ void gwinRedraw(GHandle gh) { gwinRedraw(parent); } + void gwinRemoveChild(GHandle gh) { + if(!gh || !gh->parent) { + // without a parent, removing is impossible + // should log a runtime error here + return; + } + + if (gh->parent->child == gh) { + // we are the first child, update parent + gh->parent->child = gh->sibling; + } else { + // otherwise find our predecessor + GHandle tmp = gh->parent->child; + while (tmp && tmp->sibling != gh) + tmp = tmp->sibling; + + if(!tmp) { + // our parent's children list is corrupted + // should log a runtime error here + return; + } + + tmp->sibling = gh->sibling; + } + } + GHandle gwinGetFirstChild(GHandle gh) { return gh->child; } |