summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--gr-audio/lib/gr-audio.conf4
-rw-r--r--gr-audio/lib/gr_audio_registry.cc42
2 files changed, 38 insertions, 8 deletions
diff --git a/gr-audio/lib/gr-audio.conf b/gr-audio/lib/gr-audio.conf
index a79413d1a..cf3d6db11 100644
--- a/gr-audio/lib/gr-audio.conf
+++ b/gr-audio/lib/gr-audio.conf
@@ -1,3 +1,7 @@
# This file contains system wide configuration data for GNU Radio.
# You may override any setting on a per-user basis by editing
# ~/.gnuradio/config.conf
+
+[audio]
+
+#default_arch = alsa
diff --git a/gr-audio/lib/gr_audio_registry.cc b/gr-audio/lib/gr_audio_registry.cc
index be1337101..7be652807 100644
--- a/gr-audio/lib/gr_audio_registry.cc
+++ b/gr-audio/lib/gr_audio_registry.cc
@@ -20,20 +20,25 @@
*/
#include "gr_audio_registry.h"
+#include <boost/foreach.hpp>
+#include <gr_prefs.h>
#include <stdexcept>
#include <vector>
#include <utility>
+#include <iostream>
/***********************************************************************
* Create registries
**********************************************************************/
-static std::vector<std::pair<std::string, source_factory_t> > &get_source_registry(void){
- static std::vector<std::pair<std::string, source_factory_t> > _registry;
+typedef std::pair<std::string, source_factory_t> source_pair_t;
+static std::vector<source_pair_t> &get_source_registry(void){
+ static std::vector<source_pair_t> _registry;
return _registry;
}
-static std::vector<std::pair<std::string, sink_factory_t> > &get_sink_registry(void){
- static std::vector<std::pair<std::string, sink_factory_t> > _registry;
+typedef std::pair<std::string, sink_factory_t> sink_pair_t;
+static std::vector<sink_pair_t> &get_sink_registry(void){
+ static std::vector<sink_pair_t> _registry;
return _registry;
}
@@ -51,15 +56,30 @@ void audio_register_sink(const std::string &name, sink_factory_t sink){
/***********************************************************************
* Factory functions
**********************************************************************/
+static std::string default_arch_name(void){
+ return gr_prefs::singleton()->get_string("audio", "default_arch", "");
+}
+
+static void do_arch_warning(const std::string &arch){
+ std::cerr << "Could not find audio architecture \"" << arch << "\" in registry." << std::endl;
+ std::cerr << " Defaulting to the first available architecture..." << std::endl;
+}
+
audio_source::sptr audio_make_source(
int sampling_rate,
const std::string device_name,
bool ok_to_block
){
if (get_source_registry().empty()){
- throw std::runtime_error("no available audio factories");
+ throw std::runtime_error("no available audio source factories");
+ }
+ std::string arch = default_arch_name();
+ BOOST_FOREACH(const source_pair_t &e, get_source_registry()){
+ if (arch.empty() || arch == e.first){
+ return e.second(sampling_rate, device_name, ok_to_block);
+ }
}
- //TODO we may prefer to use a specific entry in the registry
+ do_arch_warning(arch);
return get_source_registry().front().second(sampling_rate, device_name, ok_to_block);
}
@@ -69,9 +89,15 @@ audio_sink::sptr audio_make_sink(
bool ok_to_block
){
if (get_sink_registry().empty()){
- throw std::runtime_error("no available audio factories");
+ throw std::runtime_error("no available audio sink factories");
+ }
+ std::string arch = default_arch_name();
+ BOOST_FOREACH(const sink_pair_t &e, get_sink_registry()){
+ if (arch.empty() || arch == e.first){
+ return e.second(sampling_rate, device_name, ok_to_block);
+ }
}
- //TODO we may prefer to use a specific entry in the registry
+ do_arch_warning(arch);
return get_sink_registry().front().second(sampling_rate, device_name, ok_to_block);
}