//
// Copyright 2014-2015 Ettus Research LLC
//
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with this program.  If not, see .
//
#include 
#include 
using namespace uhd::rfnoc;
const double rate_node_ctrl::RATE_UNDEFINED = -1.0;
static double _get_input_samp_rate(rate_node_ctrl::sptr node, size_t port)
{
    return node->get_input_samp_rate(port);
}
static double _get_output_samp_rate(rate_node_ctrl::sptr node, size_t port)
{
    return node->get_output_samp_rate(port);
}
// FIXME add recursion limiters (i.e. list of explored nodes)
double rate_node_ctrl::get_input_samp_rate(
        size_t /* port */
) {
    try {
        return find_downstream_unique_property(
                boost::bind(_get_input_samp_rate, _1, _2),
                RATE_UNDEFINED
        );
    } catch (const uhd::runtime_error &ex) {
        throw uhd::runtime_error(str(
            boost::format("Multiple sampling rates downstream of %s: %s.")
            % unique_id() % ex.what()
        ));
    }
}
double rate_node_ctrl::get_output_samp_rate(
        size_t /* port */
) {
    try {
        return find_upstream_unique_property(
                boost::bind(_get_output_samp_rate, _1, _2),
                RATE_UNDEFINED
        );
    } catch (const uhd::runtime_error &ex) {
        throw uhd::runtime_error(str(
            boost::format("Multiple sampling rates upstream of %s: %s.")
            % unique_id() % ex.what()
        ));
    }
}