diff options
author | Jordan Halase <jordan@halase.me> | 2019-10-22 14:54:47 -0500 |
---|---|---|
committer | David Robillard <d@drobilla.net> | 2019-11-03 20:52:32 +0100 |
commit | a96511e36737284589361616f4fb4c0874095da7 (patch) | |
tree | 673fef8758a901db01ff68eb24108f918dbda4b6 /pugl/detail/mac.m | |
parent | 3d6b80ccb48068b001efd6ff369386e69c21c580 (diff) | |
download | pugl-a96511e36737284589361616f4fb4c0874095da7.tar.gz pugl-a96511e36737284589361616f4fb4c0874095da7.tar.bz2 pugl-a96511e36737284589361616f4fb4c0874095da7.zip |
Fix puglFreeView() crashes when window creation failed
Diffstat (limited to 'pugl/detail/mac.m')
-rw-r--r-- | pugl/detail/mac.m | 27 |
1 files changed, 17 insertions, 10 deletions
diff --git a/pugl/detail/mac.m b/pugl/detail/mac.m index ab13452..c9847eb 100644 --- a/pugl/detail/mac.m +++ b/pugl/detail/mac.m @@ -818,17 +818,24 @@ puglHideWindow(PuglView* view) void puglFreeViewInternals(PuglView* view) { - view->backend->destroy(view); - [view->impl->wrapperView removeFromSuperview]; - view->impl->wrapperView->puglview = NULL; - if (view->impl->window) { - [view->impl->window close]; - } - [view->impl->wrapperView release]; - if (view->impl->window) { - [view->impl->window release]; + if (view) { + if (view->backend) { + view->backend->destroy(view); + } + + if (view->impl) { + [view->impl->wrapperView removeFromSuperview]; + view->impl->wrapperView->puglview = NULL; + if (view->impl->window) { + [view->impl->window close]; + } + [view->impl->wrapperView release]; + if (view->impl->window) { + [view->impl->window release]; + } + free(view->impl); + } } - free(view->impl); } PuglStatus |