mirror of
https://github.com/AlexandreRouma/SDRPlusPlus.git
synced 2025-01-12 11:17:11 +01:00
more bugfix on the module manager and audio streams
This commit is contained in:
parent
fa9347f2ee
commit
646fe4fd02
@ -248,7 +248,8 @@ public:
|
|||||||
}
|
}
|
||||||
|
|
||||||
~AudioSinkModule() {
|
~AudioSinkModule() {
|
||||||
|
// Unregister sink, this will automatically stop and delete all instances of the audio sink
|
||||||
|
sigpath::sinkManager.unregisterSinkProvider("Audio");
|
||||||
}
|
}
|
||||||
|
|
||||||
void postInit() {}
|
void postInit() {}
|
||||||
|
@ -87,11 +87,52 @@ void SinkManager::Stream::setSampleRate(float sampleRate) {
|
|||||||
|
|
||||||
void SinkManager::registerSinkProvider(std::string name, SinkProvider provider) {
|
void SinkManager::registerSinkProvider(std::string name, SinkProvider provider) {
|
||||||
if (providers.find(name) != providers.end()) {
|
if (providers.find(name) != providers.end()) {
|
||||||
spdlog::error("Cannot create sink provider '{0}', this name is already taken", name);
|
spdlog::error("Cannot register sink provider '{0}', this name is already taken", name);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Add the provider to the lists
|
||||||
providers[name] = provider;
|
providers[name] = provider;
|
||||||
providerNames.push_back(name);
|
providerNames.push_back(name);
|
||||||
|
|
||||||
|
// Recreatd the text list for the menu
|
||||||
|
refreshProviders();
|
||||||
|
|
||||||
|
// Update the IDs of every stream
|
||||||
|
for (auto& [streamName, stream] : streams) {
|
||||||
|
stream->providerId = std::distance(providerNames.begin(), std::find(providerNames.begin(), providerNames.end(), stream->providerName));
|
||||||
|
}
|
||||||
|
|
||||||
|
onSinkProviderRegistered.emit(name);
|
||||||
|
}
|
||||||
|
|
||||||
|
void SinkManager::unregisterSinkProvider(std::string name) {
|
||||||
|
if (providers.find(name) == providers.end()) {
|
||||||
|
spdlog::error("Cannot unregister sink provider '{0}', no such provider exists.", name);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
onSinkProviderUnregister.emit(name);
|
||||||
|
|
||||||
|
// Switch all sinks using it to a null sink
|
||||||
|
for (auto& [streamName, stream] : streams) {
|
||||||
|
if (providerNames[stream->providerId] != name) { continue; }
|
||||||
|
setStreamSink(streamName, "None");
|
||||||
|
}
|
||||||
|
|
||||||
|
// Erase the provider from the lists
|
||||||
|
providers.erase(name);
|
||||||
|
providerNames.erase(std::find(providerNames.begin(), providerNames.end(), name));
|
||||||
|
|
||||||
|
// Recreatd the text list for the menu
|
||||||
|
refreshProviders();
|
||||||
|
|
||||||
|
// Update the IDs of every stream
|
||||||
|
for (auto& [streamName, stream] : streams) {
|
||||||
|
stream->providerId = std::distance(providerNames.begin(), std::find(providerNames.begin(), providerNames.end(), stream->providerName));
|
||||||
|
}
|
||||||
|
|
||||||
|
onSinkProviderUnregistered.emit(name);
|
||||||
}
|
}
|
||||||
|
|
||||||
void SinkManager::registerStream(std::string name, SinkManager::Stream* stream) {
|
void SinkManager::registerStream(std::string name, SinkManager::Stream* stream) {
|
||||||
@ -105,6 +146,8 @@ void SinkManager::registerStream(std::string name, SinkManager::Stream* stream)
|
|||||||
provider = providers["None"];
|
provider = providers["None"];
|
||||||
|
|
||||||
stream->sink = provider.create(stream, name, provider.ctx);
|
stream->sink = provider.create(stream, name, provider.ctx);
|
||||||
|
stream->providerId = std::distance(providerNames.begin(), std::find(providerNames.begin(), providerNames.end(), "None"));
|
||||||
|
stream->providerName = "None";
|
||||||
|
|
||||||
streams[name] = stream;
|
streams[name] = stream;
|
||||||
streamNames.push_back(name);
|
streamNames.push_back(name);
|
||||||
@ -173,7 +216,27 @@ void SinkManager::unbindStream(std::string name, dsp::stream<dsp::stereo_t>* str
|
|||||||
}
|
}
|
||||||
|
|
||||||
void SinkManager::setStreamSink(std::string name, std::string providerName) {
|
void SinkManager::setStreamSink(std::string name, std::string providerName) {
|
||||||
spdlog::warn("setStreamSink is NOT implemented!!!");
|
if (streams.find(name) == streams.end()) {
|
||||||
|
spdlog::error("Cannot set sink for stream '{0}'. Stream doesn't exist", name);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
Stream* stream = streams[name];
|
||||||
|
if (providers.find(providerName) == providers.end()) {
|
||||||
|
spdlog::error("Unknown sink provider '{0}'", providerName);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (stream->running) {
|
||||||
|
stream->sink->stop();
|
||||||
|
}
|
||||||
|
delete stream->sink;
|
||||||
|
stream->providerId = std::distance(providerNames.begin(), std::find(providerNames.begin(), providerNames.end(), providerName));
|
||||||
|
stream->providerName = providerName;
|
||||||
|
SinkManager::SinkProvider prov = providers[providerName];
|
||||||
|
stream->sink = prov.create(stream, name, prov.ctx);
|
||||||
|
if (stream->running) {
|
||||||
|
stream->sink->start();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void SinkManager::showVolumeSlider(std::string name, std::string prefix, float width, float btnHeight, int btwBorder, bool sameLine) {
|
void SinkManager::showVolumeSlider(std::string name, std::string prefix, float width, float btnHeight, int btwBorder, bool sameLine) {
|
||||||
@ -251,6 +314,7 @@ void SinkManager::loadStreamConfig(std::string name) {
|
|||||||
delete stream->sink;
|
delete stream->sink;
|
||||||
SinkManager::SinkProvider prov = providers[provName];
|
SinkManager::SinkProvider prov = providers[provName];
|
||||||
stream->providerId = std::distance(providerNames.begin(), std::find(providerNames.begin(), providerNames.end(), provName));
|
stream->providerId = std::distance(providerNames.begin(), std::find(providerNames.begin(), providerNames.end(), provName));
|
||||||
|
stream->providerName = provName;
|
||||||
stream->sink = prov.create(stream, name, prov.ctx);
|
stream->sink = prov.create(stream, name, prov.ctx);
|
||||||
if (stream->running) {
|
if (stream->running) {
|
||||||
stream->sink->start();
|
stream->sink->start();
|
||||||
@ -293,15 +357,7 @@ void SinkManager::showMenu() {
|
|||||||
|
|
||||||
ImGui::SetNextItemWidth(menuWidth);
|
ImGui::SetNextItemWidth(menuWidth);
|
||||||
if (ImGui::Combo(CONCAT("##_sdrpp_sink_select_", name), &stream->providerId, provStr.c_str())) {
|
if (ImGui::Combo(CONCAT("##_sdrpp_sink_select_", name), &stream->providerId, provStr.c_str())) {
|
||||||
if (stream->running) {
|
setStreamSink(name, providerNames[stream->providerId]);
|
||||||
stream->sink->stop();
|
|
||||||
}
|
|
||||||
delete stream->sink;
|
|
||||||
SinkManager::SinkProvider prov = providers[providerNames[stream->providerId]];
|
|
||||||
stream->sink = prov.create(stream, name, prov.ctx);
|
|
||||||
if (stream->running) {
|
|
||||||
stream->sink->start();
|
|
||||||
}
|
|
||||||
core::configManager.acquire();
|
core::configManager.acquire();
|
||||||
saveStreamConfig(name);
|
saveStreamConfig(name);
|
||||||
core::configManager.release(true);
|
core::configManager.release(true);
|
||||||
@ -323,3 +379,11 @@ void SinkManager::showMenu() {
|
|||||||
std::vector<std::string> SinkManager::getStreamNames() {
|
std::vector<std::string> SinkManager::getStreamNames() {
|
||||||
return streamNames;
|
return streamNames;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void SinkManager::refreshProviders() {
|
||||||
|
providerNamesTxt.clear();
|
||||||
|
for (auto& provName : providerNames) {
|
||||||
|
providerNamesTxt += provName;
|
||||||
|
providerNamesTxt += '\0';
|
||||||
|
}
|
||||||
|
}
|
@ -59,6 +59,7 @@ public:
|
|||||||
std::mutex ctrlMtx;
|
std::mutex ctrlMtx;
|
||||||
float _sampleRate;
|
float _sampleRate;
|
||||||
int providerId = 0;
|
int providerId = 0;
|
||||||
|
std::string providerName = "";
|
||||||
bool running = false;
|
bool running = false;
|
||||||
|
|
||||||
float guiVolume = 1.0f;
|
float guiVolume = 1.0f;
|
||||||
@ -89,6 +90,7 @@ public:
|
|||||||
};
|
};
|
||||||
|
|
||||||
void registerSinkProvider(std::string name, SinkProvider provider);
|
void registerSinkProvider(std::string name, SinkProvider provider);
|
||||||
|
void unregisterSinkProvider(std::string name);
|
||||||
|
|
||||||
void registerStream(std::string name, Stream* stream);
|
void registerStream(std::string name, Stream* stream);
|
||||||
void unregisterStream(std::string name);
|
void unregisterStream(std::string name);
|
||||||
@ -110,6 +112,10 @@ public:
|
|||||||
|
|
||||||
std::vector<std::string> getStreamNames();
|
std::vector<std::string> getStreamNames();
|
||||||
|
|
||||||
|
Event<std::string> onSinkProviderRegistered;
|
||||||
|
Event<std::string> onSinkProviderUnregister;
|
||||||
|
Event<std::string> onSinkProviderUnregistered;
|
||||||
|
|
||||||
Event<std::string> onStreamRegistered;
|
Event<std::string> onStreamRegistered;
|
||||||
Event<std::string> onStreamUnregister;
|
Event<std::string> onStreamUnregister;
|
||||||
Event<std::string> onStreamUnregistered;
|
Event<std::string> onStreamUnregistered;
|
||||||
@ -117,10 +123,12 @@ public:
|
|||||||
private:
|
private:
|
||||||
void loadStreamConfig(std::string name);
|
void loadStreamConfig(std::string name);
|
||||||
void saveStreamConfig(std::string name);
|
void saveStreamConfig(std::string name);
|
||||||
|
void refreshProviders();
|
||||||
|
|
||||||
std::map<std::string, SinkProvider> providers;
|
std::map<std::string, SinkProvider> providers;
|
||||||
std::map<std::string, Stream*> streams;
|
std::map<std::string, Stream*> streams;
|
||||||
std::vector<std::string> providerNames;
|
std::vector<std::string> providerNames;
|
||||||
|
std::string providerNamesTxt;
|
||||||
std::vector<std::string> streamNames;
|
std::vector<std::string> streamNames;
|
||||||
|
|
||||||
};
|
};
|
@ -395,6 +395,7 @@ public:
|
|||||||
}
|
}
|
||||||
|
|
||||||
~AudioSinkModule() {
|
~AudioSinkModule() {
|
||||||
|
sigpath::sinkManager.unregisterSinkProvider("New Audio");
|
||||||
Pa_Terminate();
|
Pa_Terminate();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -293,6 +293,7 @@ public:
|
|||||||
}
|
}
|
||||||
|
|
||||||
~AudioSinkModule() {
|
~AudioSinkModule() {
|
||||||
|
sigpath::sinkManager.unregisterSinkProvider("Audio");
|
||||||
Pa_Terminate();
|
Pa_Terminate();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -398,8 +398,7 @@ private:
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (_this->selectedStreamName.empty()) {
|
if (_this->selectedStreamName.empty()) {
|
||||||
_this->streamId = 0;
|
_this->selectStream(_this->streamNames[0]);
|
||||||
_this->selectedStreamName = _this->streamNames[0];
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -420,6 +419,7 @@ private:
|
|||||||
if (_this->recording) { _this->stopRecording(); }
|
if (_this->recording) { _this->stopRecording(); }
|
||||||
if (_this->audioInput != NULL) {
|
if (_this->audioInput != NULL) {
|
||||||
sigpath::sinkManager.unbindStream(_this->selectedStreamName, _this->audioInput);
|
sigpath::sinkManager.unbindStream(_this->selectedStreamName, _this->audioInput);
|
||||||
|
_this->vol.setInput(&_this->dummyStream);
|
||||||
_this->audioInput = NULL;
|
_this->audioInput = NULL;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user