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.

2003 lines
60KB

  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. processUnlock();
  403. delete plugin;
  404. m_carlaPlugins[id] = nullptr;
  405. m_uniqueNames[id] = nullptr;
  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. m_checkThread.startNow();
  422. return true;
  423. }
  424. qCritical("CarlaEngine::removePlugin(%i) - could not find plugin", id);
  425. setLastError("Could not find plugin to remove");
  426. return false;
  427. }
  428. void CarlaEngine::removeAllPlugins()
  429. {
  430. qDebug("CarlaEngine::removeAllPlugins()");
  431. m_checkThread.stopNow();
  432. for (unsigned short i=0; i < m_maxPluginNumber; i++)
  433. {
  434. CarlaPlugin* const plugin = m_carlaPlugins[i];
  435. if (plugin)
  436. {
  437. processLock();
  438. plugin->setEnabled(false);
  439. processUnlock();
  440. delete plugin;
  441. m_carlaPlugins[i] = nullptr;
  442. m_uniqueNames[i] = nullptr;
  443. }
  444. }
  445. m_maxPluginNumber = 0;
  446. }
  447. void CarlaEngine::idlePluginGuis()
  448. {
  449. CARLA_ASSERT(m_maxPluginNumber != 0);
  450. for (unsigned short i=0; i < m_maxPluginNumber; i++)
  451. {
  452. CarlaPlugin* const plugin = m_carlaPlugins[i];
  453. if (plugin && plugin->enabled())
  454. plugin->idleGui();
  455. }
  456. }
  457. #ifndef BUILD_BRIDGE
  458. void CarlaEngine::processRack(float* inBuf[2], float* outBuf[2], uint32_t frames)
  459. {
  460. // initialize outputs (zero)
  461. zeroF(outBuf[0], frames);
  462. zeroF(outBuf[1], frames);
  463. memset(rackControlEventsOut, 0, sizeof(CarlaEngineControlEvent)*MAX_ENGINE_CONTROL_EVENTS);
  464. memset(rackMidiEventsOut, 0, sizeof(CarlaEngineMidiEvent)*MAX_ENGINE_MIDI_EVENTS);
  465. bool processed = false;
  466. // process plugins
  467. for (unsigned short i=0, max=maxPluginNumber(); i < max; i++)
  468. {
  469. CarlaPlugin* const plugin = getPluginUnchecked(i);
  470. if (plugin && plugin->enabled())
  471. {
  472. if (processed)
  473. {
  474. // initialize inputs (from previous outputs)
  475. memcpy(inBuf[0], outBuf[0], sizeof(float)*frames);
  476. memcpy(inBuf[1], outBuf[1], sizeof(float)*frames);
  477. memcpy(rackMidiEventsIn, rackMidiEventsOut, sizeof(CarlaEngineMidiEvent)*MAX_ENGINE_MIDI_EVENTS);
  478. // initialize outputs (zero)
  479. zeroF(outBuf[0], frames);
  480. zeroF(outBuf[1], frames);
  481. memset(rackMidiEventsOut, 0, sizeof(CarlaEngineMidiEvent)*MAX_ENGINE_MIDI_EVENTS);
  482. }
  483. // process
  484. plugin->engineProcessLock();
  485. plugin->initBuffers();
  486. if (carlaOptions.processHighPrecision)
  487. {
  488. float* inBuf2[2];
  489. float* outBuf2[2];
  490. for (uint32_t j=0; j < frames; j += 8)
  491. {
  492. inBuf2[0] = inBuf[0] + j;
  493. inBuf2[1] = inBuf[1] + j;
  494. outBuf2[0] = outBuf[0] + j;
  495. outBuf2[1] = outBuf[1] + j;
  496. plugin->process(inBuf2, outBuf2, 8, j);
  497. }
  498. }
  499. else
  500. plugin->process(inBuf, outBuf, frames);
  501. plugin->engineProcessUnlock();
  502. // if plugin has no audio inputs, add previous buffers
  503. if (plugin->audioInCount() == 0)
  504. {
  505. for (uint32_t j=0; j < frames; j++)
  506. {
  507. outBuf[0][j] += inBuf[0][j];
  508. outBuf[1][j] += inBuf[1][j];
  509. }
  510. }
  511. // if plugin has no midi output, add previous midi input
  512. if (plugin->midiOutCount() == 0)
  513. {
  514. memcpy(rackMidiEventsOut, rackMidiEventsIn, sizeof(CarlaEngineMidiEvent)*MAX_ENGINE_MIDI_EVENTS);
  515. }
  516. processed = true;
  517. }
  518. }
  519. // if no plugins in the rack, copy inputs over outputs
  520. if (! processed)
  521. {
  522. memcpy(outBuf[0], inBuf[0], sizeof(float)*frames);
  523. memcpy(outBuf[1], inBuf[1], sizeof(float)*frames);
  524. memcpy(rackMidiEventsOut, rackMidiEventsIn, sizeof(CarlaEngineMidiEvent)*MAX_ENGINE_MIDI_EVENTS);
  525. }
  526. }
  527. #endif
  528. // -----------------------------------------------------------------------
  529. // Information (base)
  530. CarlaEngineType CarlaEngine::getType() const
  531. {
  532. return type;
  533. }
  534. const char* CarlaEngine::getName() const
  535. {
  536. CARLA_ASSERT(name);
  537. return name;
  538. }
  539. double CarlaEngine::getSampleRate() const
  540. {
  541. //CARLA_ASSERT(sampleRate != 0.0);
  542. return sampleRate;
  543. }
  544. uint32_t CarlaEngine::getBufferSize() const
  545. {
  546. //CARLA_ASSERT(bufferSize != 0);
  547. return bufferSize;
  548. }
  549. const CarlaTimeInfo* CarlaEngine::getTimeInfo() const
  550. {
  551. return &timeInfo;
  552. }
  553. // -----------------------------------------------------------------------
  554. // Information (audio peaks)
  555. double CarlaEngine::getInputPeak(const unsigned short pluginId, const unsigned short id) const
  556. {
  557. CARLA_ASSERT(pluginId < m_maxPluginNumber);
  558. CARLA_ASSERT(id < MAX_PEAKS);
  559. return m_insPeak[pluginId*MAX_PEAKS + id];
  560. }
  561. double CarlaEngine::getOutputPeak(const unsigned short pluginId, const unsigned short id) const
  562. {
  563. CARLA_ASSERT(pluginId < m_maxPluginNumber);
  564. CARLA_ASSERT(id < MAX_PEAKS);
  565. return m_outsPeak[pluginId*MAX_PEAKS + id];
  566. }
  567. void CarlaEngine::setInputPeak(const unsigned short pluginId, const unsigned short id, double value)
  568. {
  569. CARLA_ASSERT(pluginId < m_maxPluginNumber);
  570. CARLA_ASSERT(id < MAX_PEAKS);
  571. m_insPeak[pluginId*MAX_PEAKS + id] = value;
  572. }
  573. void CarlaEngine::setOutputPeak(const unsigned short pluginId, const unsigned short id, double value)
  574. {
  575. CARLA_ASSERT(pluginId < m_maxPluginNumber);
  576. CARLA_ASSERT(id < MAX_PEAKS);
  577. m_outsPeak[pluginId*MAX_PEAKS + id] = value;
  578. }
  579. // -----------------------------------------------------------------------
  580. // Callback
  581. void CarlaEngine::callback(const CallbackType action, const unsigned short pluginId, const int value1, const int value2, const double value3)
  582. {
  583. qDebug("CarlaEngine::callback(%s, %i, %i, %i, %f)", CallbackType2str(action), pluginId, value1, value2, value3);
  584. if (m_callback)
  585. m_callback(m_callbackPtr, action, pluginId, value1, value2, value3);
  586. }
  587. void CarlaEngine::setCallback(const CallbackFunc func, void* const ptr)
  588. {
  589. qDebug("CarlaEngine::setCallback(%p, %p)", func, ptr);
  590. CARLA_ASSERT(func);
  591. m_callback = func;
  592. m_callbackPtr = ptr;
  593. }
  594. // -----------------------------------------------------------------------
  595. // Mutex locks
  596. void CarlaEngine::processLock()
  597. {
  598. m_procLock.lock();
  599. }
  600. void CarlaEngine::processUnlock()
  601. {
  602. m_procLock.unlock();
  603. }
  604. void CarlaEngine::midiLock()
  605. {
  606. m_midiLock.lock();
  607. }
  608. void CarlaEngine::midiUnlock()
  609. {
  610. m_midiLock.unlock();
  611. }
  612. // -----------------------------------------------------------------------
  613. // OSC Stuff
  614. bool CarlaEngine::isOscControlRegisted() const
  615. {
  616. #ifndef BUILD_BRIDGE
  617. return m_osc.isControlRegistered();
  618. #else
  619. return bool(m_oscData);
  620. #endif
  621. }
  622. #ifndef BUILD_BRIDGE
  623. const char* CarlaEngine::getOscServerPathTCP() const
  624. {
  625. return m_osc.getServerPathTCP();
  626. }
  627. const char* CarlaEngine::getOscServerPathUDP() const
  628. {
  629. return m_osc.getServerPathUDP();
  630. }
  631. #else
  632. void CarlaEngine::setOscBridgeData(const CarlaOscData* const oscData)
  633. {
  634. m_oscData = oscData;
  635. }
  636. #endif
  637. // -----------------------------------------------------------------------
  638. // protected calls
  639. void CarlaEngine::bufferSizeChanged(const uint32_t newBufferSize)
  640. {
  641. qDebug("CarlaEngine::bufferSizeChanged(%i)", newBufferSize);
  642. bufferSize = newBufferSize;
  643. for (unsigned short i=0; i < m_maxPluginNumber; i++)
  644. {
  645. if (m_carlaPlugins[i] && m_carlaPlugins[i]->enabled())
  646. m_carlaPlugins[i]->bufferSizeChanged(newBufferSize);
  647. }
  648. }
  649. // -------------------------------------------------------------------------------------------------------------------
  650. // Carla Engine Client
  651. CarlaEngineClient::CarlaEngineClient(const CarlaEngineClientNativeHandle& handle_)
  652. : handle(handle_)
  653. {
  654. qDebug("CarlaEngineClient::CarlaEngineClient()");
  655. CARLA_ASSERT(handle.type != CarlaEngineTypeNull);
  656. m_active = false;
  657. }
  658. CarlaEngineClient::~CarlaEngineClient()
  659. {
  660. qDebug("CarlaEngineClient::~CarlaEngineClient()");
  661. CARLA_ASSERT(! m_active);
  662. #ifndef BUILD_BRIDGE
  663. if (carlaOptions.processMode == PROCESS_MODE_MULTIPLE_CLIENTS)
  664. #endif
  665. {
  666. #ifdef CARLA_ENGINE_JACK
  667. if (handle.jackClient)
  668. jackbridge_client_close(handle.jackClient);
  669. #endif
  670. }
  671. }
  672. void CarlaEngineClient::activate()
  673. {
  674. qDebug("CarlaEngineClient::activate()");
  675. CARLA_ASSERT(! m_active);
  676. #ifndef BUILD_BRIDGE
  677. if (carlaOptions.processMode == PROCESS_MODE_MULTIPLE_CLIENTS)
  678. #endif
  679. {
  680. if (! m_active)
  681. {
  682. #ifdef CARLA_ENGINE_JACK
  683. if (handle.jackClient)
  684. jackbridge_activate(handle.jackClient);
  685. #endif
  686. }
  687. }
  688. m_active = true;
  689. }
  690. void CarlaEngineClient::deactivate()
  691. {
  692. qDebug("CarlaEngineClient::deactivate()");
  693. CARLA_ASSERT(m_active);
  694. #ifndef BUILD_BRIDGE
  695. if (carlaOptions.processMode == PROCESS_MODE_MULTIPLE_CLIENTS)
  696. #endif
  697. {
  698. if (m_active)
  699. {
  700. #ifdef CARLA_ENGINE_JACK
  701. if (handle.jackClient)
  702. jackbridge_deactivate(handle.jackClient);
  703. #endif
  704. }
  705. }
  706. m_active = false;
  707. }
  708. bool CarlaEngineClient::isActive() const
  709. {
  710. qDebug("CarlaEngineClient::isActive()");
  711. return m_active;
  712. }
  713. bool CarlaEngineClient::isOk() const
  714. {
  715. qDebug("CarlaEngineClient::isOk()");
  716. #ifndef BUILD_BRIDGE
  717. if (carlaOptions.processMode != PROCESS_MODE_CONTINUOUS_RACK)
  718. #endif
  719. {
  720. #ifdef CARLA_ENGINE_JACK
  721. if (handle.type == CarlaEngineTypeJack)
  722. return bool(handle.jackClient);
  723. #endif
  724. }
  725. return true;
  726. }
  727. const CarlaEngineBasePort* CarlaEngineClient::addPort(const CarlaEnginePortType portType, const char* const name, const bool isInput)
  728. {
  729. qDebug("CarlaEngineClient::addPort(%i, \"%s\", %s)", portType, name, bool2str(isInput));
  730. CarlaEnginePortNativeHandle portHandle;
  731. #ifdef CARLA_ENGINE_JACK
  732. portHandle.jackClient = handle.jackClient;
  733. #endif
  734. #ifndef BUILD_BRIDGE
  735. if (carlaOptions.processMode != PROCESS_MODE_CONTINUOUS_RACK)
  736. #endif
  737. {
  738. #ifdef CARLA_ENGINE_JACK
  739. if (handle.type == CarlaEngineTypeJack)
  740. {
  741. switch (portType)
  742. {
  743. case CarlaEnginePortTypeAudio:
  744. portHandle.jackPort = jackbridge_port_register(handle.jackClient, name, JACK_DEFAULT_AUDIO_TYPE, isInput ? JackPortIsInput : JackPortIsOutput, 0);
  745. break;
  746. case CarlaEnginePortTypeControl:
  747. case CarlaEnginePortTypeMIDI:
  748. portHandle.jackPort = jackbridge_port_register(handle.jackClient, name, JACK_DEFAULT_MIDI_TYPE, isInput ? JackPortIsInput : JackPortIsOutput, 0);
  749. break;
  750. }
  751. }
  752. #endif
  753. }
  754. switch (portType)
  755. {
  756. case CarlaEnginePortTypeAudio:
  757. return new CarlaEngineAudioPort(portHandle, isInput);
  758. case CarlaEnginePortTypeControl:
  759. return new CarlaEngineControlPort(portHandle, isInput);
  760. case CarlaEnginePortTypeMIDI:
  761. return new CarlaEngineMidiPort(portHandle, isInput);
  762. }
  763. qCritical("CarlaEngineClient::addPort(%i, \"%s\", %s) - invalid type", portType, name, bool2str(isInput));
  764. return nullptr;
  765. }
  766. // -------------------------------------------------------------------------------------------------------------------
  767. // Carla Engine Port (Base class)
  768. CarlaEngineBasePort::CarlaEngineBasePort(const CarlaEnginePortNativeHandle& handle_, const bool isInput_)
  769. : isInput(isInput_),
  770. handle(handle_)
  771. {
  772. qDebug("CarlaEngineBasePort::CarlaEngineBasePort(%s)", bool2str(isInput_));
  773. buffer = nullptr;
  774. }
  775. CarlaEngineBasePort::~CarlaEngineBasePort()
  776. {
  777. qDebug("CarlaEngineBasePort::~CarlaEngineBasePort()");
  778. #ifndef BUILD_BRIDGE
  779. if (carlaOptions.processMode == PROCESS_MODE_CONTINUOUS_RACK)
  780. return;
  781. #endif
  782. #ifdef CARLA_ENGINE_JACK
  783. if (handle.jackClient && handle.jackPort)
  784. jackbridge_port_unregister(handle.jackClient, handle.jackPort);
  785. #endif
  786. }
  787. // -------------------------------------------------------------------------------------------------------------------
  788. // Carla Engine Port (Audio)
  789. CarlaEngineAudioPort::CarlaEngineAudioPort(const CarlaEnginePortNativeHandle& handle, const bool isInput)
  790. : CarlaEngineBasePort(handle, isInput)
  791. {
  792. qDebug("CarlaEngineAudioPort::CarlaEngineAudioPort(%s)", bool2str(isInput));
  793. }
  794. void CarlaEngineAudioPort::initBuffer(CarlaEngine* const /*engine*/)
  795. {
  796. }
  797. #ifdef CARLA_ENGINE_JACK
  798. float* CarlaEngineAudioPort::getJackAudioBuffer(uint32_t nframes)
  799. {
  800. # ifndef BUILD_BRIDGE
  801. if (carlaOptions.processMode == PROCESS_MODE_CONTINUOUS_RACK)
  802. return nullptr;
  803. # endif
  804. CARLA_ASSERT(handle.jackPort);
  805. return (float*)jackbridge_port_get_buffer(handle.jackPort, nframes);
  806. }
  807. #endif
  808. // -------------------------------------------------------------------------------------------------------------------
  809. // Carla Engine Port (Control)
  810. CarlaEngineControlPort::CarlaEngineControlPort(const CarlaEnginePortNativeHandle& handle, const bool isInput)
  811. : CarlaEngineBasePort(handle, isInput)
  812. {
  813. qDebug("CarlaEngineControlPort::CarlaEngineControlPort(%s)", bool2str(isInput));
  814. }
  815. void CarlaEngineControlPort::initBuffer(CarlaEngine* const engine)
  816. {
  817. CARLA_ASSERT(engine);
  818. #ifndef BUILD_BRIDGE
  819. if (carlaOptions.processMode == PROCESS_MODE_CONTINUOUS_RACK)
  820. {
  821. buffer = isInput ? engine->rackControlEventsIn : engine->rackControlEventsOut;
  822. return;
  823. }
  824. #endif
  825. #ifdef CARLA_ENGINE_JACK
  826. if (handle.jackPort)
  827. {
  828. buffer = jackbridge_port_get_buffer(handle.jackPort, engine->getBufferSize());
  829. if (! isInput)
  830. jackbridge_midi_clear_buffer(buffer);
  831. }
  832. #endif
  833. }
  834. uint32_t CarlaEngineControlPort::getEventCount()
  835. {
  836. if (! isInput)
  837. return 0;
  838. CARLA_ASSERT(buffer);
  839. #ifndef BUILD_BRIDGE
  840. if (carlaOptions.processMode == PROCESS_MODE_CONTINUOUS_RACK)
  841. {
  842. uint32_t count = 0;
  843. const CarlaEngineControlEvent* const events = (CarlaEngineControlEvent*)buffer;
  844. for (unsigned short i=0; i < CarlaEngine::MAX_ENGINE_CONTROL_EVENTS; i++)
  845. {
  846. if (events[i].type != CarlaEngineEventNull)
  847. count++;
  848. else
  849. break;
  850. }
  851. return count;
  852. }
  853. #endif
  854. #ifdef CARLA_ENGINE_JACK
  855. if (handle.jackPort)
  856. return jackbridge_midi_get_event_count(buffer);
  857. #endif
  858. return 0;
  859. }
  860. const CarlaEngineControlEvent* CarlaEngineControlPort::getEvent(uint32_t index)
  861. {
  862. if (! isInput)
  863. return nullptr;
  864. CARLA_ASSERT(buffer);
  865. #ifndef BUILD_BRIDGE
  866. CARLA_ASSERT(index < CarlaEngine::MAX_ENGINE_CONTROL_EVENTS);
  867. if (carlaOptions.processMode == PROCESS_MODE_CONTINUOUS_RACK)
  868. {
  869. const CarlaEngineControlEvent* const events = (CarlaEngineControlEvent*)buffer;
  870. if (index < CarlaEngine::MAX_ENGINE_CONTROL_EVENTS)
  871. return &events[index];
  872. return nullptr;
  873. }
  874. #endif
  875. #ifdef CARLA_ENGINE_JACK
  876. if (handle.jackPort)
  877. {
  878. static jackbridge_midi_event_t jackEvent;
  879. static CarlaEngineControlEvent carlaEvent;
  880. if (jackbridge_midi_event_get(&jackEvent, buffer, index) != 0)
  881. return nullptr;
  882. memset(&carlaEvent, 0, sizeof(CarlaEngineControlEvent));
  883. uint8_t midiStatus = jackEvent.buffer[0];
  884. uint8_t midiChannel = midiStatus & 0x0F;
  885. carlaEvent.time = jackEvent.time;
  886. carlaEvent.channel = midiChannel;
  887. if (MIDI_IS_STATUS_CONTROL_CHANGE(midiStatus))
  888. {
  889. uint8_t midiControl = jackEvent.buffer[1];
  890. if (MIDI_IS_CONTROL_BANK_SELECT(midiControl))
  891. {
  892. uint8_t midiBank = jackEvent.buffer[2];
  893. carlaEvent.type = CarlaEngineEventMidiBankChange;
  894. carlaEvent.value = midiBank;
  895. }
  896. else if (midiControl == MIDI_CONTROL_ALL_SOUND_OFF)
  897. {
  898. carlaEvent.type = CarlaEngineEventAllSoundOff;
  899. }
  900. else if (midiControl == MIDI_CONTROL_ALL_NOTES_OFF)
  901. {
  902. carlaEvent.type = CarlaEngineEventAllNotesOff;
  903. }
  904. else
  905. {
  906. uint8_t midiValue = jackEvent.buffer[2];
  907. carlaEvent.type = CarlaEngineEventControlChange;
  908. carlaEvent.controller = midiControl;
  909. carlaEvent.value = double(midiValue)/127;
  910. }
  911. return &carlaEvent;
  912. }
  913. else if (MIDI_IS_STATUS_PROGRAM_CHANGE(midiStatus))
  914. {
  915. uint8_t midiProgram = jackEvent.buffer[1];
  916. carlaEvent.type = CarlaEngineEventMidiProgramChange;
  917. carlaEvent.value = midiProgram;
  918. return &carlaEvent;
  919. }
  920. }
  921. #endif
  922. return nullptr;
  923. }
  924. void CarlaEngineControlPort::writeEvent(CarlaEngineControlEventType type, uint32_t time, uint8_t channel, uint8_t controller, double value)
  925. {
  926. if (isInput)
  927. return;
  928. CARLA_ASSERT(buffer);
  929. CARLA_ASSERT(type != CarlaEngineEventNull);
  930. #ifndef BUILD_BRIDGE
  931. if (carlaOptions.processMode == PROCESS_MODE_CONTINUOUS_RACK)
  932. {
  933. CarlaEngineControlEvent* const events = (CarlaEngineControlEvent*)buffer;
  934. for (unsigned short i=0; i < CarlaEngine::MAX_ENGINE_CONTROL_EVENTS; i++)
  935. {
  936. if (events[i].type == CarlaEngineEventNull)
  937. {
  938. events[i].type = type;
  939. events[i].time = time;
  940. events[i].value = value;
  941. events[i].channel = channel;
  942. events[i].controller = controller;
  943. break;
  944. }
  945. }
  946. return;
  947. }
  948. #endif
  949. #ifdef CARLA_ENGINE_JACK
  950. if (handle.jackPort)
  951. {
  952. if (type == CarlaEngineEventControlChange && MIDI_IS_CONTROL_BANK_SELECT(controller))
  953. type = CarlaEngineEventMidiBankChange;
  954. uint8_t data[4] = { 0 };
  955. switch (type)
  956. {
  957. case CarlaEngineEventNull:
  958. break;
  959. case CarlaEngineEventControlChange:
  960. data[0] = MIDI_STATUS_CONTROL_CHANGE + channel;
  961. data[1] = controller;
  962. data[2] = value * 127;
  963. jackbridge_midi_event_write(buffer, time, data, 3);
  964. break;
  965. case CarlaEngineEventMidiBankChange:
  966. data[0] = MIDI_STATUS_CONTROL_CHANGE + channel;
  967. data[1] = MIDI_CONTROL_BANK_SELECT;
  968. data[2] = value;
  969. jackbridge_midi_event_write(buffer, time, data, 3);
  970. break;
  971. case CarlaEngineEventMidiProgramChange:
  972. data[0] = MIDI_STATUS_PROGRAM_CHANGE + channel;
  973. data[1] = value;
  974. jackbridge_midi_event_write(buffer, time, data, 2);
  975. break;
  976. case CarlaEngineEventAllSoundOff:
  977. data[0] = MIDI_STATUS_CONTROL_CHANGE + channel;
  978. data[1] = MIDI_CONTROL_ALL_SOUND_OFF;
  979. jackbridge_midi_event_write(buffer, time, data, 2);
  980. break;
  981. case CarlaEngineEventAllNotesOff:
  982. data[0] = MIDI_STATUS_CONTROL_CHANGE + channel;
  983. data[1] = MIDI_CONTROL_ALL_NOTES_OFF;
  984. jackbridge_midi_event_write(buffer, time, data, 2);
  985. break;
  986. }
  987. }
  988. #endif
  989. }
  990. // -------------------------------------------------------------------------------------------------------------------
  991. // Carla Engine Port (MIDI)
  992. CarlaEngineMidiPort::CarlaEngineMidiPort(const CarlaEnginePortNativeHandle& handle, const bool isInput)
  993. : CarlaEngineBasePort(handle, isInput)
  994. {
  995. qDebug("CarlaEngineMidiPort::CarlaEngineMidiPort(%s)", bool2str(isInput));
  996. }
  997. void CarlaEngineMidiPort::initBuffer(CarlaEngine* const engine)
  998. {
  999. CARLA_ASSERT(engine);
  1000. #ifndef BUILD_BRIDGE
  1001. if (carlaOptions.processMode == PROCESS_MODE_CONTINUOUS_RACK)
  1002. {
  1003. buffer = isInput ? engine->rackMidiEventsIn : engine->rackMidiEventsOut;
  1004. return;
  1005. }
  1006. #endif
  1007. #ifdef CARLA_ENGINE_JACK
  1008. if (handle.jackPort)
  1009. {
  1010. buffer = jackbridge_port_get_buffer(handle.jackPort, engine->getBufferSize());
  1011. if (! isInput)
  1012. jackbridge_midi_clear_buffer(buffer);
  1013. }
  1014. #endif
  1015. }
  1016. uint32_t CarlaEngineMidiPort::getEventCount()
  1017. {
  1018. if (! isInput)
  1019. return 0;
  1020. CARLA_ASSERT(buffer);
  1021. #ifndef BUILD_BRIDGE
  1022. if (carlaOptions.processMode == PROCESS_MODE_CONTINUOUS_RACK)
  1023. {
  1024. uint32_t count = 0;
  1025. const CarlaEngineMidiEvent* const events = (CarlaEngineMidiEvent*)buffer;
  1026. for (unsigned short i=0; i < CarlaEngine::MAX_ENGINE_MIDI_EVENTS; i++)
  1027. {
  1028. if (events[i].size > 0)
  1029. count++;
  1030. else
  1031. break;
  1032. }
  1033. return count;
  1034. }
  1035. #endif
  1036. #ifdef CARLA_ENGINE_JACK
  1037. if (handle.jackPort)
  1038. return jackbridge_midi_get_event_count(buffer);
  1039. #endif
  1040. return 0;
  1041. }
  1042. const CarlaEngineMidiEvent* CarlaEngineMidiPort::getEvent(uint32_t index)
  1043. {
  1044. if (! isInput)
  1045. return nullptr;
  1046. CARLA_ASSERT(buffer);
  1047. #ifndef BUILD_BRIDGE
  1048. CARLA_ASSERT(index < CarlaEngine::MAX_ENGINE_MIDI_EVENTS);
  1049. if (carlaOptions.processMode == PROCESS_MODE_CONTINUOUS_RACK)
  1050. {
  1051. const CarlaEngineMidiEvent* const events = (CarlaEngineMidiEvent*)buffer;
  1052. if (index < CarlaEngine::MAX_ENGINE_MIDI_EVENTS)
  1053. return &events[index];
  1054. return nullptr;
  1055. }
  1056. #endif
  1057. #ifdef CARLA_ENGINE_JACK
  1058. if (handle.jackPort)
  1059. {
  1060. static jackbridge_midi_event_t jackEvent;
  1061. static CarlaEngineMidiEvent carlaEvent;
  1062. if (jackbridge_midi_event_get(&jackEvent, buffer, index) == 0 && jackEvent.size <= 4)
  1063. {
  1064. carlaEvent.time = jackEvent.time;
  1065. carlaEvent.size = jackEvent.size;
  1066. memcpy(carlaEvent.data, jackEvent.buffer, jackEvent.size);
  1067. return &carlaEvent;
  1068. }
  1069. }
  1070. #endif
  1071. return nullptr;
  1072. }
  1073. void CarlaEngineMidiPort::writeEvent(uint32_t time, const uint8_t* data, uint8_t size)
  1074. {
  1075. if (isInput)
  1076. return;
  1077. CARLA_ASSERT(buffer);
  1078. CARLA_ASSERT(data);
  1079. CARLA_ASSERT(size > 0);
  1080. #ifndef BUILD_BRIDGE
  1081. if (carlaOptions.processMode == PROCESS_MODE_CONTINUOUS_RACK)
  1082. {
  1083. if (size > 4)
  1084. return;
  1085. CarlaEngineMidiEvent* const events = (CarlaEngineMidiEvent*)buffer;
  1086. for (unsigned short i=0; i < CarlaEngine::MAX_ENGINE_MIDI_EVENTS; i++)
  1087. {
  1088. if (events[i].size == 0)
  1089. {
  1090. events[i].time = time;
  1091. events[i].size = size;
  1092. memcpy(events[i].data, data, size);
  1093. break;
  1094. }
  1095. }
  1096. return;
  1097. }
  1098. #endif
  1099. #ifdef CARLA_ENGINE_JACK
  1100. if (handle.jackPort)
  1101. jackbridge_midi_event_write(buffer, time, data, size);
  1102. #endif
  1103. }
  1104. // -------------------------------------------------------------------------------------------------------------------
  1105. // Carla Engine OSC stuff
  1106. #ifndef BUILD_BRIDGE
  1107. void CarlaEngine::osc_send_control_add_plugin_start(const int32_t pluginId, const char* const pluginName)
  1108. {
  1109. qDebug("CarlaEngine::osc_send_control_add_plugin_start(%i, \"%s\")", pluginId, pluginName);
  1110. CARLA_ASSERT(m_oscData);
  1111. CARLA_ASSERT(pluginId >= 0 && pluginId < m_maxPluginNumber);
  1112. CARLA_ASSERT(pluginName);
  1113. if (m_oscData && m_oscData->target)
  1114. {
  1115. char target_path[strlen(m_oscData->path)+18];
  1116. strcpy(target_path, m_oscData->path);
  1117. strcat(target_path, "/add_plugin_start");
  1118. lo_send(m_oscData->target, target_path, "is", pluginId, pluginName);
  1119. }
  1120. }
  1121. void CarlaEngine::osc_send_control_add_plugin_end(const int32_t pluginId)
  1122. {
  1123. qDebug("CarlaEngine::osc_send_control_add_plugin_end(%i)", pluginId);
  1124. CARLA_ASSERT(m_oscData);
  1125. CARLA_ASSERT(pluginId >= 0 && pluginId < m_maxPluginNumber);
  1126. if (m_oscData && m_oscData->target)
  1127. {
  1128. char target_path[strlen(m_oscData->path)+16];
  1129. strcpy(target_path, m_oscData->path);
  1130. strcat(target_path, "/add_plugin_end");
  1131. lo_send(m_oscData->target, target_path, "i", pluginId);
  1132. }
  1133. }
  1134. void CarlaEngine::osc_send_control_remove_plugin(const int32_t pluginId)
  1135. {
  1136. qDebug("CarlaEngine::osc_send_control_remove_plugin(%i)", pluginId);
  1137. CARLA_ASSERT(m_oscData);
  1138. CARLA_ASSERT(pluginId >= 0 && pluginId < m_maxPluginNumber);
  1139. if (m_oscData && m_oscData->target)
  1140. {
  1141. char target_path[strlen(m_oscData->path)+15];
  1142. strcpy(target_path, m_oscData->path);
  1143. strcat(target_path, "/remove_plugin");
  1144. lo_send(m_oscData->target, target_path, "i", pluginId);
  1145. }
  1146. }
  1147. 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)
  1148. {
  1149. 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);
  1150. CARLA_ASSERT(m_oscData);
  1151. CARLA_ASSERT(pluginId >= 0 && pluginId < m_maxPluginNumber);
  1152. CARLA_ASSERT(type != PLUGIN_NONE);
  1153. if (m_oscData && m_oscData->target)
  1154. {
  1155. char target_path[strlen(m_oscData->path)+17];
  1156. strcpy(target_path, m_oscData->path);
  1157. strcat(target_path, "/set_plugin_data");
  1158. lo_send(m_oscData->target, target_path, "iiiissssh", pluginId, type, category, hints, realName, label, maker, copyright, uniqueId);
  1159. }
  1160. }
  1161. 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)
  1162. {
  1163. qDebug("CarlaEngine::osc_send_control_set_plugin_ports(%i, %i, %i, %i, %i, %i, %i, %i)", pluginId, audioIns, audioOuts, midiIns, midiOuts, cIns, cOuts, cTotals);
  1164. CARLA_ASSERT(m_oscData);
  1165. CARLA_ASSERT(pluginId >= 0 && pluginId < m_maxPluginNumber);
  1166. if (m_oscData && m_oscData->target)
  1167. {
  1168. char target_path[strlen(m_oscData->path)+18];
  1169. strcpy(target_path, m_oscData->path);
  1170. strcat(target_path, "/set_plugin_ports");
  1171. lo_send(m_oscData->target, target_path, "iiiiiiii", pluginId, audioIns, audioOuts, midiIns, midiOuts, cIns, cOuts, cTotals);
  1172. }
  1173. }
  1174. 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)
  1175. {
  1176. qDebug("CarlaEngine::osc_send_control_set_parameter_data(%i, %i, %i, %i, \"%s\", \"%s\", %g)", pluginId, index, type, hints, name, label, current);
  1177. CARLA_ASSERT(m_oscData);
  1178. CARLA_ASSERT(pluginId >= 0 && pluginId < m_maxPluginNumber);
  1179. CARLA_ASSERT(index >= 0);
  1180. CARLA_ASSERT(type != PARAMETER_UNKNOWN);
  1181. if (m_oscData && m_oscData->target)
  1182. {
  1183. char target_path[strlen(m_oscData->path)+20];
  1184. strcpy(target_path, m_oscData->path);
  1185. strcat(target_path, "/set_parameter_data");
  1186. lo_send(m_oscData->target, target_path, "iiiissd", pluginId, index, type, hints, name, label, current);
  1187. }
  1188. }
  1189. 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)
  1190. {
  1191. qDebug("CarlaEngine::osc_send_control_set_parameter_ranges(%i, %i, %g, %g, %g, %g, %g, %g)", pluginId, index, min, max, def, step, stepSmall, stepLarge);
  1192. CARLA_ASSERT(m_oscData);
  1193. CARLA_ASSERT(pluginId >= 0 && pluginId < m_maxPluginNumber);
  1194. CARLA_ASSERT(index >= 0);
  1195. CARLA_ASSERT(min < max);
  1196. if (m_oscData && m_oscData->target)
  1197. {
  1198. char target_path[strlen(m_oscData->path)+22];
  1199. strcpy(target_path, m_oscData->path);
  1200. strcat(target_path, "/set_parameter_ranges");
  1201. lo_send(m_oscData->target, target_path, "iidddddd", pluginId, index, min, max, def, step, stepSmall, stepLarge);
  1202. }
  1203. }
  1204. void CarlaEngine::osc_send_control_set_parameter_midi_cc(const int32_t pluginId, const int32_t index, const int32_t cc)
  1205. {
  1206. qDebug("CarlaEngine::osc_send_control_set_parameter_midi_cc(%i, %i, %i)", pluginId, index, cc);
  1207. CARLA_ASSERT(m_oscData);
  1208. CARLA_ASSERT(pluginId >= 0 && pluginId < m_maxPluginNumber);
  1209. CARLA_ASSERT(index >= 0);
  1210. if (m_oscData && m_oscData->target)
  1211. {
  1212. char target_path[strlen(m_oscData->path)+23];
  1213. strcpy(target_path, m_oscData->path);
  1214. strcat(target_path, "/set_parameter_midi_cc");
  1215. lo_send(m_oscData->target, target_path, "iii", pluginId, index, cc);
  1216. }
  1217. }
  1218. void CarlaEngine::osc_send_control_set_parameter_midi_channel(const int32_t pluginId, const int32_t index, const int32_t channel)
  1219. {
  1220. qDebug("CarlaEngine::osc_send_control_set_parameter_midi_channel(%i, %i, %i)", pluginId, index, channel);
  1221. CARLA_ASSERT(m_oscData);
  1222. CARLA_ASSERT(pluginId >= 0 && pluginId < m_maxPluginNumber);
  1223. CARLA_ASSERT(index >= 0);
  1224. CARLA_ASSERT(channel >= 0 && channel < 16);
  1225. if (m_oscData && m_oscData->target)
  1226. {
  1227. char target_path[strlen(m_oscData->path)+28];
  1228. strcpy(target_path, m_oscData->path);
  1229. strcat(target_path, "/set_parameter_midi_channel");
  1230. lo_send(m_oscData->target, target_path, "iii", pluginId, index, channel);
  1231. }
  1232. }
  1233. void CarlaEngine::osc_send_control_set_parameter_value(const int32_t pluginId, const int32_t index, const double value)
  1234. {
  1235. #if DEBUG
  1236. if (index < -1)
  1237. qDebug("CarlaEngine::osc_send_control_set_parameter_value(%i, %s, %g)", pluginId, InternalParametersIndex2str((InternalParametersIndex)index), value);
  1238. else
  1239. qDebug("CarlaEngine::osc_send_control_set_parameter_value(%i, %i, %g)", pluginId, index, value);
  1240. #endif
  1241. CARLA_ASSERT(m_oscData);
  1242. CARLA_ASSERT(pluginId >= 0 && pluginId < m_maxPluginNumber);
  1243. if (m_oscData && m_oscData->target)
  1244. {
  1245. char target_path[strlen(m_oscData->path)+21];
  1246. strcpy(target_path, m_oscData->path);
  1247. strcat(target_path, "/set_parameter_value");
  1248. lo_send(m_oscData->target, target_path, "iid", pluginId, index, value);
  1249. }
  1250. }
  1251. void CarlaEngine::osc_send_control_set_default_value(const int32_t pluginId, const int32_t index, const double value)
  1252. {
  1253. qDebug("CarlaEngine::osc_send_control_set_default_value(%i, %i, %g)", pluginId, index, value);
  1254. CARLA_ASSERT(m_oscData);
  1255. CARLA_ASSERT(pluginId >= 0 && pluginId < m_maxPluginNumber);
  1256. CARLA_ASSERT(index >= 0);
  1257. if (m_oscData && m_oscData->target)
  1258. {
  1259. char target_path[strlen(m_oscData->path)+19];
  1260. strcpy(target_path, m_oscData->path);
  1261. strcat(target_path, "/set_default_value");
  1262. lo_send(m_oscData->target, target_path, "iid", pluginId, index, value);
  1263. }
  1264. }
  1265. void CarlaEngine::osc_send_control_set_program(const int32_t pluginId, const int32_t index)
  1266. {
  1267. qDebug("CarlaEngine::osc_send_control_set_program(%i, %i)", pluginId, index);
  1268. CARLA_ASSERT(m_oscData);
  1269. CARLA_ASSERT(pluginId >= 0 && pluginId < m_maxPluginNumber);
  1270. if (m_oscData && m_oscData->target)
  1271. {
  1272. char target_path[strlen(m_oscData->path)+13];
  1273. strcpy(target_path, m_oscData->path);
  1274. strcat(target_path, "/set_program");
  1275. lo_send(m_oscData->target, target_path, "ii", pluginId, index);
  1276. }
  1277. }
  1278. void CarlaEngine::osc_send_control_set_program_count(const int32_t pluginId, const int32_t count)
  1279. {
  1280. qDebug("CarlaEngine::osc_send_control_set_program_count(%i, %i)", pluginId, count);
  1281. CARLA_ASSERT(m_oscData);
  1282. CARLA_ASSERT(pluginId >= 0 && pluginId < m_maxPluginNumber);
  1283. CARLA_ASSERT(count >= 0);
  1284. if (m_oscData && m_oscData->target)
  1285. {
  1286. char target_path[strlen(m_oscData->path)+19];
  1287. strcpy(target_path, m_oscData->path);
  1288. strcat(target_path, "/set_program_count");
  1289. lo_send(m_oscData->target, target_path, "ii", pluginId, count);
  1290. }
  1291. }
  1292. void CarlaEngine::osc_send_control_set_program_name(const int32_t pluginId, const int32_t index, const char* const name)
  1293. {
  1294. qDebug("CarlaEngine::osc_send_control_set_program_name(%i, %i, \"%s\")", pluginId, index, name);
  1295. CARLA_ASSERT(m_oscData);
  1296. CARLA_ASSERT(pluginId >= 0 && pluginId < m_maxPluginNumber);
  1297. CARLA_ASSERT(index >= 0);
  1298. CARLA_ASSERT(name);
  1299. if (m_oscData && m_oscData->target)
  1300. {
  1301. char target_path[strlen(m_oscData->path)+18];
  1302. strcpy(target_path, m_oscData->path);
  1303. strcat(target_path, "/set_program_name");
  1304. lo_send(m_oscData->target, target_path, "iis", pluginId, index, name);
  1305. }
  1306. }
  1307. void CarlaEngine::osc_send_control_set_midi_program(const int32_t pluginId, const int32_t index)
  1308. {
  1309. qDebug("CarlaEngine::osc_send_control_set_midi_program(%i, %i)", pluginId, index);
  1310. CARLA_ASSERT(m_oscData);
  1311. CARLA_ASSERT(pluginId >= 0 && pluginId < m_maxPluginNumber);
  1312. if (m_oscData && m_oscData->target)
  1313. {
  1314. char target_path[strlen(m_oscData->path)+18];
  1315. strcpy(target_path, m_oscData->path);
  1316. strcat(target_path, "/set_midi_program");
  1317. lo_send(m_oscData->target, target_path, "ii", pluginId, index);
  1318. }
  1319. }
  1320. void CarlaEngine::osc_send_control_set_midi_program_count(const int32_t pluginId, const int32_t count)
  1321. {
  1322. qDebug("CarlaEngine::osc_send_control_set_midi_program_count(%i, %i)", pluginId, count);
  1323. CARLA_ASSERT(m_oscData);
  1324. CARLA_ASSERT(pluginId >= 0 && pluginId < m_maxPluginNumber);
  1325. CARLA_ASSERT(count >= 0);
  1326. if (m_oscData && m_oscData->target)
  1327. {
  1328. char target_path[strlen(m_oscData->path)+24];
  1329. strcpy(target_path, m_oscData->path);
  1330. strcat(target_path, "/set_midi_program_count");
  1331. lo_send(m_oscData->target, target_path, "ii", pluginId, count);
  1332. }
  1333. }
  1334. 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)
  1335. {
  1336. qDebug("CarlaEngine::osc_send_control_set_midi_program_data(%i, %i, %i, %i, \"%s\")", pluginId, index, bank, program, name);
  1337. CARLA_ASSERT(m_oscData);
  1338. CARLA_ASSERT(pluginId >= 0 && pluginId < m_maxPluginNumber);
  1339. CARLA_ASSERT(index >= 0);
  1340. CARLA_ASSERT(bank >= 0);
  1341. CARLA_ASSERT(program >= 0);
  1342. CARLA_ASSERT(name);
  1343. if (m_oscData && m_oscData->target)
  1344. {
  1345. char target_path[strlen(m_oscData->path)+23];
  1346. strcpy(target_path, m_oscData->path);
  1347. strcat(target_path, "/set_midi_program_data");
  1348. lo_send(m_oscData->target, target_path, "iiiis", pluginId, index, bank, program, name);
  1349. }
  1350. }
  1351. void CarlaEngine::osc_send_control_note_on(const int32_t pluginId, const int32_t channel, const int32_t note, const int32_t velo)
  1352. {
  1353. qDebug("CarlaEngine::osc_send_control_note_on(%i, %i, %i, %i)", pluginId, channel, note, velo);
  1354. CARLA_ASSERT(m_oscData);
  1355. CARLA_ASSERT(pluginId >= 0 && pluginId < m_maxPluginNumber);
  1356. CARLA_ASSERT(channel >= 0 && channel < 16);
  1357. CARLA_ASSERT(note >= 0 && note < 128);
  1358. CARLA_ASSERT(velo > 0 && velo < 128);
  1359. if (m_oscData && m_oscData->target)
  1360. {
  1361. char target_path[strlen(m_oscData->path)+9];
  1362. strcpy(target_path, m_oscData->path);
  1363. strcat(target_path, "/note_on");
  1364. lo_send(m_oscData->target, target_path, "iiii", pluginId, channel, note, velo);
  1365. }
  1366. }
  1367. void CarlaEngine::osc_send_control_note_off(const int32_t pluginId, const int32_t channel, const int32_t note)
  1368. {
  1369. qDebug("CarlaEngine::osc_send_control_note_off(%i, %i, %i)", pluginId, channel, note);
  1370. CARLA_ASSERT(m_oscData);
  1371. CARLA_ASSERT(pluginId >= 0 && pluginId < m_maxPluginNumber);
  1372. CARLA_ASSERT(channel >= 0 && channel < 16);
  1373. CARLA_ASSERT(note >= 0 && note < 128);
  1374. if (m_oscData && m_oscData->target)
  1375. {
  1376. char target_path[strlen(m_oscData->path)+10];
  1377. strcpy(target_path, m_oscData->path);
  1378. strcat(target_path, "/note_off");
  1379. lo_send(m_oscData->target, target_path, "iii", pluginId, channel, note);
  1380. }
  1381. }
  1382. void CarlaEngine::osc_send_control_set_input_peak_value(const int32_t pluginId, const int32_t portId, const double value)
  1383. {
  1384. //qDebug("CarlaEngine::osc_send_control_set_input_peak_value(%i, %i, %g)", pluginId, portId, value);
  1385. CARLA_ASSERT(m_oscData);
  1386. CARLA_ASSERT(pluginId >= 0 && pluginId < m_maxPluginNumber);
  1387. CARLA_ASSERT(portId == 1 || portId == 2);
  1388. if (m_oscData && m_oscData->target)
  1389. {
  1390. char target_path[strlen(m_oscData->path)+22];
  1391. strcpy(target_path, m_oscData->path);
  1392. strcat(target_path, "/set_input_peak_value");
  1393. lo_send(m_oscData->target, target_path, "iid", pluginId, portId, value);
  1394. }
  1395. }
  1396. void CarlaEngine::osc_send_control_set_output_peak_value(const int32_t pluginId, const int32_t portId, const double value)
  1397. {
  1398. //qDebug("CarlaEngine::osc_send_control_set_output_peak_value(%i, %i, %g)", pluginId, portId, value);
  1399. CARLA_ASSERT(m_oscData);
  1400. CARLA_ASSERT(pluginId >= 0 && pluginId < m_maxPluginNumber);
  1401. CARLA_ASSERT(portId == 1 || portId == 2);
  1402. if (m_oscData && m_oscData->target)
  1403. {
  1404. char target_path[strlen(m_oscData->path)+23];
  1405. strcpy(target_path, m_oscData->path);
  1406. strcat(target_path, "/set_output_peak_value");
  1407. lo_send(m_oscData->target, target_path, "iid", pluginId, portId, value);
  1408. }
  1409. }
  1410. void CarlaEngine::osc_send_control_exit()
  1411. {
  1412. qDebug("CarlaEngine::osc_send_control_exit()");
  1413. CARLA_ASSERT(m_oscData);
  1414. if (m_oscData && m_oscData->target)
  1415. {
  1416. char target_path[strlen(m_oscData->path)+6];
  1417. strcpy(target_path, m_oscData->path);
  1418. strcat(target_path, "/exit");
  1419. lo_send(m_oscData->target, target_path, "");
  1420. }
  1421. }
  1422. #else
  1423. void CarlaEngine::osc_send_bridge_audio_count(const int32_t ins, const int32_t outs, const int32_t total)
  1424. {
  1425. qDebug("CarlaEngine::osc_send_bridge_audio_count(%i, %i, %i)", ins, outs, total);
  1426. CARLA_ASSERT(m_oscData);
  1427. CARLA_ASSERT(total >= 0 && total >= ins + outs);
  1428. if (m_oscData && m_oscData->target)
  1429. {
  1430. char target_path[strlen(m_oscData->path)+20];
  1431. strcpy(target_path, m_oscData->path);
  1432. strcat(target_path, "/bridge_audio_count");
  1433. lo_send(m_oscData->target, target_path, "iii", ins, outs, total);
  1434. }
  1435. }
  1436. void CarlaEngine::osc_send_bridge_midi_count(const int32_t ins, const int32_t outs, const int32_t total)
  1437. {
  1438. qDebug("CarlaEngine::osc_send_bridge_midi_count(%i, %i, %i)", ins, outs, total);
  1439. CARLA_ASSERT(m_oscData);
  1440. CARLA_ASSERT(total >= 0 && total >= ins + outs);
  1441. if (m_oscData && m_oscData->target)
  1442. {
  1443. char target_path[strlen(m_oscData->path)+19];
  1444. strcpy(target_path, m_oscData->path);
  1445. strcat(target_path, "/bridge_midi_count");
  1446. lo_send(m_oscData->target, target_path, "iii", ins, outs, total);
  1447. }
  1448. }
  1449. void CarlaEngine::osc_send_bridge_parameter_count(const int32_t ins, const int32_t outs, const int32_t total)
  1450. {
  1451. qDebug("CarlaEngine::osc_send_bridge_parameter_count(%i, %i, %i)", ins, outs, total);
  1452. CARLA_ASSERT(m_oscData);
  1453. CARLA_ASSERT(total >= 0 && total >= ins + outs);
  1454. if (m_oscData && m_oscData->target)
  1455. {
  1456. char target_path[strlen(m_oscData->path)+24];
  1457. strcpy(target_path, m_oscData->path);
  1458. strcat(target_path, "/bridge_parameter_count");
  1459. lo_send(m_oscData->target, target_path, "iii", ins, outs, total);
  1460. }
  1461. }
  1462. void CarlaEngine::osc_send_bridge_program_count(const int32_t count)
  1463. {
  1464. qDebug("CarlaEngine::osc_send_bridge_program_count(%i)", count);
  1465. CARLA_ASSERT(m_oscData);
  1466. CARLA_ASSERT(count >= 0);
  1467. if (m_oscData && m_oscData->target)
  1468. {
  1469. char target_path[strlen(m_oscData->path)+22];
  1470. strcpy(target_path, m_oscData->path);
  1471. strcat(target_path, "/bridge_program_count");
  1472. lo_send(m_oscData->target, target_path, "i", count);
  1473. }
  1474. }
  1475. void CarlaEngine::osc_send_bridge_midi_program_count(const int32_t count)
  1476. {
  1477. qDebug("CarlaEngine::osc_send_bridge_midi_program_count(%i)", count);
  1478. CARLA_ASSERT(m_oscData);
  1479. CARLA_ASSERT(count >= 0);
  1480. if (m_oscData && m_oscData->target)
  1481. {
  1482. char target_path[strlen(m_oscData->path)+27];
  1483. strcpy(target_path, m_oscData->path);
  1484. strcat(target_path, "/bridge_midi_program_count");
  1485. lo_send(m_oscData->target, target_path, "i", count);
  1486. }
  1487. }
  1488. 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)
  1489. {
  1490. qDebug("CarlaEngine::osc_send_bridge_plugin_info(%i, %i, \"%s\", \"%s\", \"%s\", \"%s\", " P_INT64 ")", category, hints, name, label, maker, copyright, uniqueId);
  1491. CARLA_ASSERT(m_oscData);
  1492. CARLA_ASSERT(name);
  1493. CARLA_ASSERT(label);
  1494. CARLA_ASSERT(maker);
  1495. CARLA_ASSERT(copyright);
  1496. if (m_oscData && m_oscData->target)
  1497. {
  1498. char target_path[strlen(m_oscData->path)+20];
  1499. strcpy(target_path, m_oscData->path);
  1500. strcat(target_path, "/bridge_plugin_info");
  1501. lo_send(m_oscData->target, target_path, "iissssh", category, hints, name, label, maker, copyright, uniqueId);
  1502. }
  1503. }
  1504. void CarlaEngine::osc_send_bridge_parameter_info(const int32_t index, const char* const name, const char* const unit)
  1505. {
  1506. qDebug("CarlaEngine::osc_send_bridge_parameter_info(%i, \"%s\", \"%s\")", index, name, unit);
  1507. CARLA_ASSERT(m_oscData);
  1508. CARLA_ASSERT(name);
  1509. CARLA_ASSERT(unit);
  1510. if (m_oscData && m_oscData->target)
  1511. {
  1512. char target_path[strlen(m_oscData->path)+23];
  1513. strcpy(target_path, m_oscData->path);
  1514. strcat(target_path, "/bridge_parameter_info");
  1515. lo_send(m_oscData->target, target_path, "iss", index, name, unit);
  1516. }
  1517. }
  1518. 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)
  1519. {
  1520. qDebug("CarlaEngine::osc_send_bridge_parameter_data(%i, %i, %i, %i, %i, %i)", index, type, rindex, hints, midiChannel, midiCC);
  1521. CARLA_ASSERT(m_oscData);
  1522. if (m_oscData && m_oscData->target)
  1523. {
  1524. char target_path[strlen(m_oscData->path)+23];
  1525. strcpy(target_path, m_oscData->path);
  1526. strcat(target_path, "/bridge_parameter_data");
  1527. lo_send(m_oscData->target, target_path, "iiiiii", index, type, rindex, hints, midiChannel, midiCC);
  1528. }
  1529. }
  1530. 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)
  1531. {
  1532. qDebug("CarlaEngine::osc_send_bridge_parameter_ranges(%i, %g, %g, %g, %g, %g, %g)", index, def, min, max, step, stepSmall, stepLarge);
  1533. CARLA_ASSERT(m_oscData);
  1534. if (m_oscData && m_oscData->target)
  1535. {
  1536. char target_path[strlen(m_oscData->path)+25];
  1537. strcpy(target_path, m_oscData->path);
  1538. strcat(target_path, "/bridge_parameter_ranges");
  1539. lo_send(m_oscData->target, target_path, "idddddd", index, def, min, max, step, stepSmall, stepLarge);
  1540. }
  1541. }
  1542. void CarlaEngine::osc_send_bridge_program_info(const int32_t index, const char* const name)
  1543. {
  1544. qDebug("CarlaEngine::osc_send_bridge_program_info(%i, \"%s\")", index, name);
  1545. CARLA_ASSERT(m_oscData);
  1546. if (m_oscData && m_oscData->target)
  1547. {
  1548. char target_path[strlen(m_oscData->path)+21];
  1549. strcpy(target_path, m_oscData->path);
  1550. strcat(target_path, "/bridge_program_info");
  1551. lo_send(m_oscData->target, target_path, "is", index, name);
  1552. }
  1553. }
  1554. void CarlaEngine::osc_send_bridge_midi_program_info(const int32_t index, const int32_t bank, const int32_t program, const char* const label)
  1555. {
  1556. qDebug("CarlaEngine::osc_send_bridge_midi_program_info(%i, %i, %i, \"%s\")", index, bank, program, label);
  1557. CARLA_ASSERT(m_oscData);
  1558. if (m_oscData && m_oscData->target)
  1559. {
  1560. char target_path[strlen(m_oscData->path)+26];
  1561. strcpy(target_path, m_oscData->path);
  1562. strcat(target_path, "/bridge_midi_program_info");
  1563. lo_send(m_oscData->target, target_path, "iiis", index, bank, program, label);
  1564. }
  1565. }
  1566. void CarlaEngine::osc_send_bridge_configure(const char* const key, const char* const value)
  1567. {
  1568. qDebug("CarlaEngine::osc_send_bridge_configure(\"%s\", \"%s\")", key, value);
  1569. CARLA_ASSERT(m_oscData);
  1570. CARLA_ASSERT(key);
  1571. CARLA_ASSERT(value);
  1572. if (m_oscData && m_oscData->target)
  1573. {
  1574. char target_path[strlen(m_oscData->path)+18];
  1575. strcpy(target_path, m_oscData->path);
  1576. strcat(target_path, "/bridge_configure");
  1577. lo_send(m_oscData->target, target_path, "ss", key, value);
  1578. }
  1579. }
  1580. void CarlaEngine::osc_send_bridge_set_parameter_value(const int32_t index, const double value)
  1581. {
  1582. qDebug("CarlaEngine::osc_send_bridge_set_parameter_value(%i, %g)", index, value);
  1583. CARLA_ASSERT(m_oscData);
  1584. if (m_oscData && m_oscData->target)
  1585. {
  1586. char target_path[strlen(m_oscData->path)+28];
  1587. strcpy(target_path, m_oscData->path);
  1588. strcat(target_path, "/bridge_set_parameter_value");
  1589. lo_send(m_oscData->target, target_path, "id", index, value);
  1590. }
  1591. }
  1592. void CarlaEngine::osc_send_bridge_set_default_value(const int32_t index, const double value)
  1593. {
  1594. qDebug("CarlaEngine::osc_send_bridge_set_default_value(%i, %g)", index, value);
  1595. CARLA_ASSERT(m_oscData);
  1596. if (m_oscData && m_oscData->target)
  1597. {
  1598. char target_path[strlen(m_oscData->path)+26];
  1599. strcpy(target_path, m_oscData->path);
  1600. strcat(target_path, "/bridge_set_default_value");
  1601. lo_send(m_oscData->target, target_path, "id", index, value);
  1602. }
  1603. }
  1604. void CarlaEngine::osc_send_bridge_set_program(const int32_t index)
  1605. {
  1606. qDebug("CarlaEngine::osc_send_bridge_set_program(%i)", index);
  1607. CARLA_ASSERT(m_oscData);
  1608. if (m_oscData && m_oscData->target)
  1609. {
  1610. char target_path[strlen(m_oscData->path)+20];
  1611. strcpy(target_path, m_oscData->path);
  1612. strcat(target_path, "/bridge_set_program");
  1613. lo_send(m_oscData->target, target_path, "i", index);
  1614. }
  1615. }
  1616. void CarlaEngine::osc_send_bridge_set_midi_program(const int32_t index)
  1617. {
  1618. qDebug("CarlaEngine::osc_send_bridge_set_midi_program(%i)", index);
  1619. CARLA_ASSERT(m_oscData);
  1620. if (m_oscData && m_oscData->target)
  1621. {
  1622. char target_path[strlen(m_oscData->path)+25];
  1623. strcpy(target_path, m_oscData->path);
  1624. strcat(target_path, "/bridge_set_midi_program");
  1625. lo_send(m_oscData->target, target_path, "i", index);
  1626. }
  1627. }
  1628. void CarlaEngine::osc_send_bridge_set_custom_data(const char* const stype, const char* const key, const char* const value)
  1629. {
  1630. qDebug("CarlaEngine::osc_send_bridge_set_custom_data(\"%s\", \"%s\", \"%s\")", stype, key, value);
  1631. CARLA_ASSERT(m_oscData);
  1632. if (m_oscData && m_oscData->target)
  1633. {
  1634. char target_path[strlen(m_oscData->path)+24];
  1635. strcpy(target_path, m_oscData->path);
  1636. strcat(target_path, "/bridge_set_custom_data");
  1637. lo_send(m_oscData->target, target_path, "sss", stype, key, value);
  1638. }
  1639. }
  1640. void CarlaEngine::osc_send_bridge_set_chunk_data(const char* const chunkFile)
  1641. {
  1642. qDebug("CarlaEngine::osc_send_bridge_set_chunk_data(\"%s\")", chunkFile);
  1643. CARLA_ASSERT(m_oscData);
  1644. if (m_oscData && m_oscData->target)
  1645. {
  1646. char target_path[strlen(m_oscData->path)+23];
  1647. strcpy(target_path, m_oscData->path);
  1648. strcat(target_path, "/bridge_set_chunk_data");
  1649. lo_send(m_oscData->target, target_path, "s", chunkFile);
  1650. }
  1651. }
  1652. void CarlaEngine::osc_send_bridge_set_input_peak_value(const int32_t portId, const double value)
  1653. {
  1654. CARLA_ASSERT(m_oscData);
  1655. CARLA_ASSERT(portId == 1 || portId == 2);
  1656. if (m_oscData && m_oscData->target)
  1657. {
  1658. char target_path[strlen(m_oscData->path)+28];
  1659. strcpy(target_path, m_oscData->path);
  1660. strcat(target_path, "/bridge_set_input_peak_value");
  1661. lo_send(m_oscData->target, target_path, "id", portId, value);
  1662. }
  1663. }
  1664. void CarlaEngine::osc_send_bridge_set_output_peak_value(const int32_t portId, const double value)
  1665. {
  1666. CARLA_ASSERT(m_oscData);
  1667. CARLA_ASSERT(portId == 1 || portId == 2);
  1668. if (m_oscData && m_oscData->target)
  1669. {
  1670. char target_path[strlen(m_oscData->path)+29];
  1671. strcpy(target_path, m_oscData->path);
  1672. strcat(target_path, "/bridge_set_output_peak_value");
  1673. lo_send(m_oscData->target, target_path, "id", portId, value);
  1674. }
  1675. }
  1676. #endif
  1677. CARLA_BACKEND_END_NAMESPACE