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.

1822 lines
54KB

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