From 5f8106554738df91444ecd8af1c2c5d318ff4326 Mon Sep 17 00:00:00 2001 From: David Robillard Date: Wed, 4 Jan 2012 00:09:39 +0000 Subject: Fix errors on clode with Qt4 in Gtk2 wrapper. git-svn-id: http://svn.drobilla.net/lad/trunk/suil@3914 a436a847-0d15-0410-975c-d299462d15a1 --- src/instance.c | 9 ++++----- src/qt4_in_gtk2.cpp | 34 +++++++++++++++++++++++++--------- 2 files changed, 29 insertions(+), 14 deletions(-) (limited to 'src') diff --git a/src/instance.c b/src/instance.c index 2bce3f6..92c61f9 100644 --- a/src/instance.c +++ b/src/instance.c @@ -232,15 +232,14 @@ void suil_instance_free(SuilInstance* instance) { if (instance) { + if (instance->wrapper) { + instance->wrapper->free(instance->wrapper); + dlclose(instance->wrapper->lib); + } if (instance->handle) { instance->descriptor->cleanup(instance->handle); } dlclose(instance->lib_handle); - if (instance->wrapper) { - void* lib = instance->wrapper->lib; - instance->wrapper->free(instance->wrapper); - dlclose(lib); - } free(instance); } } diff --git a/src/qt4_in_gtk2.cpp b/src/qt4_in_gtk2.cpp index 6de448f..3e66598 100644 --- a/src/qt4_in_gtk2.cpp +++ b/src/qt4_in_gtk2.cpp @@ -24,9 +24,6 @@ extern "C" { -static int argc = 0; -static QApplication application(argc, NULL, true); - #define SUIL_TYPE_QT_WRAPPER (suil_qt_wrapper_get_type()) #define SUIL_QT_WRAPPER(obj) (G_TYPE_CHECK_INSTANCE_CAST((obj), SUIL_TYPE_QT_WRAPPER, SuilQtWrapper)) @@ -35,6 +32,7 @@ typedef struct _SuilQtWrapperClass SuilQtWrapperClass; struct _SuilQtWrapper { GtkSocket socket; + QApplication* app; QX11EmbedWidget* qembed; SuilInstance* instance; }; @@ -53,11 +51,11 @@ suil_qt_wrapper_dispose(GObject* gobject) SuilQtWrapper* const self = SUIL_QT_WRAPPER(gobject); if (self->qembed) { - QWidget* const qwidget = (QWidget*)self->instance->ui_widget; - qwidget->setParent(NULL); - delete self->qembed; self->qembed = NULL; + + delete self->app; + self->app = NULL; } G_OBJECT_CLASS(suil_qt_wrapper_parent_class)->dispose(gobject); @@ -74,6 +72,7 @@ suil_qt_wrapper_class_init(SuilQtWrapperClass* klass) static void suil_qt_wrapper_init(SuilQtWrapper* self) { + self->app = NULL; self->qembed = NULL; self->instance = NULL; } @@ -92,8 +91,7 @@ static int wrapper_wrap(SuilWrapper* wrapper, SuilInstance* instance) { - SuilQtWrapper* const wrap = SUIL_QT_WRAPPER( - g_object_new(SUIL_TYPE_QT_WRAPPER, NULL)); + SuilQtWrapper* const wrap = SUIL_QT_WRAPPER(wrapper->impl); wrap->qembed = new QX11EmbedWidget(); wrap->instance = instance; @@ -114,6 +112,16 @@ wrapper_wrap(SuilWrapper* wrapper, return 0; } +static void +wrapper_free(SuilWrapper* wrapper) +{ + SuilQtWrapper* const wrap = SUIL_QT_WRAPPER( + g_object_new(SUIL_TYPE_QT_WRAPPER, NULL)); + + gtk_object_destroy(GTK_OBJECT(wrap)); + free(wrap); +} + SUIL_API SuilWrapper* suil_wrapper_new(SuilHost* host, @@ -123,10 +131,18 @@ suil_wrapper_new(SuilHost* host, { SuilWrapper* wrapper = (SuilWrapper*)malloc(sizeof(SuilWrapper)); wrapper->wrap = wrapper_wrap; - wrapper->free = (SuilWrapperFreeFunc)free; + wrapper->free = wrapper_free; wrapper->features = (LV2_Feature**)features; wrapper->impl = NULL; + SuilQtWrapper* const wrap = SUIL_QT_WRAPPER( + g_object_new(SUIL_TYPE_QT_WRAPPER, NULL)); + + int argc = 0; + wrap->app = new QApplication(argc, NULL, true); + + wrapper->impl = wrap; + return wrapper; } -- cgit v1.2.1