audio-drain/audio/drain/Process.hpp

189 lines
6.2 KiB
C++
Raw Normal View History

2015-04-10 23:00:13 +02:00
/** @file
* @author Edouard DUPIN
* @copyright 2011, Edouard DUPIN, all right reserved
* @license MPL v2.0 (see license file)
2015-04-10 23:00:13 +02:00
*/
#pragma once
2015-04-10 23:00:13 +02:00
#include <string>
#include <vector>
#include <cstdint>
2016-10-02 21:41:55 +02:00
#include <audio/format.hpp>
#include <audio/channel.hpp>
#include <audio/drain/Algo.hpp>
2015-09-14 21:11:04 +02:00
#include <chrono>
2016-10-02 21:41:55 +02:00
#include <ememory/memory.hpp>
#include <etk/os/FSNode.hpp>
2015-04-10 23:00:13 +02:00
namespace audio {
namespace drain{
typedef std::function<void (const std::string& _origin, const std::string& _status)> statusFunction;
2015-04-10 23:00:13 +02:00
class Process {
protected:
std::vector<int8_t> m_data; //!< temporary overlap output buffer (change size of the output data)
public:
Process();
virtual ~Process();
public:
/**
* @brief Push data in the algo stream.
* @param[in] _time Time of the first sample pushed.
* @param[in] _data Pointer on the data pushed.
* @param[in] _nbChunk Number of chunk present in the pointer.
* @return true The procress is done corectly.
* @return false An error occured.
*/
2015-04-13 21:49:48 +02:00
bool push(audio::Time& _time,
2015-04-10 23:00:13 +02:00
void* _data,
size_t _nbChunk);
/**
* @brief Push data in the algo stream.
* @param[in] _time Time of the first sample requested.
* @param[in] _data Pointer on the data pushed.
* @param[in,out] _nbChunk Number of chunk present in the pointer (set at the number of chunk requested(hope)).
* @param[out] _chunkSize size of a single chunk. TODO : Not needed ... Remove it ...
* @return true The procress is done corectly.
* @return false An error occured.
*/
2015-04-13 21:49:48 +02:00
bool pull(audio::Time& _time,
2015-04-10 23:00:13 +02:00
void* _data,
size_t _nbChunk,
size_t _chunkSize);
/**
* @brief Push data in the algo stream.
* @param[in] _time Time of the first sample pushed.
* @param[in] _inData Pointer on the data pushed.
* @param[in] _inNbChunk Number of chunk present in the input pointer.
* @param[out] _outData Pointer on the data geted.
* @param[out] _outNbChunk Number of chunk present in the output pointer.
* @return true The procress is done corectly.
* @return false An error occured.
*/
2015-04-13 21:49:48 +02:00
bool process(audio::Time& _time,
2015-04-10 23:00:13 +02:00
void* _inData,
size_t _inNbChunk,
void*& _outData,
size_t& _outNbChunk);
bool process(void* _inData,
size_t _inNbChunk,
void*& _outData,
size_t& _outNbChunk) {
2015-04-13 21:49:48 +02:00
audio::Time time;
2015-04-10 23:00:13 +02:00
return process(time, _inData, _inNbChunk, _outData, _outNbChunk);
}
bool processIn(void* _inData,
size_t _inNbChunk,
void* _outData,
size_t _outNbChunk);
protected:
IOFormatInterface m_inputConfig;
public:
const IOFormatInterface& getInputConfig() const {
return m_inputConfig;
}
void setInputConfig(const IOFormatInterface& _interface) {
m_inputConfig = _interface;
}
protected:
IOFormatInterface m_outputConfig;
public:
const IOFormatInterface& getOutputConfig() const {
return m_outputConfig;
}
void setOutputConfig(const IOFormatInterface& _interface) {
m_outputConfig = _interface;
}
protected:
2016-07-19 21:43:58 +02:00
std::vector<ememory::SharedPtr<drain::Algo> > m_listAlgo;
2015-04-10 23:00:13 +02:00
public:
2016-07-19 21:43:58 +02:00
void pushBack(ememory::SharedPtr<drain::Algo> _algo);
void pushFront(ememory::SharedPtr<drain::Algo> _algo);
2015-04-10 23:00:13 +02:00
void clear() {
m_isConfigured = false;
m_listAlgo.clear();
}
size_t size() {
return m_listAlgo.size();
}
2016-07-19 21:43:58 +02:00
std::vector<ememory::SharedPtr<drain::Algo> >::iterator begin() {
2015-04-10 23:00:13 +02:00
return m_listAlgo.begin();
}
2016-07-19 21:43:58 +02:00
std::vector<ememory::SharedPtr<drain::Algo> >::iterator end() {
2015-04-10 23:00:13 +02:00
return m_listAlgo.end();
}
2016-07-19 21:43:58 +02:00
ememory::SharedPtr<drain::Algo> operator[](int32_t _id) {
2015-04-10 23:00:13 +02:00
return m_listAlgo[_id];
}
2016-07-19 21:43:58 +02:00
template<typename T> ememory::SharedPtr<T> get(const std::string& _name) {
2015-04-10 23:00:13 +02:00
for (size_t iii=0; iii<m_listAlgo.size(); ++iii) {
if (m_listAlgo[iii] == nullptr) {
continue;
}
if (m_listAlgo[iii]->getName() == _name) {
2016-07-19 21:43:58 +02:00
return ememory::dynamicPointerCast<T>(m_listAlgo[iii]);
2015-04-10 23:00:13 +02:00
}
}
2016-07-19 21:43:58 +02:00
return ememory::SharedPtr<T>();
2015-04-10 23:00:13 +02:00
}
2016-07-19 21:43:58 +02:00
template<typename T> ememory::SharedPtr<const T> get(const std::string& _name) const {
2015-04-10 23:00:13 +02:00
for (size_t iii=0; iii<m_listAlgo.size(); ++iii) {
if (m_listAlgo[iii] == nullptr) {
continue;
}
if (m_listAlgo[iii]->getName() == _name) {
2016-07-19 21:43:58 +02:00
return ememory::dynamicPointerCast<T>(m_listAlgo[iii]);
2015-04-10 23:00:13 +02:00
}
}
2016-07-19 21:43:58 +02:00
return ememory::SharedPtr<const T>();
2015-04-10 23:00:13 +02:00
}
2016-07-19 21:43:58 +02:00
template<typename T> ememory::SharedPtr<T> get(int32_t _id) {
return ememory::dynamicPointerCast<T>(m_listAlgo[_id]);
2015-04-10 23:00:13 +02:00
}
template<typename T> void removeIfFirst() {
if (m_listAlgo.size() > 0) {
2016-07-19 21:43:58 +02:00
ememory::SharedPtr<T> algoEP = get<T>(0);
2015-04-10 23:00:13 +02:00
if (algoEP != nullptr) {
m_listAlgo.erase(m_listAlgo.begin());
}
}
}
template<typename T> void removeIfLast() {
if (m_listAlgo.size() > 0) {
2016-07-19 21:43:58 +02:00
ememory::SharedPtr<T> algoEP = get<T>(m_listAlgo.size()-1);
2015-04-10 23:00:13 +02:00
if (algoEP != nullptr) {
m_listAlgo.erase(m_listAlgo.begin()+m_listAlgo.size()-1);
}
}
}
template<typename T> bool hasType() {
for (size_t iii=0; iii<m_listAlgo.size(); ++iii) {
2016-07-19 21:43:58 +02:00
ememory::SharedPtr<T> tmp = ememory::dynamicPointerCast<T>(m_listAlgo[iii]);
2015-04-10 23:00:13 +02:00
if (tmp != nullptr) {
return true;
}
}
return false;
}
private:
statusFunction m_statusFunction;
public:
void generateStatus(const std::string& _origin, const std::string& _status);
void setStatusFunction(statusFunction _newFunction);
private:
bool m_isConfigured;
public:
void updateInterAlgo();
void removeAlgoDynamic();
private:
void displayAlgo();
void updateAlgo(size_t _position);
public:
void generateDot(etk::FSNode& _node, int32_t _offset, int32_t _basicID, std::string& _nameIn, std::string& _nameOut, bool _reserseGraph);
// TODO : Remove this one when we find a good way to do it ...
void generateDotProcess(etk::FSNode& _node, int32_t _offset, int32_t _basicID, std::string& _nameIn, std::string& _nameOut, bool _reserseGraph);
};
}
}