2015-03-03 21:28:07 +01:00
|
|
|
/** @file
|
|
|
|
* @author Edouard DUPIN
|
|
|
|
* @copyright 2015, Edouard DUPIN, all right reserved
|
|
|
|
* @license APACHE v2.0 (see license file)
|
|
|
|
*/
|
|
|
|
|
2015-04-11 09:38:30 +02:00
|
|
|
#include <audio/river/io/Group.h>
|
|
|
|
#include <audio/river/debug.h>
|
2015-03-03 21:28:07 +01:00
|
|
|
#include "Node.h"
|
|
|
|
#include "NodeAEC.h"
|
2015-04-11 09:38:30 +02:00
|
|
|
#include "NodeOrchestra.h"
|
2015-03-03 21:28:07 +01:00
|
|
|
#include "NodePortAudio.h"
|
|
|
|
#include "Node.h"
|
|
|
|
|
|
|
|
#undef __class__
|
|
|
|
#define __class__ "io::Group"
|
|
|
|
|
2015-04-11 09:38:30 +02:00
|
|
|
void audio::river::io::Group::createFrom(const ejson::Document& _obj, const std::string& _name) {
|
2015-03-03 21:28:07 +01:00
|
|
|
RIVER_INFO("Create Group[" << _name << "] (START) ___________________________");
|
|
|
|
for (size_t iii=0; iii<_obj.size(); ++iii) {
|
|
|
|
const std11::shared_ptr<const ejson::Object> tmpObject = _obj.getObject(_obj.getKey(iii));
|
|
|
|
if (tmpObject == nullptr) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
std::string groupName = tmpObject->getStringValue("group", "");
|
|
|
|
if (groupName == _name) {
|
|
|
|
RIVER_INFO("Add element in Group[" << _name << "]: " << _obj.getKey(iii));
|
|
|
|
// get type : io
|
|
|
|
std::string ioType = tmpObject->getStringValue("io", "error");
|
2015-04-11 17:43:09 +02:00
|
|
|
#ifdef AUDIO_RIVER_BUILD_ORCHESTRA
|
2015-03-03 21:28:07 +01:00
|
|
|
if ( ioType == "input"
|
|
|
|
|| ioType == "output") {
|
2015-04-11 09:38:30 +02:00
|
|
|
std11::shared_ptr<audio::river::io::Node> tmp = audio::river::io::NodeOrchestra::create(_obj.getKey(iii), tmpObject);
|
2015-03-03 21:28:07 +01:00
|
|
|
tmp->setGroup(shared_from_this());
|
|
|
|
m_list.push_back(tmp);
|
|
|
|
}
|
|
|
|
#endif
|
2015-04-11 17:43:09 +02:00
|
|
|
#ifdef AUDIO_RIVER_BUILD_PORTAUDIO
|
2015-03-03 21:28:07 +01:00
|
|
|
if ( ioType == "PAinput"
|
|
|
|
|| ioType == "PAoutput") {
|
2015-04-11 09:38:30 +02:00
|
|
|
std11::shared_ptr<audio::river::io::Node> tmp = audio::river::io::NodePortAudio::create(_obj.getKey(iii), tmpObject);
|
2015-03-03 21:28:07 +01:00
|
|
|
tmp->setGroup(shared_from_this());
|
|
|
|
m_list.push_back(tmp);
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// Link all the IO together : (not needed if one device ...
|
|
|
|
// Note : The interlink work only for alsa (NOW) and with AirTAudio...
|
|
|
|
if(m_list.size() > 1) {
|
2015-04-11 17:43:09 +02:00
|
|
|
#ifdef AUDIO_RIVER_BUILD_ORCHESTRA
|
2015-04-11 09:38:30 +02:00
|
|
|
std11::shared_ptr<audio::river::io::NodeOrchestra> linkRef = std11::dynamic_pointer_cast<audio::river::io::NodeOrchestra>(m_list[0]);
|
2015-03-03 21:28:07 +01:00
|
|
|
for (size_t iii=1; iii<m_list.size(); ++iii) {
|
|
|
|
if (m_list[iii] != nullptr) {
|
2015-04-11 09:38:30 +02:00
|
|
|
std11::shared_ptr<audio::river::io::NodeOrchestra> link = std11::dynamic_pointer_cast<audio::river::io::NodeOrchestra>(m_list[iii]);
|
2015-06-14 18:33:24 +02:00
|
|
|
linkRef->m_interface.isMasterOf(link->m_interface);
|
2015-03-03 21:28:07 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
/*
|
|
|
|
// manage Link Between Nodes :
|
|
|
|
if (m_link != nullptr) {
|
|
|
|
RIVER_INFO("******** START LINK ************");
|
2015-04-11 09:38:30 +02:00
|
|
|
std11::shared_ptr<audio::river::io::NodeOrchestra> link = std11::dynamic_pointer_cast<audio::river::io::NodeOrchestra>(m_link);
|
2015-03-03 21:28:07 +01:00
|
|
|
if (link == nullptr) {
|
|
|
|
RIVER_ERROR("Can not link 2 Interface with not the same type (reserved for HW interface)");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
link->m_adac.isMasterOf(m_adac);
|
|
|
|
// TODO : Add return ...
|
|
|
|
RIVER_INFO("******** LINK might be done ************");
|
|
|
|
}
|
|
|
|
*/
|
|
|
|
RIVER_INFO("Create Group[" << _name << "] ( END ) ___________________________");
|
|
|
|
RIVER_INFO("Group[" << _name << "] List elements : ");
|
|
|
|
for (size_t iii=0; iii<m_list.size(); ++iii) {
|
|
|
|
if (m_list[iii] != nullptr) {
|
|
|
|
RIVER_INFO(" " << m_list[iii]->getName());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2015-04-11 09:38:30 +02:00
|
|
|
std11::shared_ptr<audio::river::io::Node> audio::river::io::Group::getNode(const std::string& _name) {
|
2015-03-03 21:28:07 +01:00
|
|
|
for (size_t iii=0; iii<m_list.size(); ++iii) {
|
|
|
|
if (m_list[iii] != nullptr) {
|
|
|
|
if (m_list[iii]->getName() == _name) {
|
|
|
|
return m_list[iii];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2015-04-11 09:38:30 +02:00
|
|
|
return std11::shared_ptr<audio::river::io::Node>();
|
2015-03-03 21:28:07 +01:00
|
|
|
}
|
|
|
|
|
2015-04-11 09:38:30 +02:00
|
|
|
void audio::river::io::Group::start() {
|
2015-03-03 21:28:07 +01:00
|
|
|
RIVER_ERROR("request start ");
|
|
|
|
int32_t count = 0;
|
|
|
|
for (size_t iii=0; iii<m_list.size(); ++iii) {
|
|
|
|
if (m_list[iii] != nullptr) {
|
|
|
|
count += m_list[iii]->getNumberOfInterface();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
RIVER_ERROR(" have " << count << " interfaces ...");
|
|
|
|
if (count == 1) {
|
|
|
|
RIVER_ERROR("GROUP :::::::::::: START() [START]");
|
|
|
|
for (size_t iii=0; iii<m_list.size(); ++iii) {
|
|
|
|
if (m_list[iii] != nullptr) {
|
|
|
|
m_list[iii]->start();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
RIVER_ERROR("GROUP :::::::::::: START() [DONE]");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-04-11 09:38:30 +02:00
|
|
|
void audio::river::io::Group::stop() {
|
2015-03-03 21:28:07 +01:00
|
|
|
RIVER_ERROR("request stop ");
|
|
|
|
int32_t count = 0;
|
|
|
|
for (size_t iii=0; iii<m_list.size(); ++iii) {
|
|
|
|
if (m_list[iii] != nullptr) {
|
|
|
|
count += m_list[iii]->getNumberOfInterface();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
RIVER_ERROR(" have " << count << " interfaces ...");
|
|
|
|
if (count == 0) {
|
|
|
|
RIVER_ERROR("GROUP :::::::::::: STOP() [START]");
|
2015-03-04 22:25:22 +01:00
|
|
|
for (int32_t iii=m_list.size()-1; iii>=0; --iii) {
|
2015-03-03 21:28:07 +01:00
|
|
|
if (m_list[iii] != nullptr) {
|
|
|
|
m_list[iii]->stop();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
RIVER_ERROR("GROUP :::::::::::: STOP() [DONE]");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-04-11 09:38:30 +02:00
|
|
|
void audio::river::io::Group::generateDot(etk::FSNode& _node, bool _hardwareNode) {
|
2015-03-04 22:15:35 +01:00
|
|
|
for (size_t iii=0; iii<m_list.size(); ++iii) {
|
|
|
|
if (m_list[iii] != nullptr) {
|
2015-03-05 21:28:39 +01:00
|
|
|
if (m_list[iii]->isHarwareNode() == _hardwareNode) {
|
|
|
|
m_list[iii]->generateDot(_node);
|
|
|
|
}
|
2015-03-04 22:15:35 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|