Bell catchup

This commit is contained in:
philippe44
2023-07-26 13:19:20 -07:00
parent 859efdb954
commit 232afb948b
467 changed files with 77538 additions and 37137 deletions

View File

@@ -1,14 +1,22 @@
#include <memory.h>
#include <atomic>
#include <cmath>
#include <fstream>
#include <iostream>
#include <map>
#include <memory>
#include <string>
#include <type_traits>
#include <vector>
#include "AudioCodecs.h"
#include "AudioContainers.h"
#include "BellHTTPServer.h"
#include "BellTask.h"
#include "CentralAudioBuffer.h"
#include "Compressor.h"
#include "DecoderGlobals.h"
#include "EncodedAudioStream.h"
#include "HTTPClient.h"
#include "PortAudioSink.h"
#include "StreamInfo.h"
#define DEBUG_LEVEL 4
#include <BellDSP.h>
#include <BellLogger.h>
@@ -33,8 +41,8 @@ class AudioPlayer : bell::Task {
auto chunk = audioBuffer->readChunk();
if (chunk != nullptr && chunk->pcmSize > 0) {
this->dsp->process(chunk->pcmData, chunk->pcmSize, 2, 44100,
bell::BitWidth::BW_16);
// this->dsp->process(chunk->pcmData, chunk->pcmSize, 2, 44100,
// bell::BitWidth::BW_16);
this->audioSink->feedPCMFrames(chunk->pcmData, chunk->pcmSize);
}
@@ -45,9 +53,51 @@ class AudioPlayer : bell::Task {
int main() {
bell::setDefaultLogger();
bell::createDecoders();
size_t size = sizeof(void*);
audioBuffer = std::make_shared<bell::CentralAudioBuffer>(512);
auto task = AudioPlayer();
auto url = "http://193.222.135.71/378";
// std::ifstream file("aactest.aac", std::ios::binary);
BELL_LOG(info, "cock", "Published?");
auto req = bell::HTTPClient::get(url);
auto container = AudioContainers::guessAudioContainer(req->stream());
auto codec = AudioCodecs::getCodec(container.get());
uint32_t dataLen;
while (true) {
uint8_t* data = codec->decode(container.get(), dataLen);
if (!data) {
std::cout << "data invalid" << std::endl;
continue;
}
size_t toWrite = dataLen;
while (toWrite > 0) {
toWrite -= audioBuffer->writePCM(data + dataLen - toWrite, toWrite, 0);
}
// std::cout << dataLen << std::endl;
}
// return 0;
// std::vector<uint8_t> frameData(1024 * 10);
// /*
// while (true) {
// size_t bytes =audioStream->decodeFrame(frameData.data());
// std::cout << bytes <<std::endl;
// size_t toWrite = bytes;
// if (!isPaused) {
// while (toWrite > 0) {
// toWrite -= audioBuffer->writePCM(frameData.data() + bytes - toWrite,
// toWrite, 0);
// }
// }
// }*/
return 0;
}
}