[DEV] end corection placeholder

This commit is contained in:
Edouard DUPIN 2015-02-24 23:55:28 +01:00
parent 0b50032cab
commit 94fb75709c
5 changed files with 76 additions and 88 deletions

View File

@ -181,29 +181,21 @@ river::io::NodeAEC::NodeAEC(const std::string& _name, const std11::shared_ptr<co
// set callback mode ... // set callback mode ...
m_interfaceFeedBack->setInputCallback(std11::bind(&river::io::NodeAEC::onDataReceivedFeedBack, m_interfaceFeedBack->setInputCallback(std11::bind(&river::io::NodeAEC::onDataReceivedFeedBack,
this, this,
#if __cplusplus >= 201103L
std11::placeholders::_1, std11::placeholders::_1,
std11::placeholders::_2, std11::placeholders::_2,
std11::placeholders::_3, std11::placeholders::_3,
std11::placeholders::_4, std11::placeholders::_4,
std11::placeholders::_5, std11::placeholders::_5,
std11::placeholders::_6)); std11::placeholders::_6));
#else
_1, _2, _3, _4, _5, _6));
#endif
// set callback mode ... // set callback mode ...
m_interfaceMicrophone->setInputCallback(std11::bind(&river::io::NodeAEC::onDataReceivedMicrophone, m_interfaceMicrophone->setInputCallback(std11::bind(&river::io::NodeAEC::onDataReceivedMicrophone,
this, this,
#if __cplusplus >= 201103L
std11::placeholders::_1, std11::placeholders::_1,
std11::placeholders::_2, std11::placeholders::_2,
std11::placeholders::_3, std11::placeholders::_3,
std11::placeholders::_4, std11::placeholders::_4,
std11::placeholders::_5, std11::placeholders::_5,
std11::placeholders::_6)); std11::placeholders::_6));
#else
_1, _2, _3, _4, _5, _6));
#endif
m_bufferMicrophone.setCapacity(std11::chrono::milliseconds(1000), m_bufferMicrophone.setCapacity(std11::chrono::milliseconds(1000),
audio::getFormatBytes(hardwareFormat.getFormat())*hardwareFormat.getMap().size(), audio::getFormatBytes(hardwareFormat.getFormat())*hardwareFormat.getMap().size(),

View File

@ -220,28 +220,20 @@ river::io::NodeAirTAudio::NodeAirTAudio(const std::string& _name, const std11::s
hardwareFormat.getFormat(), hardwareFormat.getFrequency(), &m_rtaudioFrameSize, hardwareFormat.getFormat(), hardwareFormat.getFrequency(), &m_rtaudioFrameSize,
std11::bind(&river::io::NodeAirTAudio::recordCallback, std11::bind(&river::io::NodeAirTAudio::recordCallback,
this, this,
#if __cplusplus >= 201103L std11::placeholders::_1,
std::placeholders::_1, std11::placeholders::_2,
std::placeholders::_2, std11::placeholders::_5,
std::placeholders::_5, std11::placeholders::_6)
std::placeholders::_6)
#else
_1, _2, _5, _6)
#endif
); );
} else { } else {
err = m_adac.openStream(&params, nullptr, err = m_adac.openStream(&params, nullptr,
hardwareFormat.getFormat(), hardwareFormat.getFrequency(), &m_rtaudioFrameSize, hardwareFormat.getFormat(), hardwareFormat.getFrequency(), &m_rtaudioFrameSize,
std11::bind(&river::io::NodeAirTAudio::playbackCallback, std11::bind(&river::io::NodeAirTAudio::playbackCallback,
this, this,
#if __cplusplus >= 201103L std11::placeholders::_3,
std::placeholders::_3, std11::placeholders::_4,
std::placeholders::_4, std11::placeholders::_5,
std::placeholders::_5, std11::placeholders::_6)
std::placeholders::_6)
#else
_3, _4, _5, _6)
#endif
); );
} }
if (err != airtaudio::error_none) { if (err != airtaudio::error_none) {

View File

@ -4,7 +4,7 @@
* @license APACHE v2.0 (see license file) * @license APACHE v2.0 (see license file)
*/ */
#ifdef __PORTTAUDIO_INFERFACE__ #ifdef __PORTAUDIO_INFERFACE__
#include <river/io/NodePortAudio.h> #include <river/io/NodePortAudio.h>
#include <river/debug.h> #include <river/debug.h>
@ -30,7 +30,7 @@ static std::string asString(const std11::chrono::system_clock::time_point& tp) {
namespace std { namespace std {
static std::ostream& operator <<(std::ostream& _os, const std11::chrono::system_clock::time_point& _obj) { static std::ostream& operator <<(std::ostream& _os, const std11::chrono::system_clock::time_point& _obj) {
std11::chrono::microseconds us = std11::chrono::duration_cast<std::chrono::microseconds>(_obj.time_since_epoch()); std11::chrono::microseconds us = std11::chrono::duration_cast<std11::chrono::microseconds>(_obj.time_since_epoch());
_os << us.count(); _os << us.count();
return _os; return _os;
} }
@ -45,10 +45,10 @@ static int portAudioStreamCallback(const void *_input,
river::io::NodePortAudio* myClass = reinterpret_cast<river::io::NodePortAudio*>(_userData); river::io::NodePortAudio* myClass = reinterpret_cast<river::io::NodePortAudio*>(_userData);
int64_t sec = int64_t(_timeInfo->inputBufferAdcTime); int64_t sec = int64_t(_timeInfo->inputBufferAdcTime);
int64_t nsec = (_timeInfo->inputBufferAdcTime-double(sec))*1000000000LL; int64_t nsec = (_timeInfo->inputBufferAdcTime-double(sec))*1000000000LL;
std11::chrono::system_clock::time_point timeInput = std11::chrono::system_clock::from_time_t(sec) + std::chrono::nanoseconds(nsec); std11::chrono::system_clock::time_point timeInput = std11::chrono::system_clock::from_time_t(sec) + std11::chrono::nanoseconds(nsec);
sec = int64_t(_timeInfo->outputBufferDacTime); sec = int64_t(_timeInfo->outputBufferDacTime);
nsec = (_timeInfo->outputBufferDacTime-double(sec))*1000000000LL; nsec = (_timeInfo->outputBufferDacTime-double(sec))*1000000000LL;
std11::chrono::system_clock::time_point timeOutput = std11::chrono::system_clock::from_time_t(sec) + std::chrono::nanoseconds(nsec); std11::chrono::system_clock::time_point timeOutput = std11::chrono::system_clock::from_time_t(sec) + std11::chrono::nanoseconds(nsec);
return myClass->duplexCallback(_input, return myClass->duplexCallback(_input,
timeInput, timeInput,
_output, _output,

View File

@ -7,7 +7,7 @@
#ifndef __RIVER_IO_NODE_PORTAUDIO_H__ #ifndef __RIVER_IO_NODE_PORTAUDIO_H__
#define __RIVER_IO_NODE_PORTAUDIO_H__ #define __RIVER_IO_NODE_PORTAUDIO_H__
#ifdef __PORTTAUDIO_INFERFACE__ #ifdef __PORTAUDIO_INFERFACE__
#include <river/Interface.h> #include <river/Interface.h>
#include <river/io/Node.h> #include <river/io/Node.h>

View File

@ -12,9 +12,14 @@
#include <math.h> #include <math.h>
#include <sstream> #include <sstream>
#include <thread>
#include <unistd.h> #include <unistd.h>
#if __cplusplus >= 201103L
#include <thread>
#else
#include <etk/thread.h>
#endif
#undef __class__ #undef __class__
#define __class__ "test" #define __class__ "test"
@ -78,13 +83,12 @@ TEST(TestALL, testOutputWrite) {
manager = river::Manager::create("testApplication"); manager = river::Manager::create("testApplication");
APPL_INFO("test output (write mode)"); APPL_INFO("test output (write mode)");
std11::shared_ptr<testOutWrite> process = std::make_shared<testOutWrite>(manager); std11::shared_ptr<testOutWrite> process = std11::make_shared<testOutWrite>(manager);
process->run(); process->run();
process.reset(); process.reset();
usleep(500000); usleep(500000);
} }
class testOutWriteCallback { class testOutWriteCallback {
private: private:
std11::shared_ptr<river::Manager> m_manager; std11::shared_ptr<river::Manager> m_manager;
@ -104,13 +108,13 @@ class testOutWriteCallback {
"speaker", "speaker",
"WriteMode+Callback"); "WriteMode+Callback");
m_interface->setReadwrite(); m_interface->setReadwrite();
m_interface->setWriteCallback(std::bind(&testOutWriteCallback::onDataNeeded, m_interface->setWriteCallback(std11::bind(&testOutWriteCallback::onDataNeeded,
this, this,
std::placeholders::_1, std11::placeholders::_1,
std::placeholders::_2, std11::placeholders::_2,
std::placeholders::_3, std11::placeholders::_3,
std::placeholders::_4, std11::placeholders::_4,
std::placeholders::_5)); std11::placeholders::_5));
} }
void onDataNeeded(const std11::chrono::system_clock::time_point& _time, void onDataNeeded(const std11::chrono::system_clock::time_point& _time,
size_t _nbChunk, size_t _nbChunk,
@ -147,7 +151,7 @@ TEST(TestALL, testOutputWriteWithCallback) {
manager = river::Manager::create("testApplication"); manager = river::Manager::create("testApplication");
APPL_INFO("test output (write with callback event mode)"); APPL_INFO("test output (write with callback event mode)");
std11::shared_ptr<testOutWriteCallback> process = std::make_shared<testOutWriteCallback>(manager); std11::shared_ptr<testOutWriteCallback> process = std11::make_shared<testOutWriteCallback>(manager);
process->run(); process->run();
process.reset(); process.reset();
usleep(500000); usleep(500000);
@ -173,14 +177,14 @@ class testOutCallback {
_io, _io,
"WriteModeCallback"); "WriteModeCallback");
// set callback mode ... // set callback mode ...
m_interface->setOutputCallback(std::bind(&testOutCallback::onDataNeeded, m_interface->setOutputCallback(std11::bind(&testOutCallback::onDataNeeded,
this, this,
std::placeholders::_1, std11::placeholders::_1,
std::placeholders::_2, std11::placeholders::_2,
std::placeholders::_3, std11::placeholders::_3,
std::placeholders::_4, std11::placeholders::_4,
std::placeholders::_5, std11::placeholders::_5,
std::placeholders::_6)); std11::placeholders::_6));
} }
void onDataNeeded(void* _data, void onDataNeeded(void* _data,
const std11::chrono::system_clock::time_point& _time, const std11::chrono::system_clock::time_point& _time,
@ -216,7 +220,7 @@ TEST(TestALL, testOutputCallBack) {
manager = river::Manager::create("testApplication"); manager = river::Manager::create("testApplication");
APPL_INFO("test output (callback mode)"); APPL_INFO("test output (callback mode)");
std11::shared_ptr<testOutCallback> process = std::make_shared<testOutCallback>(manager, "speaker"); std11::shared_ptr<testOutCallback> process = std11::make_shared<testOutCallback>(manager, "speaker");
process->run(); process->run();
process.reset(); process.reset();
usleep(500000); usleep(500000);
@ -227,7 +231,7 @@ TEST(TestALL, testOutputCallBackPulse) {
manager = river::Manager::create("testApplication"); manager = river::Manager::create("testApplication");
APPL_INFO("test output (callback mode)"); APPL_INFO("test output (callback mode)");
std11::shared_ptr<testOutCallback> process = std::make_shared<testOutCallback>(manager, "speaker-pulse"); std11::shared_ptr<testOutCallback> process = std11::make_shared<testOutCallback>(manager, "speaker-pulse");
process->run(); process->run();
process.reset(); process.reset();
usleep(500000); usleep(500000);
@ -238,7 +242,7 @@ TEST(TestALL, testOutputCallBackJack) {
manager = river::Manager::create("testApplication"); manager = river::Manager::create("testApplication");
APPL_INFO("test output (callback mode)"); APPL_INFO("test output (callback mode)");
std11::shared_ptr<testOutCallback> process = std::make_shared<testOutCallback>(manager, "speaker-jack"); std11::shared_ptr<testOutCallback> process = std11::make_shared<testOutCallback>(manager, "speaker-jack");
process->run(); process->run();
process.reset(); process.reset();
usleep(500000); usleep(500000);
@ -283,7 +287,7 @@ TEST(TestALL, testInputCallBack) {
std11::shared_ptr<river::Manager> manager; std11::shared_ptr<river::Manager> manager;
manager = river::Manager::create("testApplication"); manager = river::Manager::create("testApplication");
APPL_INFO("test input (callback mode)"); APPL_INFO("test input (callback mode)");
std11::shared_ptr<testInCallback> process = std::make_shared<testInCallback>(manager); std11::shared_ptr<testInCallback> process = std11::make_shared<testInCallback>(manager);
process->run(); process->run();
process.reset(); process.reset();
usleep(500000); usleep(500000);
@ -309,14 +313,14 @@ class testInCallback {
_input, _input,
"WriteModeCallback"); "WriteModeCallback");
// set callback mode ... // set callback mode ...
m_interface->setInputCallback(std::bind(&testInCallback::onDataReceived, m_interface->setInputCallback(std11::bind(&testInCallback::onDataReceived,
this, this,
std::placeholders::_1, std11::placeholders::_1,
std::placeholders::_2, std11::placeholders::_2,
std::placeholders::_3, std11::placeholders::_3,
std::placeholders::_4, std11::placeholders::_4,
std::placeholders::_5, std11::placeholders::_5,
std::placeholders::_6)); std11::placeholders::_6));
} }
void onDataReceived(const void* _data, void onDataReceived(const void* _data,
const std11::chrono::system_clock::time_point& _time, const std11::chrono::system_clock::time_point& _time,
@ -349,7 +353,7 @@ TEST(TestALL, testInputCallBack) {
std11::shared_ptr<river::Manager> manager; std11::shared_ptr<river::Manager> manager;
manager = river::Manager::create("testApplication"); manager = river::Manager::create("testApplication");
APPL_INFO("test input (callback mode)"); APPL_INFO("test input (callback mode)");
std11::shared_ptr<testInCallback> process = std::make_shared<testInCallback>(manager); std11::shared_ptr<testInCallback> process = std11::make_shared<testInCallback>(manager);
process->run(); process->run();
process.reset(); process.reset();
usleep(500000); usleep(500000);
@ -398,14 +402,14 @@ class testOutCallbackType {
"speaker", "speaker",
"WriteModeCallbackType"); "WriteModeCallbackType");
// set callback mode ... // set callback mode ...
m_interface->setOutputCallback(std::bind(&testOutCallbackType::onDataNeeded, m_interface->setOutputCallback(std11::bind(&testOutCallbackType::onDataNeeded,
this, this,
std::placeholders::_1, std11::placeholders::_1,
std::placeholders::_2, std11::placeholders::_2,
std::placeholders::_3, std11::placeholders::_3,
std::placeholders::_4, std11::placeholders::_4,
std::placeholders::_5, std11::placeholders::_5,
std::placeholders::_6)); std11::placeholders::_6));
} }
void onDataNeeded(void* _data, void onDataNeeded(void* _data,
const std11::chrono::system_clock::time_point& _time, const std11::chrono::system_clock::time_point& _time,
@ -479,7 +483,7 @@ class testResampling : public ::testing::TestWithParam<float> {};
TEST_P(testResampling, base) { TEST_P(testResampling, base) {
std11::shared_ptr<river::Manager> manager; std11::shared_ptr<river::Manager> manager;
manager = river::Manager::create("testApplication"); manager = river::Manager::create("testApplication");
std11::shared_ptr<testOutCallbackType> process = std::make_shared<testOutCallbackType>(manager, GetParam(), 2, audio::format_int16); std11::shared_ptr<testOutCallbackType> process = std11::make_shared<testOutCallbackType>(manager, GetParam(), 2, audio::format_int16);
process->run(); process->run();
process.reset(); process.reset();
usleep(500000); usleep(500000);
@ -494,7 +498,7 @@ class testFormat : public ::testing::TestWithParam<audio::format> {};
TEST_P(testFormat, base) { TEST_P(testFormat, base) {
std11::shared_ptr<river::Manager> manager; std11::shared_ptr<river::Manager> manager;
manager = river::Manager::create("testApplication"); manager = river::Manager::create("testApplication");
std11::shared_ptr<testOutCallbackType> process = std::make_shared<testOutCallbackType>(manager, 48000, 2, GetParam()); std11::shared_ptr<testOutCallbackType> process = std11::make_shared<testOutCallbackType>(manager, 48000, 2, GetParam());
process->run(); process->run();
process.reset(); process.reset();
usleep(500000); usleep(500000);
@ -508,7 +512,7 @@ class testChannels : public ::testing::TestWithParam<int32_t> {};
TEST_P(testChannels, base) { TEST_P(testChannels, base) {
std11::shared_ptr<river::Manager> manager; std11::shared_ptr<river::Manager> manager;
manager = river::Manager::create("testApplication"); manager = river::Manager::create("testApplication");
std11::shared_ptr<testOutCallbackType> process = std::make_shared<testOutCallbackType>(manager, 48000, GetParam(), audio::format_int16); std11::shared_ptr<testOutCallbackType> process = std11::make_shared<testOutCallbackType>(manager, 48000, GetParam(), audio::format_int16);
process->run(); process->run();
process.reset(); process.reset();
usleep(500000); usleep(500000);
@ -538,14 +542,14 @@ class testCallbackVolume {
"speaker", "speaker",
"WriteModeCallback"); "WriteModeCallback");
// set callback mode ... // set callback mode ...
m_interface->setOutputCallback(std::bind(&testCallbackVolume::onDataNeeded, m_interface->setOutputCallback(std11::bind(&testCallbackVolume::onDataNeeded,
this, this,
std::placeholders::_1, std11::placeholders::_1,
std::placeholders::_2, std11::placeholders::_2,
std::placeholders::_3, std11::placeholders::_3,
std::placeholders::_4, std11::placeholders::_4,
std::placeholders::_5, std11::placeholders::_5,
std::placeholders::_6)); std11::placeholders::_6));
m_interface->addVolumeGroup("MEDIA"); m_interface->addVolumeGroup("MEDIA");
m_interface->addVolumeGroup("FLOW"); m_interface->addVolumeGroup("FLOW");
} }
@ -610,7 +614,7 @@ class testCallbackVolume {
void threadVolume(void* _userData) { void threadVolume(void* _userData) {
std11::shared_ptr<river::Manager> manager; std11::shared_ptr<river::Manager> manager;
manager = river::Manager::create("testApplication"); manager = river::Manager::create("testApplication");
std11::shared_ptr<testCallbackVolume> process = std::make_shared<testCallbackVolume>(manager); std11::shared_ptr<testCallbackVolume> process = std11::make_shared<testCallbackVolume>(manager);
process->run(); process->run();
process.reset(); process.reset();
usleep(500000); usleep(500000);
@ -623,7 +627,7 @@ TEST(TestALL, testInputCallBackMicClean) {
usleep(100000); usleep(100000);
APPL_INFO("test input (callback mode)"); APPL_INFO("test input (callback mode)");
std11::shared_ptr<testInCallback> process = std::make_shared<testInCallback>(manager, "microphone-clean"); std11::shared_ptr<testInCallback> process = std11::make_shared<testInCallback>(manager, "microphone-clean");
process->run(); process->run();
process.reset(); process.reset();
usleep(500000); usleep(500000);
@ -634,7 +638,7 @@ TEST(TestALL, testInputCallBackMicClean) {
TEST(TestALL, testVolume) { TEST(TestALL, testVolume) {
std11::shared_ptr<river::Manager> manager; std11::shared_ptr<river::Manager> manager;
manager = river::Manager::create("testApplication"); manager = river::Manager::create("testApplication");
std11::shared_ptr<testCallbackVolume> process = std::make_shared<testCallbackVolume>(manager); std11::shared_ptr<testCallbackVolume> process = std11::make_shared<testCallbackVolume>(manager);
process->run(); process->run();
process.reset(); process.reset();
usleep(500000); usleep(500000);
@ -666,11 +670,11 @@ TEST(TestALL, testChannelsFormatResampling) {
listFormat.push_back(audio::format_int16_on_int32); listFormat.push_back(audio::format_int16_on_int32);
listFormat.push_back(audio::format_int32); listFormat.push_back(audio::format_int32);
listFormat.push_back(audio::format_float); listFormat.push_back(audio::format_float);
for (auto &itFreq : listFreq) { for (size_t fff=0; fff<listFreq.size(); ++fff) {
for (auto &itChannel : listChannel) { for (size_t ccc=0; ccc<listChannel.size(); ++ccc) {
for (auto &itFormat : listFormat) { for (size_t iii=0; iii<listFormat.size(); ++iii) {
APPL_INFO("freq=" << itFreq << " channel=" << itChannel << " format=" << getFormatString(itFormat)); APPL_INFO("freq=" << listFreq[fff] << " channel=" << listChannel[ccc] << " format=" << getFormatString(listFormat[iii]));
std11::shared_ptr<testOutCallbackType> process = std::make_shared<testOutCallbackType>(manager, itFreq, itChannel, itFormat); std11::shared_ptr<testOutCallbackType> process = std11::make_shared<testOutCallbackType>(manager, listFreq[fff], listChannel[ccc], listFormat[iii]);
process->run(); process->run();
process.reset(); process.reset();
usleep(500000); usleep(500000);