diff options
Diffstat (limited to 'host/lib')
| -rw-r--r-- | host/lib/types/device_addr.cpp | 14 | ||||
| -rw-r--r-- | host/lib/usrp/subdev_spec.cpp | 12 | ||||
| -rw-r--r-- | host/lib/usrp/usrp2/usrp2_impl.cpp | 7 | ||||
| -rw-r--r-- | host/lib/utils/paths.cpp | 8 | ||||
| -rw-r--r-- | host/lib/utils/warning.cpp | 8 | 
5 files changed, 30 insertions, 19 deletions
diff --git a/host/lib/types/device_addr.cpp b/host/lib/types/device_addr.cpp index 4fdce097b..14afaa24b 100644 --- a/host/lib/types/device_addr.cpp +++ b/host/lib/types/device_addr.cpp @@ -32,19 +32,15 @@ static std::string trim(const std::string &in){      return boost::algorithm::trim_copy(in);  } -static boost::tokenizer<boost::char_separator<char> > tokenize( -    const std::string &input, const std::string &tok -){ -    return boost::tokenizer<boost::char_separator<char> >( -        input, boost::char_separator<char>(tok.c_str()) -    ); -} +#define tokenizer(inp, sep) \ +    boost::tokenizer<boost::char_separator<char> > \ +    (inp, boost::char_separator<char>(sep.c_str()))  device_addr_t::device_addr_t(const std::string &args){ -    BOOST_FOREACH(const std::string &pair, tokenize(args, arg_delim)){ +    BOOST_FOREACH(const std::string &pair, tokenizer(args, arg_delim)){          if (trim(pair) == "") continue;          std::string key; -        BOOST_FOREACH(const std::string &tok, tokenize(pair, pair_delim)){ +        BOOST_FOREACH(const std::string &tok, tokenizer(pair, pair_delim)){              if (key.empty()) key = tok;              else{                  this->set(trim(key), trim(tok)); diff --git a/host/lib/usrp/subdev_spec.cpp b/host/lib/usrp/subdev_spec.cpp index 95d2cbb12..c905eab7d 100644 --- a/host/lib/usrp/subdev_spec.cpp +++ b/host/lib/usrp/subdev_spec.cpp @@ -16,15 +16,21 @@  //  #include <uhd/usrp/subdev_spec.hpp> -#include <uhd/utils/algorithm.hpp> +#include <boost/algorithm/string.hpp> //for split +#include <boost/tokenizer.hpp>  #include <boost/format.hpp>  #include <boost/foreach.hpp>  #include <stdexcept>  #include <sstream> +#include <vector>  using namespace uhd;  using namespace uhd::usrp; +#define pair_tokenizer(inp) \ +    boost::tokenizer<boost::char_separator<char> > \ +    (inp, boost::char_separator<char>(" ")) +  subdev_spec_pair_t::subdev_spec_pair_t(      const std::string &db_name, const std::string &sd_name  ): @@ -39,9 +45,9 @@ bool usrp::operator==(const subdev_spec_pair_t &lhs, const subdev_spec_pair_t &r  }  subdev_spec_t::subdev_spec_t(const std::string &markup){ -    BOOST_FOREACH(const std::string &pair, std::split_string(markup)){ +    BOOST_FOREACH(const std::string &pair, pair_tokenizer(markup)){          if (pair == "") continue; -        std::vector<std::string> db_sd = std::split_string(pair, ":"); +        std::vector<std::string> db_sd; boost::split(db_sd, pair, boost::is_any_of(":"));          switch(db_sd.size()){          case 1: this->push_back(subdev_spec_pair_t("", db_sd.front())); break;          case 2: this->push_back(subdev_spec_pair_t(db_sd.front(), db_sd.back())); break; diff --git a/host/lib/usrp/usrp2/usrp2_impl.cpp b/host/lib/usrp/usrp2/usrp2_impl.cpp index f910999d4..06ca61e13 100644 --- a/host/lib/usrp/usrp2/usrp2_impl.cpp +++ b/host/lib/usrp/usrp2/usrp2_impl.cpp @@ -22,7 +22,7 @@  #include <uhd/utils/assert.hpp>  #include <uhd/utils/static.hpp>  #include <uhd/utils/warning.hpp> -#include <uhd/utils/algorithm.hpp> +#include <boost/algorithm/string.hpp> //for split  #include <boost/assign/list_of.hpp>  #include <boost/format.hpp>  #include <boost/foreach.hpp> @@ -31,6 +31,7 @@  #include <boost/bind.hpp>  #include <boost/asio.hpp> //htonl and ntohl  #include <iostream> +#include <vector>  using namespace uhd;  using namespace uhd::usrp; @@ -47,8 +48,8 @@ template <class T> std::string num2str(T num){  //! separate indexed device addresses into a vector of device addresses  device_addrs_t sep_indexed_dev_addrs(const device_addr_t &dev_addr){      //------------ support old deprecated way and print warning -------- -    if (dev_addr.has_key("addr")){ -        std::vector<std::string> addrs = std::split_string(dev_addr["addr"]); +    if (dev_addr.has_key("addr") and not dev_addr["addr"].empty()){ +        std::vector<std::string> addrs; boost::split(addrs, dev_addr["addr"], boost::is_any_of(" "));          if (addrs.size() > 1){              device_addr_t fixed_dev_addr = dev_addr;              fixed_dev_addr.pop("addr"); diff --git a/host/lib/utils/paths.cpp b/host/lib/utils/paths.cpp index 9e9525caf..f2037a38d 100644 --- a/host/lib/utils/paths.cpp +++ b/host/lib/utils/paths.cpp @@ -17,7 +17,7 @@  #include "constants.hpp"  #include <uhd/config.hpp> -#include <uhd/utils/algorithm.hpp> +#include <boost/tokenizer.hpp>  #include <boost/program_options.hpp>  #include <boost/filesystem.hpp>  #include <boost/foreach.hpp> @@ -38,6 +38,10 @@ namespace fs = boost::filesystem;      static const std::string env_path_sep = ":";  #endif /*UHD_PLATFORM_WIN32*/ +#define path_tokenizer(inp) \ +    boost::tokenizer<boost::char_separator<char> > \ +    (inp, boost::char_separator<char>(env_path_sep.c_str())) +  /***********************************************************************   * Get a list of paths for an environment variable   **********************************************************************/ @@ -60,7 +64,7 @@ static std::vector<fs::path> get_env_paths(const std::string &var_name){      //convert to filesystem path, filter blank paths      std::vector<fs::path> paths; -    BOOST_FOREACH(const std::string &path_string, std::split_string(var_value, env_path_sep)){ +    BOOST_FOREACH(const std::string &path_string, path_tokenizer(var_value)){          if (path_string.empty()) continue;          paths.push_back(fs::system_complete(path_string));      } diff --git a/host/lib/utils/warning.cpp b/host/lib/utils/warning.cpp index 05be7ae4d..09a12aba5 100644 --- a/host/lib/utils/warning.cpp +++ b/host/lib/utils/warning.cpp @@ -16,7 +16,7 @@  //  #include <uhd/utils/warning.hpp> -#include <uhd/utils/algorithm.hpp> +#include <boost/tokenizer.hpp>  #include <uhd/utils/static.hpp>  #include <uhd/types/dict.hpp>  #include <boost/foreach.hpp> @@ -27,6 +27,10 @@  using namespace uhd; +#define tokenizer(inp, sep) \ +    boost::tokenizer<boost::char_separator<char> > \ +    (inp, boost::char_separator<char>(sep)) +  /***********************************************************************   * Registry implementation   **********************************************************************/ @@ -52,7 +56,7 @@ void warning::post(const std::string &msg){      //format the warning message      ss << std::endl << "Warning:" << std::endl; -    BOOST_FOREACH(const std::string &line, std::split_string(msg, "\n")){ +    BOOST_FOREACH(const std::string &line, tokenizer(msg, "\n")){          ss << "    " << line << std::endl;      }  | 
