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/x11_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/x11_in_qt4.cpp')
-rw-r--r-- | src/x11_in_qt4.cpp | 52 |
1 files changed, 36 insertions, 16 deletions
diff --git a/src/x11_in_qt4.cpp b/src/x11_in_qt4.cpp index c936174..7c75a95 100644 --- a/src/x11_in_qt4.cpp +++ b/src/x11_in_qt4.cpp @@ -24,29 +24,49 @@ extern "C" { -SUIL_API -int -suil_wrap_init(SuilHost* host, - const char* host_type_uri, - const char* ui_type_uri, - const LV2_Feature* const* features) +static int +wrapper_wrap(SuilWrapper* wrapper, + SuilInstance* instance) { + QX11EmbedWidget* const ew = (QX11EmbedWidget*)wrapper->impl; + QX11EmbedContainer* const wrap = new QX11EmbedContainer(); + + ew->embedInto(wrap->winId()); + //wrap->embedClient((intptr_t)instance->ui_widget); + + instance->host_widget = wrap; + return 0; } -/** Dynamic module entry point. */ SUIL_API -int -suil_wrap(const char* host_type_uri, - const char* ui_type_uri, - SuilInstance* instance) +SuilWrapper* +suil_wrapper_new(SuilHost* host, + const char* host_type_uri, + const char* ui_type_uri, + const LV2_Feature* const* features) { - QX11EmbedContainer* const wrapper = new QX11EmbedContainer(); - wrapper->embedClient((intptr_t)instance->ui_widget); - - instance->host_widget = wrapper; + SuilWrapper* wrapper = (SuilWrapper*)malloc(sizeof(SuilWrapper)); + wrapper->wrap = wrapper_wrap; + wrapper->free = (SuilWrapperFreeFunc)free; - return 0; + unsigned n_features = 0; + for (; features[n_features]; ++n_features) {} + + QX11EmbedWidget* const ew = new QX11EmbedWidget(); + wrapper->impl = ew; + + wrapper->features = (LV2_Feature**)malloc( + sizeof(LV2_Feature) * (n_features + 1)); + memcpy(wrapper->features, features, sizeof(LV2_Feature) * n_features); + + LV2_Feature* parent_feature = (LV2_Feature*)malloc(sizeof(LV2_Feature)); + parent_feature->URI = "http://example.org/winid"; + parent_feature->data = (void*)(intptr_t)ew->winId(); + + wrapper->features[n_features] = parent_feature; + + return wrapper; } } // extern "C" |