/** @file * @author Edouard DUPIN * @copyright 2011, Edouard DUPIN, all right reserved * @license APACHE v2.0 (see license file) */ #include "debug.h" #include #include #include #include #include #include #include #undef __class__ #define __class__ "Process" airtalgo::Process::Process() { } airtalgo::Process::~Process() { for (auto &it : m_listAlgo) { it.reset(); } } bool airtalgo::Process::push(std::chrono::system_clock::time_point& _time, void* _data, size_t _nbChunk) { void* out = nullptr; size_t nbChunkOut; AIRTALGO_VERBOSE(" Process push"); process(_time, _data, _nbChunk, out, nbChunkOut); return true; } bool airtalgo::Process::pull(std::chrono::system_clock::time_point& _time, void*& _data, size_t& _nbChunk) { void* in = nullptr; size_t nbChunkIn = _nbChunk; void* out = nullptr; size_t nbChunkOut; if (nbChunkIn < 128) { nbChunkIn = 128; } for (int32_t iii=m_listAlgo.size()-1; iii >=0; --iii) { if (m_listAlgo[iii] != nullptr) { nbChunkIn = m_listAlgo[iii]->needInputData(nbChunkIn); } } if (nbChunkIn < 32) { nbChunkIn = 32; } process(_time, in, nbChunkIn, _data, _nbChunk); return true; } bool airtalgo::Process::process(std::chrono::system_clock::time_point& _time, void* _inData, size_t _inNbChunk, void*& _outData, size_t& _outNbChunk) { if (m_listAlgo.size() == 0) { _outData = _inData; _outNbChunk = _inNbChunk; return true; } AIRTALGO_VERBOSE(" process : " << m_listAlgo.size() << " algos nbChunk=" << _outNbChunk); for (size_t iii=0; iiiprocess(_time, _inData, _inNbChunk, _outData, _outNbChunk); _inData = _outData; _inNbChunk = _outNbChunk; } } return true; } void airtalgo::Process::pushBack(const std::shared_ptr& _algo) { m_listAlgo.push_back(_algo); } void airtalgo::Process::pushFront(const std::shared_ptr& _algo) { m_listAlgo.insert(m_listAlgo.begin(), _algo); } void airtalgo::Process::updateInterAlgo() { // TODO : ... }