Collection of tools useful for audio production
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

2037 lines
61KB

  1. /*
  2. * Carla Backend
  3. * Copyright (C) 2012 Filipe Coelho <falktx@falktx.com>
  4. *
  5. * This program is free software; you can redistribute it and/or modify
  6. * it under the terms of the GNU General Public License as published by
  7. * the Free Software Foundation; either version 2 of the License, or
  8. * any later version.
  9. *
  10. * This program is distributed in the hope that it will be useful,
  11. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  13. * GNU General Public License for more details.
  14. *
  15. * For a full copy of the GNU General Public License see the COPYING file
  16. */
  17. #include "carla_engine.h"
  18. #include "carla_plugin.h"
  19. CARLA_BACKEND_START_NAMESPACE
  20. // -----------------------------------------------------------------------
  21. unsigned short CarlaEngine::m_maxPluginNumber = 0;
  22. CarlaEngine::CarlaEngine()
  23. : m_checkThread(this),
  24. #ifndef BUILD_BRIDGE
  25. m_osc(this),
  26. #endif
  27. m_oscData(nullptr),
  28. m_callback(nullptr),
  29. #ifdef Q_COMPILER_INITIALIZER_LISTS
  30. m_callbackPtr(nullptr),
  31. m_carlaPlugins{nullptr},
  32. m_uniqueNames{nullptr},
  33. m_insPeak{0.0},
  34. m_outsPeak{0.0}
  35. #else
  36. m_callbackPtr(nullptr)
  37. #endif
  38. {
  39. qDebug("CarlaEngine::CarlaEngine()");
  40. type = CarlaEngineTypeNull;
  41. name = nullptr;
  42. bufferSize = 0;
  43. sampleRate = 0.0;
  44. m_maxPluginNumber = 0;
  45. #ifndef Q_COMPILER_INITIALIZER_LISTS
  46. for (unsigned short i=0; i < MAX_PLUGINS; i++)
  47. {
  48. m_carlaPlugins[i] = nullptr;
  49. m_uniqueNames[i] = nullptr;
  50. }
  51. for (unsigned short i=0; i < MAX_PLUGINS * MAX_PEAKS; i++)
  52. {
  53. m_insPeak[i] = 0.0;
  54. m_outsPeak[i] = 0.0;
  55. }
  56. #endif
  57. }
  58. CarlaEngine::~CarlaEngine()
  59. {
  60. qDebug("CarlaEngine::~CarlaEngine()");
  61. if (name)
  62. free((void*)name);
  63. }
  64. // -----------------------------------------------------------------------
  65. // Static values
  66. int CarlaEngine::maxClientNameSize()
  67. {
  68. #ifdef CARLA_ENGINE_JACK
  69. # ifndef BUILD_BRIDGE
  70. if (carlaOptions.processMode != PROCESS_MODE_CONTINUOUS_RACK)
  71. # endif
  72. return jackbridge_client_name_size();
  73. #endif
  74. return STR_MAX/2;
  75. }
  76. int CarlaEngine::maxPortNameSize()
  77. {
  78. #ifdef CARLA_ENGINE_JACK
  79. # ifndef BUILD_BRIDGE
  80. if (carlaOptions.processMode != PROCESS_MODE_CONTINUOUS_RACK)
  81. # endif
  82. return jackbridge_port_name_size();
  83. #endif
  84. return STR_MAX;
  85. }
  86. unsigned short CarlaEngine::maxPluginNumber()
  87. {
  88. return m_maxPluginNumber;
  89. }
  90. const char* CarlaEngine::getFixedClientName(const char* const clientName)
  91. {
  92. char* fixedName = strdup(clientName);
  93. for (size_t i=0; i < strlen(fixedName); i++)
  94. {
  95. if (! (std::isalpha(fixedName[i]) || std::isdigit(fixedName[i])))
  96. fixedName[i] = '_';
  97. }
  98. return fixedName;
  99. }
  100. unsigned int CarlaEngine::getDriverCount()
  101. {
  102. unsigned int count = 0;
  103. #ifdef CARLA_ENGINE_JACK
  104. count += 1;
  105. #endif
  106. #ifdef CARLA_ENGINE_RTAUDIO
  107. std::vector<RtAudio::Api> apis;
  108. RtAudio::getCompiledApi(apis);
  109. count += apis.size();
  110. #endif
  111. return count;
  112. }
  113. const char* CarlaEngine::getDriverName(unsigned int index)
  114. {
  115. #ifdef CARLA_ENGINE_JACK
  116. if (index == 0)
  117. return "JACK";
  118. else
  119. index -= 1;
  120. #endif
  121. #ifdef CARLA_ENGINE_RTAUDIO
  122. std::vector<RtAudio::Api> apis;
  123. RtAudio::getCompiledApi(apis);
  124. if (index < apis.size())
  125. {
  126. RtAudio::Api api = apis[index];
  127. switch (api)
  128. {
  129. case RtAudio::UNSPECIFIED:
  130. return "Unspecified";
  131. case RtAudio::LINUX_ALSA:
  132. return "ALSA";
  133. case RtAudio::LINUX_PULSE:
  134. return "PulseAudio";
  135. case RtAudio::LINUX_OSS:
  136. return "OSS";
  137. case RtAudio::UNIX_JACK:
  138. return "JACK (RtAudio)";
  139. case RtAudio::MACOSX_CORE:
  140. return "CoreAudio";
  141. case RtAudio::WINDOWS_ASIO:
  142. return "ASIO";
  143. case RtAudio::WINDOWS_DS:
  144. return "DirectSound";
  145. case RtAudio::RTAUDIO_DUMMY:
  146. return "Dummy";
  147. }
  148. }
  149. #endif
  150. qWarning("CarlaEngine::getDriverName(%i) - invalid index", index);
  151. return nullptr;
  152. }
  153. CarlaEngine* CarlaEngine::newDriverByName(const char* driverName)
  154. {
  155. #ifdef CARLA_ENGINE_JACK
  156. if (strcmp(driverName, "JACK") == 0)
  157. return newJack();
  158. #else
  159. if (false)
  160. pass();
  161. #endif
  162. #ifdef CARLA_ENGINE_RTAUDIO
  163. #ifdef __LINUX_ALSA__
  164. else if (strcmp(driverName, "ALSA") == 0)
  165. return newRtAudio(RtAudio::LINUX_ALSA);
  166. #endif
  167. #ifdef __LINUX_PULSE__
  168. else if (strcmp(driverName, "PulseAudio") == 0)
  169. return newRtAudio(RtAudio::LINUX_PULSE);
  170. #endif
  171. #ifdef __LINUX_OSS__
  172. else if (strcmp(driverName, "OSS") == 0)
  173. return newRtAudio(RtAudio::LINUX_OSS);
  174. #endif
  175. #ifdef __UNIX_JACK__
  176. else if (strcmp(driverName, "JACK (RtAudio)") == 0)
  177. return newRtAudio(RtAudio::UNIX_JACK);
  178. #endif
  179. #ifdef __MACOSX_CORE__
  180. else if (strcmp(driverName, "CoreAudio") == 0)
  181. return newRtAudio(RtAudio::MACOSX_CORE);
  182. #endif
  183. #ifdef __WINDOWS_ASIO__
  184. else if (strcmp(driverName, "ASIO") == 0)
  185. return newRtAudio(RtAudio::WINDOWS_ASIO);
  186. #endif
  187. #ifdef __WINDOWS_DS__
  188. else if (strcmp(driverName, "DirectSound") == 0)
  189. return newRtAudio(RtAudio::WINDOWS_DS);
  190. #endif
  191. #ifdef __RTAUDIO_DUMMY__
  192. else if (strcmp(driverName, "Dummy") == 0)
  193. return newRtAudio(RtAudio::RTAUDIO_DUMMY);
  194. #endif
  195. #endif
  196. return nullptr;
  197. }
  198. // -----------------------------------------------------------------------
  199. // Virtual, per-engine type calls
  200. bool CarlaEngine::init(const char* const clientName)
  201. {
  202. qDebug("CarlaEngine::init(\"%s\")", clientName);
  203. #ifndef BUILD_BRIDGE
  204. m_osc.init(clientName);
  205. m_oscData = m_osc.getControlData();
  206. carla_setprocname(clientName);
  207. #endif
  208. return true;
  209. }
  210. bool CarlaEngine::close()
  211. {
  212. qDebug("CarlaEngine::close()");
  213. m_checkThread.stopNow();
  214. #ifndef BUILD_BRIDGE
  215. osc_send_control_exit();
  216. m_osc.close();
  217. #endif
  218. m_oscData = nullptr;
  219. m_maxPluginNumber = 0;
  220. return true;
  221. }
  222. // -----------------------------------------------------------------------
  223. // plugin management
  224. short CarlaEngine::getNewPluginId() const
  225. {
  226. qDebug("CarlaEngine::getNewPluginId()");
  227. for (unsigned short i=0; i < m_maxPluginNumber; i++)
  228. {
  229. if (! m_carlaPlugins[i])
  230. return i;
  231. }
  232. return -1;
  233. }
  234. CarlaPlugin* CarlaEngine::getPlugin(const unsigned short id) const
  235. {
  236. qDebug("CarlaEngine::getPlugin(%i/%i)", id, m_maxPluginNumber);
  237. CARLA_ASSERT(m_maxPluginNumber != 0);
  238. CARLA_ASSERT(id < m_maxPluginNumber);
  239. if (id < m_maxPluginNumber)
  240. return m_carlaPlugins[id];
  241. return nullptr;
  242. }
  243. CarlaPlugin* CarlaEngine::getPluginUnchecked(const unsigned short id) const
  244. {
  245. CARLA_ASSERT(m_maxPluginNumber != 0);
  246. CARLA_ASSERT(id < m_maxPluginNumber);
  247. return m_carlaPlugins[id];
  248. }
  249. const char* CarlaEngine::getUniquePluginName(const char* const name)
  250. {
  251. qDebug("CarlaEngine::getUniquePluginName(\"%s\")", name);
  252. CARLA_ASSERT(name);
  253. QString qname(name);
  254. if (qname.isEmpty())
  255. qname = "(No name)";
  256. qname.truncate(maxClientNameSize()-5-1); // 5 = strlen(" (10)")
  257. qname.replace(":", "."); // ":" is used in JACK1 to split client/port names
  258. for (unsigned short i=0; i < m_maxPluginNumber; i++)
  259. {
  260. // Check if unique name already exists
  261. if (m_uniqueNames[i] && qname == m_uniqueNames[i])
  262. {
  263. // Check if string has already been modified
  264. uint len = qname.size();
  265. // 1 digit, ex: " (2)"
  266. if (qname.at(len-4) == QChar(' ') && qname.at(len-3) == QChar('(') && qname.at(len-2).isDigit() && qname.at(len-1) == QChar(')'))
  267. {
  268. int number = qname.at(len-2).toAscii()-'0';
  269. if (number == 9)
  270. // next number is 10, 2 digits
  271. qname.replace(" (9)", " (10)");
  272. else
  273. qname[len-2] = QChar('0'+number+1);
  274. continue;
  275. }
  276. // 2 digits, ex: " (11)"
  277. if (qname.at(len-5) == QChar(' ') && qname.at(len-4) == QChar('(') && qname.at(len-3).isDigit() && qname.at(len-2).isDigit() && qname.at(len-1) == QChar(')'))
  278. {
  279. QChar n2 = qname.at(len-2);
  280. QChar n3 = qname.at(len-3);
  281. if (n2 == QChar('9'))
  282. {
  283. n2 = QChar('0');
  284. n3 = QChar(n3.toAscii()+1);
  285. }
  286. else
  287. n2 = QChar(n2.toAscii()+1);
  288. qname[len-2] = n2;
  289. qname[len-3] = n3;
  290. continue;
  291. }
  292. // Modify string if not
  293. qname += " (2)";
  294. }
  295. }
  296. return strdup(qname.toUtf8().constData());
  297. }
  298. short CarlaEngine::addPlugin(const PluginType ptype, const char* const filename, const char* const name, const char* const label, void* const extra)
  299. {
  300. return addPlugin(BINARY_NATIVE, ptype, filename, name, label, extra);
  301. }
  302. short CarlaEngine::addPlugin(const BinaryType btype, const PluginType ptype, const char* const filename, const char* const name, const char* const label, void* const extra)
  303. {
  304. qDebug("CarlaEngine::addPlugin(%s, %s, \"%s\", \"%s\", \"%s\", %p)", BinaryType2str(btype), PluginType2str(ptype), filename, name, label, extra);
  305. CARLA_ASSERT(btype != BINARY_NONE);
  306. CARLA_ASSERT(ptype != PLUGIN_NONE);
  307. CARLA_ASSERT(filename);
  308. CARLA_ASSERT(label);
  309. if (m_maxPluginNumber == 0)
  310. {
  311. #ifdef BUILD_BRIDGE
  312. m_maxPluginNumber = MAX_PLUGINS;
  313. #else
  314. m_maxPluginNumber = (carlaOptions.processMode == PROCESS_MODE_CONTINUOUS_RACK) ? 16 : MAX_PLUGINS;
  315. #endif
  316. }
  317. CarlaPlugin::initializer init = {
  318. this,
  319. filename,
  320. name,
  321. label
  322. };
  323. CarlaPlugin* plugin = nullptr;
  324. #ifndef BUILD_BRIDGE
  325. if (btype != BINARY_NATIVE || (carlaOptions.preferPluginBridges && getBinaryBidgePath(btype) && type == CarlaEngineTypeJack))
  326. {
  327. # ifdef CARLA_ENGINE_JACK
  328. if (carlaOptions.processMode != CarlaBackend::PROCESS_MODE_MULTIPLE_CLIENTS)
  329. {
  330. setLastError("Can only use bridged plugins in JACK Multi-Client mode");
  331. return -1;
  332. }
  333. # endif
  334. if (type != CarlaEngineTypeJack)
  335. {
  336. setLastError("Can only use bridged plugins with JACK backend");
  337. return -1;
  338. }
  339. plugin = CarlaPlugin::newBridge(init, btype, ptype);
  340. }
  341. else
  342. #endif
  343. {
  344. switch (ptype)
  345. {
  346. case PLUGIN_NONE:
  347. break;
  348. #ifndef BUILD_BRIDGE
  349. case PLUGIN_INTERNAL:
  350. plugin = CarlaPlugin::newNative(init);
  351. break;
  352. #endif
  353. case PLUGIN_LADSPA:
  354. plugin = CarlaPlugin::newLADSPA(init, extra);
  355. break;
  356. case PLUGIN_DSSI:
  357. plugin = CarlaPlugin::newDSSI(init, extra);
  358. break;
  359. case PLUGIN_LV2:
  360. plugin = CarlaPlugin::newLV2(init);
  361. break;
  362. case PLUGIN_VST:
  363. plugin = CarlaPlugin::newVST(init);
  364. break;
  365. #ifndef BUILD_BRIDGE
  366. case PLUGIN_GIG:
  367. plugin = CarlaPlugin::newGIG(init);
  368. break;
  369. case PLUGIN_SF2:
  370. plugin = CarlaPlugin::newSF2(init);
  371. break;
  372. case PLUGIN_SFZ:
  373. plugin = CarlaPlugin::newSFZ(init);
  374. break;
  375. #else
  376. default:
  377. break;
  378. #endif
  379. }
  380. }
  381. if (! plugin)
  382. return -1;
  383. const short id = plugin->id();
  384. m_carlaPlugins[id] = plugin;
  385. m_uniqueNames[id] = plugin->name();
  386. if (! m_checkThread.isRunning())
  387. m_checkThread.startNow();
  388. return id;
  389. }
  390. bool CarlaEngine::removePlugin(const unsigned short id)
  391. {
  392. qDebug("CarlaEngine::removePlugin(%i)", id);
  393. CARLA_ASSERT(m_maxPluginNumber != 0);
  394. CARLA_ASSERT(id < m_maxPluginNumber);
  395. CarlaPlugin* const plugin = m_carlaPlugins[id];
  396. if (plugin /*&& plugin->id() == id*/)
  397. {
  398. CARLA_ASSERT(plugin->id() == id);
  399. m_checkThread.stopNow();
  400. processLock();
  401. plugin->setEnabled(false);
  402. m_carlaPlugins[id] = nullptr;
  403. m_uniqueNames[id] = nullptr;
  404. processUnlock();
  405. delete plugin;
  406. #ifndef BUILD_BRIDGE
  407. osc_send_control_remove_plugin(id);
  408. if (carlaOptions.processMode == PROCESS_MODE_CONTINUOUS_RACK)
  409. {
  410. // TODO - handle OSC server comm
  411. for (unsigned short i=id; i < m_maxPluginNumber-1; i++)
  412. {
  413. m_carlaPlugins[i] = m_carlaPlugins[i+1];
  414. m_uniqueNames[i] = m_uniqueNames[i+1];
  415. if (m_carlaPlugins[i])
  416. m_carlaPlugins[i]->setId(i);
  417. }
  418. }
  419. #endif
  420. if (isRunning())
  421. {
  422. // only re-start check thread if there are still plugins left
  423. for (unsigned short i=0; i < m_maxPluginNumber; i++)
  424. {
  425. if (m_carlaPlugins[i])
  426. {
  427. m_checkThread.startNow();
  428. break;
  429. }
  430. }
  431. }
  432. return true;
  433. }
  434. qCritical("CarlaEngine::removePlugin(%i) - could not find plugin", id);
  435. setLastError("Could not find plugin to remove");
  436. return false;
  437. }
  438. void CarlaEngine::removeAllPlugins()
  439. {
  440. qDebug("CarlaEngine::removeAllPlugins()");
  441. m_checkThread.stopNow();
  442. for (unsigned short i=0; i < m_maxPluginNumber; i++)
  443. {
  444. CarlaPlugin* const plugin = m_carlaPlugins[i];
  445. if (plugin)
  446. {
  447. processLock();
  448. plugin->setEnabled(false);
  449. processUnlock();
  450. delete plugin;
  451. m_carlaPlugins[i] = nullptr;
  452. m_uniqueNames[i] = nullptr;
  453. }
  454. }
  455. m_maxPluginNumber = 0;
  456. }
  457. void CarlaEngine::idlePluginGuis()
  458. {
  459. CARLA_ASSERT(m_maxPluginNumber != 0);
  460. for (unsigned short i=0; i < m_maxPluginNumber; i++)
  461. {
  462. CarlaPlugin* const plugin = m_carlaPlugins[i];
  463. if (plugin && plugin->enabled())
  464. plugin->idleGui();
  465. }
  466. }
  467. #ifndef BUILD_BRIDGE
  468. void CarlaEngine::processRack(float* inBuf[2], float* outBuf[2], uint32_t frames)
  469. {
  470. // initialize outputs (zero)
  471. zeroF(outBuf[0], frames);
  472. zeroF(outBuf[1], frames);
  473. memset(rackControlEventsOut, 0, sizeof(CarlaEngineControlEvent)*MAX_ENGINE_CONTROL_EVENTS);
  474. memset(rackMidiEventsOut, 0, sizeof(CarlaEngineMidiEvent)*MAX_ENGINE_MIDI_EVENTS);
  475. bool processed = false;
  476. // process plugins
  477. for (unsigned short i=0, max=maxPluginNumber(); i < max; i++)
  478. {
  479. CarlaPlugin* const plugin = getPluginUnchecked(i);
  480. if (plugin && plugin->enabled())
  481. {
  482. if (processed)
  483. {
  484. // initialize inputs (from previous outputs)
  485. memcpy(inBuf[0], outBuf[0], sizeof(float)*frames);
  486. memcpy(inBuf[1], outBuf[1], sizeof(float)*frames);
  487. memcpy(rackMidiEventsIn, rackMidiEventsOut, sizeof(CarlaEngineMidiEvent)*MAX_ENGINE_MIDI_EVENTS);
  488. // initialize outputs (zero)
  489. zeroF(outBuf[0], frames);
  490. zeroF(outBuf[1], frames);
  491. memset(rackMidiEventsOut, 0, sizeof(CarlaEngineMidiEvent)*MAX_ENGINE_MIDI_EVENTS);
  492. }
  493. // process
  494. plugin->engineProcessLock();
  495. plugin->initBuffers();
  496. if (carlaOptions.processHighPrecision)
  497. {
  498. float* inBuf2[2];
  499. float* outBuf2[2];
  500. for (uint32_t j=0; j < frames; j += 8)
  501. {
  502. inBuf2[0] = inBuf[0] + j;
  503. inBuf2[1] = inBuf[1] + j;
  504. outBuf2[0] = outBuf[0] + j;
  505. outBuf2[1] = outBuf[1] + j;
  506. plugin->process(inBuf2, outBuf2, 8, j);
  507. }
  508. }
  509. else
  510. plugin->process(inBuf, outBuf, frames);
  511. plugin->engineProcessUnlock();
  512. // if plugin has no audio inputs, add previous buffers
  513. if (plugin->audioInCount() == 0)
  514. {
  515. for (uint32_t j=0; j < frames; j++)
  516. {
  517. outBuf[0][j] += inBuf[0][j];
  518. outBuf[1][j] += inBuf[1][j];
  519. }
  520. }
  521. // if plugin has no midi output, add previous midi input
  522. if (plugin->midiOutCount() == 0)
  523. {
  524. memcpy(rackMidiEventsOut, rackMidiEventsIn, sizeof(CarlaEngineMidiEvent)*MAX_ENGINE_MIDI_EVENTS);
  525. }
  526. processed = true;
  527. }
  528. }
  529. // if no plugins in the rack, copy inputs over outputs
  530. if (! processed)
  531. {
  532. memcpy(outBuf[0], inBuf[0], sizeof(float)*frames);
  533. memcpy(outBuf[1], inBuf[1], sizeof(float)*frames);
  534. memcpy(rackMidiEventsOut, rackMidiEventsIn, sizeof(CarlaEngineMidiEvent)*MAX_ENGINE_MIDI_EVENTS);
  535. }
  536. }
  537. #endif
  538. // -----------------------------------------------------------------------
  539. // Information (base)
  540. CarlaEngineType CarlaEngine::getType() const
  541. {
  542. return type;
  543. }
  544. const char* CarlaEngine::getName() const
  545. {
  546. CARLA_ASSERT(name);
  547. return name;
  548. }
  549. double CarlaEngine::getSampleRate() const
  550. {
  551. //CARLA_ASSERT(sampleRate != 0.0);
  552. return sampleRate;
  553. }
  554. uint32_t CarlaEngine::getBufferSize() const
  555. {
  556. //CARLA_ASSERT(bufferSize != 0);
  557. return bufferSize;
  558. }
  559. const CarlaTimeInfo* CarlaEngine::getTimeInfo() const
  560. {
  561. return &timeInfo;
  562. }
  563. // -----------------------------------------------------------------------
  564. // Information (audio peaks)
  565. double CarlaEngine::getInputPeak(const unsigned short pluginId, const unsigned short id) const
  566. {
  567. CARLA_ASSERT(pluginId < m_maxPluginNumber);
  568. CARLA_ASSERT(id < MAX_PEAKS);
  569. return m_insPeak[pluginId*MAX_PEAKS + id];
  570. }
  571. double CarlaEngine::getOutputPeak(const unsigned short pluginId, const unsigned short id) const
  572. {
  573. CARLA_ASSERT(pluginId < m_maxPluginNumber);
  574. CARLA_ASSERT(id < MAX_PEAKS);
  575. return m_outsPeak[pluginId*MAX_PEAKS + id];
  576. }
  577. void CarlaEngine::setInputPeak(const unsigned short pluginId, const unsigned short id, double value)
  578. {
  579. CARLA_ASSERT(pluginId < m_maxPluginNumber);
  580. CARLA_ASSERT(id < MAX_PEAKS);
  581. m_insPeak[pluginId*MAX_PEAKS + id] = value;
  582. }
  583. void CarlaEngine::setOutputPeak(const unsigned short pluginId, const unsigned short id, double value)
  584. {
  585. CARLA_ASSERT(pluginId < m_maxPluginNumber);
  586. CARLA_ASSERT(id < MAX_PEAKS);
  587. m_outsPeak[pluginId*MAX_PEAKS + id] = value;
  588. }
  589. // -----------------------------------------------------------------------
  590. // Callback
  591. void CarlaEngine::callback(const CallbackType action, const unsigned short pluginId, const int value1, const int value2, const double value3)
  592. {
  593. qDebug("CarlaEngine::callback(%s, %i, %i, %i, %f)", CallbackType2str(action), pluginId, value1, value2, value3);
  594. if (m_callback)
  595. m_callback(m_callbackPtr, action, pluginId, value1, value2, value3);
  596. }
  597. void CarlaEngine::setCallback(const CallbackFunc func, void* const ptr)
  598. {
  599. qDebug("CarlaEngine::setCallback(%p, %p)", func, ptr);
  600. CARLA_ASSERT(func);
  601. m_callback = func;
  602. m_callbackPtr = ptr;
  603. }
  604. // -----------------------------------------------------------------------
  605. // Mutex locks
  606. void CarlaEngine::processLock()
  607. {
  608. m_procLock.lock();
  609. }
  610. void CarlaEngine::processUnlock()
  611. {
  612. m_procLock.unlock();
  613. }
  614. void CarlaEngine::midiLock()
  615. {
  616. m_midiLock.lock();
  617. }
  618. void CarlaEngine::midiUnlock()
  619. {
  620. m_midiLock.unlock();
  621. }
  622. // -----------------------------------------------------------------------
  623. // OSC Stuff
  624. bool CarlaEngine::isOscControlRegisted() const
  625. {
  626. #ifndef BUILD_BRIDGE
  627. return m_osc.isControlRegistered();
  628. #else
  629. return bool(m_oscData);
  630. #endif
  631. }
  632. #ifndef BUILD_BRIDGE
  633. const char* CarlaEngine::getOscServerPathTCP() const
  634. {
  635. return m_osc.getServerPathTCP();
  636. }
  637. const char* CarlaEngine::getOscServerPathUDP() const
  638. {
  639. return m_osc.getServerPathUDP();
  640. }
  641. #else
  642. void CarlaEngine::setOscBridgeData(const CarlaOscData* const oscData)
  643. {
  644. m_oscData = oscData;
  645. }
  646. #endif
  647. // -----------------------------------------------------------------------
  648. // protected calls
  649. void CarlaEngine::bufferSizeChanged(const uint32_t newBufferSize)
  650. {
  651. qDebug("CarlaEngine::bufferSizeChanged(%i)", newBufferSize);
  652. bufferSize = newBufferSize;
  653. for (unsigned short i=0; i < m_maxPluginNumber; i++)
  654. {
  655. if (m_carlaPlugins[i] && m_carlaPlugins[i]->enabled())
  656. m_carlaPlugins[i]->bufferSizeChanged(newBufferSize);
  657. }
  658. }
  659. // -------------------------------------------------------------------------------------------------------------------
  660. // Carla Engine Client
  661. CarlaEngineClient::CarlaEngineClient(const CarlaEngineClientNativeHandle& handle_)
  662. : handle(handle_)
  663. {
  664. qDebug("CarlaEngineClient::CarlaEngineClient()");
  665. CARLA_ASSERT(handle.type != CarlaEngineTypeNull);
  666. m_active = false;
  667. }
  668. CarlaEngineClient::~CarlaEngineClient()
  669. {
  670. qDebug("CarlaEngineClient::~CarlaEngineClient()");
  671. CARLA_ASSERT(! m_active);
  672. #ifndef BUILD_BRIDGE
  673. if (carlaOptions.processMode == PROCESS_MODE_MULTIPLE_CLIENTS)
  674. #endif
  675. {
  676. #ifdef CARLA_ENGINE_JACK
  677. if (handle.jackClient)
  678. jackbridge_client_close(handle.jackClient);
  679. #endif
  680. }
  681. }
  682. void CarlaEngineClient::activate()
  683. {
  684. qDebug("CarlaEngineClient::activate()");
  685. CARLA_ASSERT(! m_active);
  686. #ifndef BUILD_BRIDGE
  687. if (carlaOptions.processMode == PROCESS_MODE_MULTIPLE_CLIENTS)
  688. #endif
  689. {
  690. if (! m_active)
  691. {
  692. #ifdef CARLA_ENGINE_JACK
  693. if (handle.jackClient)
  694. jackbridge_activate(handle.jackClient);
  695. #endif
  696. }
  697. }
  698. m_active = true;
  699. }
  700. void CarlaEngineClient::deactivate()
  701. {
  702. qDebug("CarlaEngineClient::deactivate()");
  703. CARLA_ASSERT(m_active);
  704. #ifndef BUILD_BRIDGE
  705. if (carlaOptions.processMode == PROCESS_MODE_MULTIPLE_CLIENTS)
  706. #endif
  707. {
  708. if (m_active)
  709. {
  710. #ifdef CARLA_ENGINE_JACK
  711. if (handle.jackClient)
  712. jackbridge_deactivate(handle.jackClient);
  713. #endif
  714. }
  715. }
  716. m_active = false;
  717. }
  718. bool CarlaEngineClient::isActive() const
  719. {
  720. qDebug("CarlaEngineClient::isActive()");
  721. return m_active;
  722. }
  723. bool CarlaEngineClient::isOk() const
  724. {
  725. qDebug("CarlaEngineClient::isOk()");
  726. #ifndef BUILD_BRIDGE
  727. if (carlaOptions.processMode != PROCESS_MODE_CONTINUOUS_RACK)
  728. #endif
  729. {
  730. #ifdef CARLA_ENGINE_JACK
  731. if (handle.type == CarlaEngineTypeJack)
  732. return bool(handle.jackClient);
  733. #endif
  734. }
  735. return true;
  736. }
  737. void CarlaEngineClient::recomputeLatencies()
  738. {
  739. #ifndef BUILD_BRIDGE
  740. if (carlaOptions.processMode != PROCESS_MODE_CONTINUOUS_RACK)
  741. #endif
  742. {
  743. #ifdef CARLA_ENGINE_JACK
  744. if (handle.type == CarlaEngineTypeJack)
  745. jackbridge_recompute_total_latencies(handle.jackClient);
  746. #endif
  747. }
  748. }
  749. const CarlaEngineBasePort* CarlaEngineClient::addPort(const CarlaEnginePortType portType, const char* const name, const bool isInput)
  750. {
  751. qDebug("CarlaEngineClient::addPort(%i, \"%s\", %s)", portType, name, bool2str(isInput));
  752. CarlaEnginePortNativeHandle portHandle;
  753. #ifdef CARLA_ENGINE_JACK
  754. portHandle.jackClient = handle.jackClient;
  755. #endif
  756. #ifndef BUILD_BRIDGE
  757. if (carlaOptions.processMode != PROCESS_MODE_CONTINUOUS_RACK)
  758. #endif
  759. {
  760. #ifdef CARLA_ENGINE_JACK
  761. if (handle.type == CarlaEngineTypeJack)
  762. {
  763. switch (portType)
  764. {
  765. case CarlaEnginePortTypeAudio:
  766. portHandle.jackPort = jackbridge_port_register(handle.jackClient, name, JACK_DEFAULT_AUDIO_TYPE, isInput ? JackPortIsInput : JackPortIsOutput, 0);
  767. break;
  768. case CarlaEnginePortTypeControl:
  769. case CarlaEnginePortTypeMIDI:
  770. portHandle.jackPort = jackbridge_port_register(handle.jackClient, name, JACK_DEFAULT_MIDI_TYPE, isInput ? JackPortIsInput : JackPortIsOutput, 0);
  771. break;
  772. }
  773. }
  774. #endif
  775. }
  776. switch (portType)
  777. {
  778. case CarlaEnginePortTypeAudio:
  779. return new CarlaEngineAudioPort(portHandle, isInput);
  780. case CarlaEnginePortTypeControl:
  781. return new CarlaEngineControlPort(portHandle, isInput);
  782. case CarlaEnginePortTypeMIDI:
  783. return new CarlaEngineMidiPort(portHandle, isInput);
  784. }
  785. qCritical("CarlaEngineClient::addPort(%i, \"%s\", %s) - invalid type", portType, name, bool2str(isInput));
  786. return nullptr;
  787. }
  788. // -------------------------------------------------------------------------------------------------------------------
  789. // Carla Engine Port (Base class)
  790. CarlaEngineBasePort::CarlaEngineBasePort(const CarlaEnginePortNativeHandle& handle_, const bool isInput_)
  791. : isInput(isInput_),
  792. handle(handle_)
  793. {
  794. qDebug("CarlaEngineBasePort::CarlaEngineBasePort(%s)", bool2str(isInput_));
  795. buffer = nullptr;
  796. }
  797. CarlaEngineBasePort::~CarlaEngineBasePort()
  798. {
  799. qDebug("CarlaEngineBasePort::~CarlaEngineBasePort()");
  800. #ifndef BUILD_BRIDGE
  801. if (carlaOptions.processMode == PROCESS_MODE_CONTINUOUS_RACK)
  802. return;
  803. #endif
  804. #ifdef CARLA_ENGINE_JACK
  805. if (handle.jackClient && handle.jackPort)
  806. jackbridge_port_unregister(handle.jackClient, handle.jackPort);
  807. #endif
  808. }
  809. // -------------------------------------------------------------------------------------------------------------------
  810. // Carla Engine Port (Audio)
  811. CarlaEngineAudioPort::CarlaEngineAudioPort(const CarlaEnginePortNativeHandle& handle, const bool isInput)
  812. : CarlaEngineBasePort(handle, isInput)
  813. {
  814. qDebug("CarlaEngineAudioPort::CarlaEngineAudioPort(%s)", bool2str(isInput));
  815. latency = 0;
  816. }
  817. void CarlaEngineAudioPort::initBuffer(CarlaEngine* const /*engine*/)
  818. {
  819. }
  820. uint32_t CarlaEngineAudioPort::getLatency() const
  821. {
  822. return latency;
  823. }
  824. void CarlaEngineAudioPort::setLatency(const uint32_t samples)
  825. {
  826. latency = samples;
  827. }
  828. #ifdef CARLA_ENGINE_JACK
  829. float* CarlaEngineAudioPort::getJackAudioBuffer(uint32_t nframes)
  830. {
  831. # ifndef BUILD_BRIDGE
  832. if (carlaOptions.processMode == PROCESS_MODE_CONTINUOUS_RACK)
  833. return nullptr;
  834. # endif
  835. CARLA_ASSERT(handle.jackPort);
  836. return (float*)jackbridge_port_get_buffer(handle.jackPort, nframes);
  837. }
  838. #endif
  839. // -------------------------------------------------------------------------------------------------------------------
  840. // Carla Engine Port (Control)
  841. CarlaEngineControlPort::CarlaEngineControlPort(const CarlaEnginePortNativeHandle& handle, const bool isInput)
  842. : CarlaEngineBasePort(handle, isInput)
  843. {
  844. qDebug("CarlaEngineControlPort::CarlaEngineControlPort(%s)", bool2str(isInput));
  845. }
  846. void CarlaEngineControlPort::initBuffer(CarlaEngine* const engine)
  847. {
  848. CARLA_ASSERT(engine);
  849. #ifndef BUILD_BRIDGE
  850. if (carlaOptions.processMode == PROCESS_MODE_CONTINUOUS_RACK)
  851. {
  852. buffer = isInput ? engine->rackControlEventsIn : engine->rackControlEventsOut;
  853. return;
  854. }
  855. #endif
  856. #ifdef CARLA_ENGINE_JACK
  857. if (handle.jackPort)
  858. {
  859. buffer = jackbridge_port_get_buffer(handle.jackPort, engine->getBufferSize());
  860. if (! isInput)
  861. jackbridge_midi_clear_buffer(buffer);
  862. }
  863. #endif
  864. }
  865. uint32_t CarlaEngineControlPort::getEventCount()
  866. {
  867. if (! isInput)
  868. return 0;
  869. CARLA_ASSERT(buffer);
  870. #ifndef BUILD_BRIDGE
  871. if (carlaOptions.processMode == PROCESS_MODE_CONTINUOUS_RACK)
  872. {
  873. uint32_t count = 0;
  874. const CarlaEngineControlEvent* const events = (CarlaEngineControlEvent*)buffer;
  875. for (unsigned short i=0; i < CarlaEngine::MAX_ENGINE_CONTROL_EVENTS; i++)
  876. {
  877. if (events[i].type != CarlaEngineEventNull)
  878. count++;
  879. else
  880. break;
  881. }
  882. return count;
  883. }
  884. #endif
  885. #ifdef CARLA_ENGINE_JACK
  886. if (handle.jackPort)
  887. return jackbridge_midi_get_event_count(buffer);
  888. #endif
  889. return 0;
  890. }
  891. const CarlaEngineControlEvent* CarlaEngineControlPort::getEvent(uint32_t index)
  892. {
  893. if (! isInput)
  894. return nullptr;
  895. CARLA_ASSERT(buffer);
  896. #ifndef BUILD_BRIDGE
  897. CARLA_ASSERT(index < CarlaEngine::MAX_ENGINE_CONTROL_EVENTS);
  898. if (carlaOptions.processMode == PROCESS_MODE_CONTINUOUS_RACK)
  899. {
  900. const CarlaEngineControlEvent* const events = (CarlaEngineControlEvent*)buffer;
  901. if (index < CarlaEngine::MAX_ENGINE_CONTROL_EVENTS)
  902. return &events[index];
  903. return nullptr;
  904. }
  905. #endif
  906. #ifdef CARLA_ENGINE_JACK
  907. if (handle.jackPort)
  908. {
  909. static jackbridge_midi_event_t jackEvent;
  910. static CarlaEngineControlEvent carlaEvent;
  911. if (jackbridge_midi_event_get(&jackEvent, buffer, index) != 0)
  912. return nullptr;
  913. memset(&carlaEvent, 0, sizeof(CarlaEngineControlEvent));
  914. uint8_t midiStatus = jackEvent.buffer[0];
  915. uint8_t midiChannel = midiStatus & 0x0F;
  916. carlaEvent.time = jackEvent.time;
  917. carlaEvent.channel = midiChannel;
  918. if (MIDI_IS_STATUS_CONTROL_CHANGE(midiStatus))
  919. {
  920. uint8_t midiControl = jackEvent.buffer[1];
  921. if (MIDI_IS_CONTROL_BANK_SELECT(midiControl))
  922. {
  923. uint8_t midiBank = jackEvent.buffer[2];
  924. carlaEvent.type = CarlaEngineEventMidiBankChange;
  925. carlaEvent.value = midiBank;
  926. }
  927. else if (midiControl == MIDI_CONTROL_ALL_SOUND_OFF)
  928. {
  929. carlaEvent.type = CarlaEngineEventAllSoundOff;
  930. }
  931. else if (midiControl == MIDI_CONTROL_ALL_NOTES_OFF)
  932. {
  933. carlaEvent.type = CarlaEngineEventAllNotesOff;
  934. }
  935. else
  936. {
  937. uint8_t midiValue = jackEvent.buffer[2];
  938. carlaEvent.type = CarlaEngineEventControlChange;
  939. carlaEvent.controller = midiControl;
  940. carlaEvent.value = double(midiValue)/127;
  941. }
  942. return &carlaEvent;
  943. }
  944. else if (MIDI_IS_STATUS_PROGRAM_CHANGE(midiStatus))
  945. {
  946. uint8_t midiProgram = jackEvent.buffer[1];
  947. carlaEvent.type = CarlaEngineEventMidiProgramChange;
  948. carlaEvent.value = midiProgram;
  949. return &carlaEvent;
  950. }
  951. }
  952. #endif
  953. return nullptr;
  954. }
  955. void CarlaEngineControlPort::writeEvent(CarlaEngineControlEventType type, uint32_t time, uint8_t channel, uint8_t controller, double value)
  956. {
  957. if (isInput)
  958. return;
  959. CARLA_ASSERT(buffer);
  960. CARLA_ASSERT(type != CarlaEngineEventNull);
  961. #ifndef BUILD_BRIDGE
  962. if (carlaOptions.processMode == PROCESS_MODE_CONTINUOUS_RACK)
  963. {
  964. CarlaEngineControlEvent* const events = (CarlaEngineControlEvent*)buffer;
  965. for (unsigned short i=0; i < CarlaEngine::MAX_ENGINE_CONTROL_EVENTS; i++)
  966. {
  967. if (events[i].type == CarlaEngineEventNull)
  968. {
  969. events[i].type = type;
  970. events[i].time = time;
  971. events[i].value = value;
  972. events[i].channel = channel;
  973. events[i].controller = controller;
  974. break;
  975. }
  976. }
  977. return;
  978. }
  979. #endif
  980. #ifdef CARLA_ENGINE_JACK
  981. if (handle.jackPort)
  982. {
  983. if (type == CarlaEngineEventControlChange && MIDI_IS_CONTROL_BANK_SELECT(controller))
  984. type = CarlaEngineEventMidiBankChange;
  985. uint8_t data[4] = { 0 };
  986. switch (type)
  987. {
  988. case CarlaEngineEventNull:
  989. break;
  990. case CarlaEngineEventControlChange:
  991. data[0] = MIDI_STATUS_CONTROL_CHANGE + channel;
  992. data[1] = controller;
  993. data[2] = value * 127;
  994. jackbridge_midi_event_write(buffer, time, data, 3);
  995. break;
  996. case CarlaEngineEventMidiBankChange:
  997. data[0] = MIDI_STATUS_CONTROL_CHANGE + channel;
  998. data[1] = MIDI_CONTROL_BANK_SELECT;
  999. data[2] = value;
  1000. jackbridge_midi_event_write(buffer, time, data, 3);
  1001. break;
  1002. case CarlaEngineEventMidiProgramChange:
  1003. data[0] = MIDI_STATUS_PROGRAM_CHANGE + channel;
  1004. data[1] = value;
  1005. jackbridge_midi_event_write(buffer, time, data, 2);
  1006. break;
  1007. case CarlaEngineEventAllSoundOff:
  1008. data[0] = MIDI_STATUS_CONTROL_CHANGE + channel;
  1009. data[1] = MIDI_CONTROL_ALL_SOUND_OFF;
  1010. jackbridge_midi_event_write(buffer, time, data, 2);
  1011. break;
  1012. case CarlaEngineEventAllNotesOff:
  1013. data[0] = MIDI_STATUS_CONTROL_CHANGE + channel;
  1014. data[1] = MIDI_CONTROL_ALL_NOTES_OFF;
  1015. jackbridge_midi_event_write(buffer, time, data, 2);
  1016. break;
  1017. }
  1018. }
  1019. #endif
  1020. }
  1021. // -------------------------------------------------------------------------------------------------------------------
  1022. // Carla Engine Port (MIDI)
  1023. CarlaEngineMidiPort::CarlaEngineMidiPort(const CarlaEnginePortNativeHandle& handle, const bool isInput)
  1024. : CarlaEngineBasePort(handle, isInput)
  1025. {
  1026. qDebug("CarlaEngineMidiPort::CarlaEngineMidiPort(%s)", bool2str(isInput));
  1027. }
  1028. void CarlaEngineMidiPort::initBuffer(CarlaEngine* const engine)
  1029. {
  1030. CARLA_ASSERT(engine);
  1031. #ifndef BUILD_BRIDGE
  1032. if (carlaOptions.processMode == PROCESS_MODE_CONTINUOUS_RACK)
  1033. {
  1034. buffer = isInput ? engine->rackMidiEventsIn : engine->rackMidiEventsOut;
  1035. return;
  1036. }
  1037. #endif
  1038. #ifdef CARLA_ENGINE_JACK
  1039. if (handle.jackPort)
  1040. {
  1041. buffer = jackbridge_port_get_buffer(handle.jackPort, engine->getBufferSize());
  1042. if (! isInput)
  1043. jackbridge_midi_clear_buffer(buffer);
  1044. }
  1045. #endif
  1046. }
  1047. uint32_t CarlaEngineMidiPort::getEventCount()
  1048. {
  1049. if (! isInput)
  1050. return 0;
  1051. CARLA_ASSERT(buffer);
  1052. #ifndef BUILD_BRIDGE
  1053. if (carlaOptions.processMode == PROCESS_MODE_CONTINUOUS_RACK)
  1054. {
  1055. uint32_t count = 0;
  1056. const CarlaEngineMidiEvent* const events = (CarlaEngineMidiEvent*)buffer;
  1057. for (unsigned short i=0; i < CarlaEngine::MAX_ENGINE_MIDI_EVENTS; i++)
  1058. {
  1059. if (events[i].size > 0)
  1060. count++;
  1061. else
  1062. break;
  1063. }
  1064. return count;
  1065. }
  1066. #endif
  1067. #ifdef CARLA_ENGINE_JACK
  1068. if (handle.jackPort)
  1069. return jackbridge_midi_get_event_count(buffer);
  1070. #endif
  1071. return 0;
  1072. }
  1073. const CarlaEngineMidiEvent* CarlaEngineMidiPort::getEvent(uint32_t index)
  1074. {
  1075. if (! isInput)
  1076. return nullptr;
  1077. CARLA_ASSERT(buffer);
  1078. #ifndef BUILD_BRIDGE
  1079. CARLA_ASSERT(index < CarlaEngine::MAX_ENGINE_MIDI_EVENTS);
  1080. if (carlaOptions.processMode == PROCESS_MODE_CONTINUOUS_RACK)
  1081. {
  1082. const CarlaEngineMidiEvent* const events = (CarlaEngineMidiEvent*)buffer;
  1083. if (index < CarlaEngine::MAX_ENGINE_MIDI_EVENTS)
  1084. return &events[index];
  1085. return nullptr;
  1086. }
  1087. #endif
  1088. #ifdef CARLA_ENGINE_JACK
  1089. if (handle.jackPort)
  1090. {
  1091. static jackbridge_midi_event_t jackEvent;
  1092. static CarlaEngineMidiEvent carlaEvent;
  1093. if (jackbridge_midi_event_get(&jackEvent, buffer, index) == 0 && jackEvent.size <= 4)
  1094. {
  1095. carlaEvent.time = jackEvent.time;
  1096. carlaEvent.size = jackEvent.size;
  1097. memcpy(carlaEvent.data, jackEvent.buffer, jackEvent.size);
  1098. return &carlaEvent;
  1099. }
  1100. }
  1101. #endif
  1102. return nullptr;
  1103. }
  1104. void CarlaEngineMidiPort::writeEvent(uint32_t time, const uint8_t* data, uint8_t size)
  1105. {
  1106. if (isInput)
  1107. return;
  1108. CARLA_ASSERT(buffer);
  1109. CARLA_ASSERT(data);
  1110. CARLA_ASSERT(size > 0);
  1111. #ifndef BUILD_BRIDGE
  1112. if (carlaOptions.processMode == PROCESS_MODE_CONTINUOUS_RACK)
  1113. {
  1114. if (size > 4)
  1115. return;
  1116. CarlaEngineMidiEvent* const events = (CarlaEngineMidiEvent*)buffer;
  1117. for (unsigned short i=0; i < CarlaEngine::MAX_ENGINE_MIDI_EVENTS; i++)
  1118. {
  1119. if (events[i].size == 0)
  1120. {
  1121. events[i].time = time;
  1122. events[i].size = size;
  1123. memcpy(events[i].data, data, size);
  1124. break;
  1125. }
  1126. }
  1127. return;
  1128. }
  1129. #endif
  1130. #ifdef CARLA_ENGINE_JACK
  1131. if (handle.jackPort)
  1132. jackbridge_midi_event_write(buffer, time, data, size);
  1133. #endif
  1134. }
  1135. // -------------------------------------------------------------------------------------------------------------------
  1136. // Carla Engine OSC stuff
  1137. #ifndef BUILD_BRIDGE
  1138. void CarlaEngine::osc_send_control_add_plugin_start(const int32_t pluginId, const char* const pluginName)
  1139. {
  1140. qDebug("CarlaEngine::osc_send_control_add_plugin_start(%i, \"%s\")", pluginId, pluginName);
  1141. CARLA_ASSERT(m_oscData);
  1142. CARLA_ASSERT(pluginId >= 0 && pluginId < m_maxPluginNumber);
  1143. CARLA_ASSERT(pluginName);
  1144. if (m_oscData && m_oscData->target)
  1145. {
  1146. char target_path[strlen(m_oscData->path)+18];
  1147. strcpy(target_path, m_oscData->path);
  1148. strcat(target_path, "/add_plugin_start");
  1149. lo_send(m_oscData->target, target_path, "is", pluginId, pluginName);
  1150. }
  1151. }
  1152. void CarlaEngine::osc_send_control_add_plugin_end(const int32_t pluginId)
  1153. {
  1154. qDebug("CarlaEngine::osc_send_control_add_plugin_end(%i)", pluginId);
  1155. CARLA_ASSERT(m_oscData);
  1156. CARLA_ASSERT(pluginId >= 0 && pluginId < m_maxPluginNumber);
  1157. if (m_oscData && m_oscData->target)
  1158. {
  1159. char target_path[strlen(m_oscData->path)+16];
  1160. strcpy(target_path, m_oscData->path);
  1161. strcat(target_path, "/add_plugin_end");
  1162. lo_send(m_oscData->target, target_path, "i", pluginId);
  1163. }
  1164. }
  1165. void CarlaEngine::osc_send_control_remove_plugin(const int32_t pluginId)
  1166. {
  1167. qDebug("CarlaEngine::osc_send_control_remove_plugin(%i)", pluginId);
  1168. CARLA_ASSERT(m_oscData);
  1169. CARLA_ASSERT(pluginId >= 0 && pluginId < m_maxPluginNumber);
  1170. if (m_oscData && m_oscData->target)
  1171. {
  1172. char target_path[strlen(m_oscData->path)+15];
  1173. strcpy(target_path, m_oscData->path);
  1174. strcat(target_path, "/remove_plugin");
  1175. lo_send(m_oscData->target, target_path, "i", pluginId);
  1176. }
  1177. }
  1178. void CarlaEngine::osc_send_control_set_plugin_data(const int32_t pluginId, const int32_t type, const int32_t category, const int32_t hints, const char* const realName, const char* const label, const char* const maker, const char* const copyright, const int64_t uniqueId)
  1179. {
  1180. qDebug("CarlaEngine::osc_send_control_set_plugin_data(%i, %i, %i, %i, \"%s\", \"%s\", \"%s\", \"%s\", " P_INT64 ")", pluginId, type, category, hints, realName, label, maker, copyright, uniqueId);
  1181. CARLA_ASSERT(m_oscData);
  1182. CARLA_ASSERT(pluginId >= 0 && pluginId < m_maxPluginNumber);
  1183. CARLA_ASSERT(type != PLUGIN_NONE);
  1184. if (m_oscData && m_oscData->target)
  1185. {
  1186. char target_path[strlen(m_oscData->path)+17];
  1187. strcpy(target_path, m_oscData->path);
  1188. strcat(target_path, "/set_plugin_data");
  1189. lo_send(m_oscData->target, target_path, "iiiissssh", pluginId, type, category, hints, realName, label, maker, copyright, uniqueId);
  1190. }
  1191. }
  1192. void CarlaEngine::osc_send_control_set_plugin_ports(const int32_t pluginId, const int32_t audioIns, const int32_t audioOuts, const int32_t midiIns, const int32_t midiOuts, const int32_t cIns, const int32_t cOuts, const int32_t cTotals)
  1193. {
  1194. qDebug("CarlaEngine::osc_send_control_set_plugin_ports(%i, %i, %i, %i, %i, %i, %i, %i)", pluginId, audioIns, audioOuts, midiIns, midiOuts, cIns, cOuts, cTotals);
  1195. CARLA_ASSERT(m_oscData);
  1196. CARLA_ASSERT(pluginId >= 0 && pluginId < m_maxPluginNumber);
  1197. if (m_oscData && m_oscData->target)
  1198. {
  1199. char target_path[strlen(m_oscData->path)+18];
  1200. strcpy(target_path, m_oscData->path);
  1201. strcat(target_path, "/set_plugin_ports");
  1202. lo_send(m_oscData->target, target_path, "iiiiiiii", pluginId, audioIns, audioOuts, midiIns, midiOuts, cIns, cOuts, cTotals);
  1203. }
  1204. }
  1205. void CarlaEngine::osc_send_control_set_parameter_data(const int32_t pluginId, const int32_t index, const int32_t type, const int32_t hints, const char* const name, const char* const label, const double current)
  1206. {
  1207. qDebug("CarlaEngine::osc_send_control_set_parameter_data(%i, %i, %i, %i, \"%s\", \"%s\", %g)", pluginId, index, type, hints, name, label, current);
  1208. CARLA_ASSERT(m_oscData);
  1209. CARLA_ASSERT(pluginId >= 0 && pluginId < m_maxPluginNumber);
  1210. CARLA_ASSERT(index >= 0);
  1211. CARLA_ASSERT(type != PARAMETER_UNKNOWN);
  1212. if (m_oscData && m_oscData->target)
  1213. {
  1214. char target_path[strlen(m_oscData->path)+20];
  1215. strcpy(target_path, m_oscData->path);
  1216. strcat(target_path, "/set_parameter_data");
  1217. lo_send(m_oscData->target, target_path, "iiiissd", pluginId, index, type, hints, name, label, current);
  1218. }
  1219. }
  1220. void CarlaEngine::osc_send_control_set_parameter_ranges(const int32_t pluginId, const int32_t index, const double min, const double max, const double def, const double step, const double stepSmall, const double stepLarge)
  1221. {
  1222. qDebug("CarlaEngine::osc_send_control_set_parameter_ranges(%i, %i, %g, %g, %g, %g, %g, %g)", pluginId, index, min, max, def, step, stepSmall, stepLarge);
  1223. CARLA_ASSERT(m_oscData);
  1224. CARLA_ASSERT(pluginId >= 0 && pluginId < m_maxPluginNumber);
  1225. CARLA_ASSERT(index >= 0);
  1226. CARLA_ASSERT(min < max);
  1227. if (m_oscData && m_oscData->target)
  1228. {
  1229. char target_path[strlen(m_oscData->path)+22];
  1230. strcpy(target_path, m_oscData->path);
  1231. strcat(target_path, "/set_parameter_ranges");
  1232. lo_send(m_oscData->target, target_path, "iidddddd", pluginId, index, min, max, def, step, stepSmall, stepLarge);
  1233. }
  1234. }
  1235. void CarlaEngine::osc_send_control_set_parameter_midi_cc(const int32_t pluginId, const int32_t index, const int32_t cc)
  1236. {
  1237. qDebug("CarlaEngine::osc_send_control_set_parameter_midi_cc(%i, %i, %i)", pluginId, index, cc);
  1238. CARLA_ASSERT(m_oscData);
  1239. CARLA_ASSERT(pluginId >= 0 && pluginId < m_maxPluginNumber);
  1240. CARLA_ASSERT(index >= 0);
  1241. if (m_oscData && m_oscData->target)
  1242. {
  1243. char target_path[strlen(m_oscData->path)+23];
  1244. strcpy(target_path, m_oscData->path);
  1245. strcat(target_path, "/set_parameter_midi_cc");
  1246. lo_send(m_oscData->target, target_path, "iii", pluginId, index, cc);
  1247. }
  1248. }
  1249. void CarlaEngine::osc_send_control_set_parameter_midi_channel(const int32_t pluginId, const int32_t index, const int32_t channel)
  1250. {
  1251. qDebug("CarlaEngine::osc_send_control_set_parameter_midi_channel(%i, %i, %i)", pluginId, index, channel);
  1252. CARLA_ASSERT(m_oscData);
  1253. CARLA_ASSERT(pluginId >= 0 && pluginId < m_maxPluginNumber);
  1254. CARLA_ASSERT(index >= 0);
  1255. CARLA_ASSERT(channel >= 0 && channel < 16);
  1256. if (m_oscData && m_oscData->target)
  1257. {
  1258. char target_path[strlen(m_oscData->path)+28];
  1259. strcpy(target_path, m_oscData->path);
  1260. strcat(target_path, "/set_parameter_midi_channel");
  1261. lo_send(m_oscData->target, target_path, "iii", pluginId, index, channel);
  1262. }
  1263. }
  1264. void CarlaEngine::osc_send_control_set_parameter_value(const int32_t pluginId, const int32_t index, const double value)
  1265. {
  1266. #if DEBUG
  1267. if (index < -1)
  1268. qDebug("CarlaEngine::osc_send_control_set_parameter_value(%i, %s, %g)", pluginId, InternalParametersIndex2str((InternalParametersIndex)index), value);
  1269. else
  1270. qDebug("CarlaEngine::osc_send_control_set_parameter_value(%i, %i, %g)", pluginId, index, value);
  1271. #endif
  1272. CARLA_ASSERT(m_oscData);
  1273. CARLA_ASSERT(pluginId >= 0 && pluginId < m_maxPluginNumber);
  1274. if (m_oscData && m_oscData->target)
  1275. {
  1276. char target_path[strlen(m_oscData->path)+21];
  1277. strcpy(target_path, m_oscData->path);
  1278. strcat(target_path, "/set_parameter_value");
  1279. lo_send(m_oscData->target, target_path, "iid", pluginId, index, value);
  1280. }
  1281. }
  1282. void CarlaEngine::osc_send_control_set_default_value(const int32_t pluginId, const int32_t index, const double value)
  1283. {
  1284. qDebug("CarlaEngine::osc_send_control_set_default_value(%i, %i, %g)", pluginId, index, value);
  1285. CARLA_ASSERT(m_oscData);
  1286. CARLA_ASSERT(pluginId >= 0 && pluginId < m_maxPluginNumber);
  1287. CARLA_ASSERT(index >= 0);
  1288. if (m_oscData && m_oscData->target)
  1289. {
  1290. char target_path[strlen(m_oscData->path)+19];
  1291. strcpy(target_path, m_oscData->path);
  1292. strcat(target_path, "/set_default_value");
  1293. lo_send(m_oscData->target, target_path, "iid", pluginId, index, value);
  1294. }
  1295. }
  1296. void CarlaEngine::osc_send_control_set_program(const int32_t pluginId, const int32_t index)
  1297. {
  1298. qDebug("CarlaEngine::osc_send_control_set_program(%i, %i)", pluginId, index);
  1299. CARLA_ASSERT(m_oscData);
  1300. CARLA_ASSERT(pluginId >= 0 && pluginId < m_maxPluginNumber);
  1301. if (m_oscData && m_oscData->target)
  1302. {
  1303. char target_path[strlen(m_oscData->path)+13];
  1304. strcpy(target_path, m_oscData->path);
  1305. strcat(target_path, "/set_program");
  1306. lo_send(m_oscData->target, target_path, "ii", pluginId, index);
  1307. }
  1308. }
  1309. void CarlaEngine::osc_send_control_set_program_count(const int32_t pluginId, const int32_t count)
  1310. {
  1311. qDebug("CarlaEngine::osc_send_control_set_program_count(%i, %i)", pluginId, count);
  1312. CARLA_ASSERT(m_oscData);
  1313. CARLA_ASSERT(pluginId >= 0 && pluginId < m_maxPluginNumber);
  1314. CARLA_ASSERT(count >= 0);
  1315. if (m_oscData && m_oscData->target)
  1316. {
  1317. char target_path[strlen(m_oscData->path)+19];
  1318. strcpy(target_path, m_oscData->path);
  1319. strcat(target_path, "/set_program_count");
  1320. lo_send(m_oscData->target, target_path, "ii", pluginId, count);
  1321. }
  1322. }
  1323. void CarlaEngine::osc_send_control_set_program_name(const int32_t pluginId, const int32_t index, const char* const name)
  1324. {
  1325. qDebug("CarlaEngine::osc_send_control_set_program_name(%i, %i, \"%s\")", pluginId, index, name);
  1326. CARLA_ASSERT(m_oscData);
  1327. CARLA_ASSERT(pluginId >= 0 && pluginId < m_maxPluginNumber);
  1328. CARLA_ASSERT(index >= 0);
  1329. CARLA_ASSERT(name);
  1330. if (m_oscData && m_oscData->target)
  1331. {
  1332. char target_path[strlen(m_oscData->path)+18];
  1333. strcpy(target_path, m_oscData->path);
  1334. strcat(target_path, "/set_program_name");
  1335. lo_send(m_oscData->target, target_path, "iis", pluginId, index, name);
  1336. }
  1337. }
  1338. void CarlaEngine::osc_send_control_set_midi_program(const int32_t pluginId, const int32_t index)
  1339. {
  1340. qDebug("CarlaEngine::osc_send_control_set_midi_program(%i, %i)", pluginId, index);
  1341. CARLA_ASSERT(m_oscData);
  1342. CARLA_ASSERT(pluginId >= 0 && pluginId < m_maxPluginNumber);
  1343. if (m_oscData && m_oscData->target)
  1344. {
  1345. char target_path[strlen(m_oscData->path)+18];
  1346. strcpy(target_path, m_oscData->path);
  1347. strcat(target_path, "/set_midi_program");
  1348. lo_send(m_oscData->target, target_path, "ii", pluginId, index);
  1349. }
  1350. }
  1351. void CarlaEngine::osc_send_control_set_midi_program_count(const int32_t pluginId, const int32_t count)
  1352. {
  1353. qDebug("CarlaEngine::osc_send_control_set_midi_program_count(%i, %i)", pluginId, count);
  1354. CARLA_ASSERT(m_oscData);
  1355. CARLA_ASSERT(pluginId >= 0 && pluginId < m_maxPluginNumber);
  1356. CARLA_ASSERT(count >= 0);
  1357. if (m_oscData && m_oscData->target)
  1358. {
  1359. char target_path[strlen(m_oscData->path)+24];
  1360. strcpy(target_path, m_oscData->path);
  1361. strcat(target_path, "/set_midi_program_count");
  1362. lo_send(m_oscData->target, target_path, "ii", pluginId, count);
  1363. }
  1364. }
  1365. void CarlaEngine::osc_send_control_set_midi_program_data(const int32_t pluginId, const int32_t index, const int32_t bank, const int32_t program, const char* const name)
  1366. {
  1367. qDebug("CarlaEngine::osc_send_control_set_midi_program_data(%i, %i, %i, %i, \"%s\")", pluginId, index, bank, program, name);
  1368. CARLA_ASSERT(m_oscData);
  1369. CARLA_ASSERT(pluginId >= 0 && pluginId < m_maxPluginNumber);
  1370. CARLA_ASSERT(index >= 0);
  1371. CARLA_ASSERT(bank >= 0);
  1372. CARLA_ASSERT(program >= 0);
  1373. CARLA_ASSERT(name);
  1374. if (m_oscData && m_oscData->target)
  1375. {
  1376. char target_path[strlen(m_oscData->path)+23];
  1377. strcpy(target_path, m_oscData->path);
  1378. strcat(target_path, "/set_midi_program_data");
  1379. lo_send(m_oscData->target, target_path, "iiiis", pluginId, index, bank, program, name);
  1380. }
  1381. }
  1382. void CarlaEngine::osc_send_control_note_on(const int32_t pluginId, const int32_t channel, const int32_t note, const int32_t velo)
  1383. {
  1384. qDebug("CarlaEngine::osc_send_control_note_on(%i, %i, %i, %i)", pluginId, channel, note, velo);
  1385. CARLA_ASSERT(m_oscData);
  1386. CARLA_ASSERT(pluginId >= 0 && pluginId < m_maxPluginNumber);
  1387. CARLA_ASSERT(channel >= 0 && channel < 16);
  1388. CARLA_ASSERT(note >= 0 && note < 128);
  1389. CARLA_ASSERT(velo > 0 && velo < 128);
  1390. if (m_oscData && m_oscData->target)
  1391. {
  1392. char target_path[strlen(m_oscData->path)+9];
  1393. strcpy(target_path, m_oscData->path);
  1394. strcat(target_path, "/note_on");
  1395. lo_send(m_oscData->target, target_path, "iiii", pluginId, channel, note, velo);
  1396. }
  1397. }
  1398. void CarlaEngine::osc_send_control_note_off(const int32_t pluginId, const int32_t channel, const int32_t note)
  1399. {
  1400. qDebug("CarlaEngine::osc_send_control_note_off(%i, %i, %i)", pluginId, channel, note);
  1401. CARLA_ASSERT(m_oscData);
  1402. CARLA_ASSERT(pluginId >= 0 && pluginId < m_maxPluginNumber);
  1403. CARLA_ASSERT(channel >= 0 && channel < 16);
  1404. CARLA_ASSERT(note >= 0 && note < 128);
  1405. if (m_oscData && m_oscData->target)
  1406. {
  1407. char target_path[strlen(m_oscData->path)+10];
  1408. strcpy(target_path, m_oscData->path);
  1409. strcat(target_path, "/note_off");
  1410. lo_send(m_oscData->target, target_path, "iii", pluginId, channel, note);
  1411. }
  1412. }
  1413. void CarlaEngine::osc_send_control_set_input_peak_value(const int32_t pluginId, const int32_t portId, const double value)
  1414. {
  1415. //qDebug("CarlaEngine::osc_send_control_set_input_peak_value(%i, %i, %g)", pluginId, portId, value);
  1416. CARLA_ASSERT(m_oscData);
  1417. CARLA_ASSERT(pluginId >= 0 && pluginId < m_maxPluginNumber);
  1418. CARLA_ASSERT(portId == 1 || portId == 2);
  1419. if (m_oscData && m_oscData->target)
  1420. {
  1421. char target_path[strlen(m_oscData->path)+22];
  1422. strcpy(target_path, m_oscData->path);
  1423. strcat(target_path, "/set_input_peak_value");
  1424. lo_send(m_oscData->target, target_path, "iid", pluginId, portId, value);
  1425. }
  1426. }
  1427. void CarlaEngine::osc_send_control_set_output_peak_value(const int32_t pluginId, const int32_t portId, const double value)
  1428. {
  1429. //qDebug("CarlaEngine::osc_send_control_set_output_peak_value(%i, %i, %g)", pluginId, portId, value);
  1430. CARLA_ASSERT(m_oscData);
  1431. CARLA_ASSERT(pluginId >= 0 && pluginId < m_maxPluginNumber);
  1432. CARLA_ASSERT(portId == 1 || portId == 2);
  1433. if (m_oscData && m_oscData->target)
  1434. {
  1435. char target_path[strlen(m_oscData->path)+23];
  1436. strcpy(target_path, m_oscData->path);
  1437. strcat(target_path, "/set_output_peak_value");
  1438. lo_send(m_oscData->target, target_path, "iid", pluginId, portId, value);
  1439. }
  1440. }
  1441. void CarlaEngine::osc_send_control_exit()
  1442. {
  1443. qDebug("CarlaEngine::osc_send_control_exit()");
  1444. CARLA_ASSERT(m_oscData);
  1445. if (m_oscData && m_oscData->target)
  1446. {
  1447. char target_path[strlen(m_oscData->path)+6];
  1448. strcpy(target_path, m_oscData->path);
  1449. strcat(target_path, "/exit");
  1450. lo_send(m_oscData->target, target_path, "");
  1451. }
  1452. }
  1453. #else
  1454. void CarlaEngine::osc_send_bridge_audio_count(const int32_t ins, const int32_t outs, const int32_t total)
  1455. {
  1456. qDebug("CarlaEngine::osc_send_bridge_audio_count(%i, %i, %i)", ins, outs, total);
  1457. CARLA_ASSERT(m_oscData);
  1458. CARLA_ASSERT(total >= 0 && total >= ins + outs);
  1459. if (m_oscData && m_oscData->target)
  1460. {
  1461. char target_path[strlen(m_oscData->path)+20];
  1462. strcpy(target_path, m_oscData->path);
  1463. strcat(target_path, "/bridge_audio_count");
  1464. lo_send(m_oscData->target, target_path, "iii", ins, outs, total);
  1465. }
  1466. }
  1467. void CarlaEngine::osc_send_bridge_midi_count(const int32_t ins, const int32_t outs, const int32_t total)
  1468. {
  1469. qDebug("CarlaEngine::osc_send_bridge_midi_count(%i, %i, %i)", ins, outs, total);
  1470. CARLA_ASSERT(m_oscData);
  1471. CARLA_ASSERT(total >= 0 && total >= ins + outs);
  1472. if (m_oscData && m_oscData->target)
  1473. {
  1474. char target_path[strlen(m_oscData->path)+19];
  1475. strcpy(target_path, m_oscData->path);
  1476. strcat(target_path, "/bridge_midi_count");
  1477. lo_send(m_oscData->target, target_path, "iii", ins, outs, total);
  1478. }
  1479. }
  1480. void CarlaEngine::osc_send_bridge_parameter_count(const int32_t ins, const int32_t outs, const int32_t total)
  1481. {
  1482. qDebug("CarlaEngine::osc_send_bridge_parameter_count(%i, %i, %i)", ins, outs, total);
  1483. CARLA_ASSERT(m_oscData);
  1484. CARLA_ASSERT(total >= 0 && total >= ins + outs);
  1485. if (m_oscData && m_oscData->target)
  1486. {
  1487. char target_path[strlen(m_oscData->path)+24];
  1488. strcpy(target_path, m_oscData->path);
  1489. strcat(target_path, "/bridge_parameter_count");
  1490. lo_send(m_oscData->target, target_path, "iii", ins, outs, total);
  1491. }
  1492. }
  1493. void CarlaEngine::osc_send_bridge_program_count(const int32_t count)
  1494. {
  1495. qDebug("CarlaEngine::osc_send_bridge_program_count(%i)", count);
  1496. CARLA_ASSERT(m_oscData);
  1497. CARLA_ASSERT(count >= 0);
  1498. if (m_oscData && m_oscData->target)
  1499. {
  1500. char target_path[strlen(m_oscData->path)+22];
  1501. strcpy(target_path, m_oscData->path);
  1502. strcat(target_path, "/bridge_program_count");
  1503. lo_send(m_oscData->target, target_path, "i", count);
  1504. }
  1505. }
  1506. void CarlaEngine::osc_send_bridge_midi_program_count(const int32_t count)
  1507. {
  1508. qDebug("CarlaEngine::osc_send_bridge_midi_program_count(%i)", count);
  1509. CARLA_ASSERT(m_oscData);
  1510. CARLA_ASSERT(count >= 0);
  1511. if (m_oscData && m_oscData->target)
  1512. {
  1513. char target_path[strlen(m_oscData->path)+27];
  1514. strcpy(target_path, m_oscData->path);
  1515. strcat(target_path, "/bridge_midi_program_count");
  1516. lo_send(m_oscData->target, target_path, "i", count);
  1517. }
  1518. }
  1519. void CarlaEngine::osc_send_bridge_plugin_info(const int32_t category, const int32_t hints, const char* const name, const char* const label, const char* const maker, const char* const copyright, const int64_t uniqueId)
  1520. {
  1521. qDebug("CarlaEngine::osc_send_bridge_plugin_info(%i, %i, \"%s\", \"%s\", \"%s\", \"%s\", " P_INT64 ")", category, hints, name, label, maker, copyright, uniqueId);
  1522. CARLA_ASSERT(m_oscData);
  1523. CARLA_ASSERT(name);
  1524. CARLA_ASSERT(label);
  1525. CARLA_ASSERT(maker);
  1526. CARLA_ASSERT(copyright);
  1527. if (m_oscData && m_oscData->target)
  1528. {
  1529. char target_path[strlen(m_oscData->path)+20];
  1530. strcpy(target_path, m_oscData->path);
  1531. strcat(target_path, "/bridge_plugin_info");
  1532. lo_send(m_oscData->target, target_path, "iissssh", category, hints, name, label, maker, copyright, uniqueId);
  1533. }
  1534. }
  1535. void CarlaEngine::osc_send_bridge_parameter_info(const int32_t index, const char* const name, const char* const unit)
  1536. {
  1537. qDebug("CarlaEngine::osc_send_bridge_parameter_info(%i, \"%s\", \"%s\")", index, name, unit);
  1538. CARLA_ASSERT(m_oscData);
  1539. CARLA_ASSERT(name);
  1540. CARLA_ASSERT(unit);
  1541. if (m_oscData && m_oscData->target)
  1542. {
  1543. char target_path[strlen(m_oscData->path)+23];
  1544. strcpy(target_path, m_oscData->path);
  1545. strcat(target_path, "/bridge_parameter_info");
  1546. lo_send(m_oscData->target, target_path, "iss", index, name, unit);
  1547. }
  1548. }
  1549. void CarlaEngine::osc_send_bridge_parameter_data(const int32_t index, const int32_t type, const int32_t rindex, const int32_t hints, const int32_t midiChannel, const int32_t midiCC)
  1550. {
  1551. qDebug("CarlaEngine::osc_send_bridge_parameter_data(%i, %i, %i, %i, %i, %i)", index, type, rindex, hints, midiChannel, midiCC);
  1552. CARLA_ASSERT(m_oscData);
  1553. if (m_oscData && m_oscData->target)
  1554. {
  1555. char target_path[strlen(m_oscData->path)+23];
  1556. strcpy(target_path, m_oscData->path);
  1557. strcat(target_path, "/bridge_parameter_data");
  1558. lo_send(m_oscData->target, target_path, "iiiiii", index, type, rindex, hints, midiChannel, midiCC);
  1559. }
  1560. }
  1561. void CarlaEngine::osc_send_bridge_parameter_ranges(const int32_t index, const double def, const double min, const double max, const double step, const double stepSmall, const double stepLarge)
  1562. {
  1563. qDebug("CarlaEngine::osc_send_bridge_parameter_ranges(%i, %g, %g, %g, %g, %g, %g)", index, def, min, max, step, stepSmall, stepLarge);
  1564. CARLA_ASSERT(m_oscData);
  1565. if (m_oscData && m_oscData->target)
  1566. {
  1567. char target_path[strlen(m_oscData->path)+25];
  1568. strcpy(target_path, m_oscData->path);
  1569. strcat(target_path, "/bridge_parameter_ranges");
  1570. lo_send(m_oscData->target, target_path, "idddddd", index, def, min, max, step, stepSmall, stepLarge);
  1571. }
  1572. }
  1573. void CarlaEngine::osc_send_bridge_program_info(const int32_t index, const char* const name)
  1574. {
  1575. qDebug("CarlaEngine::osc_send_bridge_program_info(%i, \"%s\")", index, name);
  1576. CARLA_ASSERT(m_oscData);
  1577. if (m_oscData && m_oscData->target)
  1578. {
  1579. char target_path[strlen(m_oscData->path)+21];
  1580. strcpy(target_path, m_oscData->path);
  1581. strcat(target_path, "/bridge_program_info");
  1582. lo_send(m_oscData->target, target_path, "is", index, name);
  1583. }
  1584. }
  1585. void CarlaEngine::osc_send_bridge_midi_program_info(const int32_t index, const int32_t bank, const int32_t program, const char* const label)
  1586. {
  1587. qDebug("CarlaEngine::osc_send_bridge_midi_program_info(%i, %i, %i, \"%s\")", index, bank, program, label);
  1588. CARLA_ASSERT(m_oscData);
  1589. if (m_oscData && m_oscData->target)
  1590. {
  1591. char target_path[strlen(m_oscData->path)+26];
  1592. strcpy(target_path, m_oscData->path);
  1593. strcat(target_path, "/bridge_midi_program_info");
  1594. lo_send(m_oscData->target, target_path, "iiis", index, bank, program, label);
  1595. }
  1596. }
  1597. void CarlaEngine::osc_send_bridge_configure(const char* const key, const char* const value)
  1598. {
  1599. qDebug("CarlaEngine::osc_send_bridge_configure(\"%s\", \"%s\")", key, value);
  1600. CARLA_ASSERT(m_oscData);
  1601. CARLA_ASSERT(key);
  1602. CARLA_ASSERT(value);
  1603. if (m_oscData && m_oscData->target)
  1604. {
  1605. char target_path[strlen(m_oscData->path)+18];
  1606. strcpy(target_path, m_oscData->path);
  1607. strcat(target_path, "/bridge_configure");
  1608. lo_send(m_oscData->target, target_path, "ss", key, value);
  1609. }
  1610. }
  1611. void CarlaEngine::osc_send_bridge_set_parameter_value(const int32_t index, const double value)
  1612. {
  1613. qDebug("CarlaEngine::osc_send_bridge_set_parameter_value(%i, %g)", index, value);
  1614. CARLA_ASSERT(m_oscData);
  1615. if (m_oscData && m_oscData->target)
  1616. {
  1617. char target_path[strlen(m_oscData->path)+28];
  1618. strcpy(target_path, m_oscData->path);
  1619. strcat(target_path, "/bridge_set_parameter_value");
  1620. lo_send(m_oscData->target, target_path, "id", index, value);
  1621. }
  1622. }
  1623. void CarlaEngine::osc_send_bridge_set_default_value(const int32_t index, const double value)
  1624. {
  1625. qDebug("CarlaEngine::osc_send_bridge_set_default_value(%i, %g)", index, value);
  1626. CARLA_ASSERT(m_oscData);
  1627. if (m_oscData && m_oscData->target)
  1628. {
  1629. char target_path[strlen(m_oscData->path)+26];
  1630. strcpy(target_path, m_oscData->path);
  1631. strcat(target_path, "/bridge_set_default_value");
  1632. lo_send(m_oscData->target, target_path, "id", index, value);
  1633. }
  1634. }
  1635. void CarlaEngine::osc_send_bridge_set_program(const int32_t index)
  1636. {
  1637. qDebug("CarlaEngine::osc_send_bridge_set_program(%i)", index);
  1638. CARLA_ASSERT(m_oscData);
  1639. if (m_oscData && m_oscData->target)
  1640. {
  1641. char target_path[strlen(m_oscData->path)+20];
  1642. strcpy(target_path, m_oscData->path);
  1643. strcat(target_path, "/bridge_set_program");
  1644. lo_send(m_oscData->target, target_path, "i", index);
  1645. }
  1646. }
  1647. void CarlaEngine::osc_send_bridge_set_midi_program(const int32_t index)
  1648. {
  1649. qDebug("CarlaEngine::osc_send_bridge_set_midi_program(%i)", index);
  1650. CARLA_ASSERT(m_oscData);
  1651. if (m_oscData && m_oscData->target)
  1652. {
  1653. char target_path[strlen(m_oscData->path)+25];
  1654. strcpy(target_path, m_oscData->path);
  1655. strcat(target_path, "/bridge_set_midi_program");
  1656. lo_send(m_oscData->target, target_path, "i", index);
  1657. }
  1658. }
  1659. void CarlaEngine::osc_send_bridge_set_custom_data(const char* const stype, const char* const key, const char* const value)
  1660. {
  1661. qDebug("CarlaEngine::osc_send_bridge_set_custom_data(\"%s\", \"%s\", \"%s\")", stype, key, value);
  1662. CARLA_ASSERT(m_oscData);
  1663. if (m_oscData && m_oscData->target)
  1664. {
  1665. char target_path[strlen(m_oscData->path)+24];
  1666. strcpy(target_path, m_oscData->path);
  1667. strcat(target_path, "/bridge_set_custom_data");
  1668. lo_send(m_oscData->target, target_path, "sss", stype, key, value);
  1669. }
  1670. }
  1671. void CarlaEngine::osc_send_bridge_set_chunk_data(const char* const chunkFile)
  1672. {
  1673. qDebug("CarlaEngine::osc_send_bridge_set_chunk_data(\"%s\")", chunkFile);
  1674. CARLA_ASSERT(m_oscData);
  1675. if (m_oscData && m_oscData->target)
  1676. {
  1677. char target_path[strlen(m_oscData->path)+23];
  1678. strcpy(target_path, m_oscData->path);
  1679. strcat(target_path, "/bridge_set_chunk_data");
  1680. lo_send(m_oscData->target, target_path, "s", chunkFile);
  1681. }
  1682. }
  1683. void CarlaEngine::osc_send_bridge_set_inpeak(const int32_t portId, const double value)
  1684. {
  1685. CARLA_ASSERT(m_oscData);
  1686. CARLA_ASSERT(portId == 1 || portId == 2);
  1687. if (m_oscData && m_oscData->target)
  1688. {
  1689. char target_path[strlen(m_oscData->path)+28];
  1690. strcpy(target_path, m_oscData->path);
  1691. strcat(target_path, "/bridge_set_inpeak");
  1692. lo_send(m_oscData->target, target_path, "id", portId, value);
  1693. }
  1694. }
  1695. void CarlaEngine::osc_send_bridge_set_outpeak(const int32_t portId, const double value)
  1696. {
  1697. CARLA_ASSERT(m_oscData);
  1698. CARLA_ASSERT(portId == 1 || portId == 2);
  1699. if (m_oscData && m_oscData->target)
  1700. {
  1701. char target_path[strlen(m_oscData->path)+29];
  1702. strcpy(target_path, m_oscData->path);
  1703. strcat(target_path, "/bridge_set_outpeak");
  1704. lo_send(m_oscData->target, target_path, "id", portId, value);
  1705. }
  1706. }
  1707. #endif
  1708. CARLA_BACKEND_END_NAMESPACE