diff options
author | David Robillard <d@drobilla.net> | 2011-12-10 04:40:00 +0000 |
---|---|---|
committer | David Robillard <d@drobilla.net> | 2011-12-10 04:40:00 +0000 |
commit | c545e17c4d3d1f0bf791e9112d2873de01c06e51 (patch) | |
tree | 3cb5257796cf59d78d024c6525894ce122a08c60 /src/gtk2_in_qt4.cpp | |
parent | 5810fec09eee8491744482b882a635ab8e3d7e78 (diff) | |
download | suil-c545e17c4d3d1f0bf791e9112d2873de01c06e51.tar.gz suil-c545e17c4d3d1f0bf791e9112d2873de01c06e51.tar.bz2 suil-c545e17c4d3d1f0bf791e9112d2873de01c06e51.zip |
Rework module interface to support modules that need to pass features.
Pass experimental parent window ID feature for embedding X11 UIs with events working.
git-svn-id: http://svn.drobilla.net/lad/trunk/suil@3851 a436a847-0d15-0410-975c-d299462d15a1
Diffstat (limited to 'src/gtk2_in_qt4.cpp')
-rw-r--r-- | src/gtk2_in_qt4.cpp | 71 |
1 files changed, 36 insertions, 35 deletions
diff --git a/src/gtk2_in_qt4.cpp b/src/gtk2_in_qt4.cpp index 9dd9cc6..11f0b1c 100644 --- a/src/gtk2_in_qt4.cpp +++ b/src/gtk2_in_qt4.cpp @@ -25,12 +25,36 @@ extern "C" { +static int +wrapper_wrap(SuilWrapper* wrapper, + SuilInstance* instance) +{ + QX11EmbedContainer* const wrap = new QX11EmbedContainer(); + GtkWidget* const plug = gtk_plug_new(wrap->winId()); + GtkWidget* const widget = (GtkWidget*)instance->ui_widget; + + gtk_container_add(GTK_CONTAINER(plug), widget); + gtk_widget_show_all(plug); + +#ifdef SUIL_OLD_GTK + wrap->resize(widget->allocation.width, widget->allocation.height); +#else + GtkAllocation alloc; + gtk_widget_get_allocation(widget, &alloc); + wrap->resize(alloc.width, alloc.height); +#endif + + instance->host_widget = wrap; + + return 0; +} + SUIL_API -int -suil_wrap_init(SuilHost* host, - const char* host_type_uri, - const char* ui_type_uri, - const LV2_Feature* const* features) +SuilWrapper* +suil_wrapper_new(SuilHost* host, + const char* host_type_uri, + const char* ui_type_uri, + const LV2_Feature* const* features) { /* We have to open libgtk here, so Gtk type symbols are present and will be found by the introspection stuff. This is required at least to make @@ -43,41 +67,18 @@ suil_wrap_init(SuilHost* host, if (!host->gtk_lib) { fprintf(stderr, "Failed to open %s (%s)\n", SUIL_GTK2_LIB_NAME, dlerror()); - return 1; + return NULL; } gtk_init(NULL, NULL); } - return 0; -} - -/** Dynamic module entry point. */ -SUIL_API -int -suil_wrap(const char* host_type_uri, - const char* ui_type_uri, - SuilInstance* instance) -{ - QX11EmbedContainer* const wrapper = new QX11EmbedContainer(); - GtkWidget* const plug = gtk_plug_new(wrapper->winId()); - GtkWidget* const widget = (GtkWidget*)instance->ui_widget; - - //wrapper->embedClient(gtk_plug_get_id(GTK_PLUG(plug))); - - gtk_container_add(GTK_CONTAINER(plug), widget); - gtk_widget_show_all(plug); - -#ifdef SUIL_OLD_GTK - wrapper->resize(widget->allocation.width, widget->allocation.height); -#else - GtkAllocation alloc; - gtk_widget_get_allocation(widget, &alloc); - wrapper->resize(alloc.width, alloc.height); -#endif - - instance->host_widget = wrapper; + SuilWrapper* wrapper = (SuilWrapper*)malloc(sizeof(SuilWrapper)); + wrapper->wrap = wrapper_wrap; + wrapper->free = (SuilWrapperFreeFunc)free; + wrapper->features = (LV2_Feature**)features; + wrapper->impl = NULL; - return 0; + return wrapper; } } // extern "C" |