Browse Source

Accept modguis as real UIs

tags/1.9.6
falkTX 10 years ago
parent
commit
edf17b97b2
3 changed files with 18 additions and 5 deletions
  1. +1
    -1
      source/backend/CarlaUtils.cpp
  2. +16
    -3
      source/backend/plugin/CarlaPluginLV2.cpp
  3. +1
    -1
      source/bridges-ui/CarlaBridgeUI.cpp

+ 1
- 1
source/backend/CarlaUtils.cpp View File

@@ -455,7 +455,7 @@ const CarlaCachedPluginInfo* carla_get_cached_plugin_info(CB::PluginType ptype,
// features
info.hints = 0x0;

if (lilvPlugin.get_uis().size() > 0 /*|| lilvPlugin.get_modgui_resources_directory().as_uri() != nullptr*/)
if (lilvPlugin.get_uis().size() > 0 || lilvPlugin.get_modgui_resources_directory().as_uri() != nullptr)
info.hints |= CB::PLUGIN_HAS_CUSTOM_UI;

{


+ 16
- 3
source/backend/plugin/CarlaPluginLV2.cpp View File

@@ -1269,6 +1269,10 @@ public:
fPipeServer.writeUiOptionsMessage(pData->engine->getSampleRate(), true, true, fLv2Options.windowTitle, frontendWinId);

fPipeServer.writeShowMessage();
#ifndef BUILD_BRIDGE
if (fUI.rdfDescriptor->Type == LV2_UI_MOD)
pData->tryTransient();
#endif
}
else
{
@@ -4096,6 +4100,9 @@ public:
case LV2_UI_OLD_EXTERNAL:
bridgeBinary += CARLA_OS_SEP_STR "carla-bridge-lv2-external";
break;
case LV2_UI_MOD:
bridgeBinary += CARLA_OS_SEP_STR "carla-bridge-lv2-modgui";
break;
default:
return nullptr;
}
@@ -5034,8 +5041,8 @@ public:
// ---------------------------------------------------------------
// find the most appropriate ui

int eQt4, eQt5, eGtk2, eGtk3, eCocoa, eWindows, eX11, eExt, iCocoa, iWindows, iX11, iExt, iFinal;
eQt4 = eQt5 = eGtk2 = eGtk3 = eCocoa = eWindows = eX11 = eExt = iCocoa = iWindows = iX11 = iExt = iFinal = -1;
int eQt4, eQt5, eGtk2, eGtk3, eCocoa, eWindows, eX11, eExt, eMod, iCocoa, iWindows, iX11, iExt, iFinal;
eQt4 = eQt5 = eGtk2 = eGtk3 = eCocoa = eWindows = eX11 = eExt = eMod = iCocoa = iWindows = iX11 = iExt = iFinal = -1;

#if defined(BUILD_BRIDGE)
const bool preferUiBridges(false);
@@ -5090,6 +5097,9 @@ public:
eExt = ii;
iExt = ii;
break;
case LV2_UI_MOD:
eMod = ii;
break;
default:
break;
}
@@ -5123,6 +5133,8 @@ public:
#endif
//else if (eExt >= 0) // TODO
// iFinal = eExt;
else if (eMod >= 0)
iFinal = eMod;
#ifndef LV2_UIS_ONLY_BRIDGES
# ifdef CARLA_OS_MAC
else if (iCocoa >= 0)
@@ -5216,7 +5228,8 @@ public:

const LV2_Property uiType(fUI.rdfDescriptor->Type);

if (iFinal == eQt4 || iFinal == eQt5 || iFinal == eGtk2 || iFinal == eGtk3 || iFinal == eCocoa || iFinal == eWindows || iFinal == eX11 || iFinal == eExt)
if (iFinal == eQt4 || iFinal == eQt5 || iFinal == eGtk2 || iFinal == eGtk3 ||
iFinal == eCocoa || iFinal == eWindows || iFinal == eX11 || iFinal == eExt || iFinal == eMod)
{
// -----------------------------------------------------------
// initialize ui-bridge


+ 1
- 1
source/bridges-ui/CarlaBridgeUI.cpp View File

@@ -138,7 +138,7 @@ bool CarlaBridgeUI::msgReceived(const char* const msg) noexcept
return true;
}

if (std::strcmp(msg, "mprogram") == 0)
if (std::strcmp(msg, "midiprogram") == 0)
{
uint32_t bank, program;



Loading…
Cancel
Save