23#ifndef GNSS_SDR_GNSS_BLOCK_INTERFACE_H
24#define GNSS_SDR_GNSS_BLOCK_INTERFACE_H
26#include <gnuradio/top_block.h>
37#if GNURADIO_USES_STD_POINTERS
40using gnss_shared_ptr = std::shared_ptr<T>;
41template <
typename C,
typename... Args>
42gnss_shared_ptr<C> gnss_make_shared(Args &&... args)
44 return std::make_shared<C>(std::forward<Args>(args)...);
47#include <boost/make_shared.hpp>
48#include <boost/shared_ptr.hpp>
50using gnss_shared_ptr = boost::shared_ptr<T>;
51template <
typename C,
typename... Args>
52gnss_shared_ptr<C> gnss_make_shared(Args &&... args)
54 return boost::make_shared<C>(std::forward<Args>(args)...);
72 virtual std::string role() = 0;
73 virtual std::string implementation() = 0;
74 virtual size_t item_size() = 0;
75 virtual void connect(gr::top_block_sptr top_block) = 0;
76 virtual void disconnect(gr::top_block_sptr top_block) = 0;
78 virtual gr::basic_block_sptr get_left_block() = 0;
79 virtual gr::basic_block_sptr get_right_block() = 0;
81 virtual gr::basic_block_sptr get_left_block(
int RF_channel)
83 assert(RF_channel >= 0);
89 virtual gr::basic_block_sptr get_right_block(
int RF_channel)
91 assert(RF_channel >= 0);
This abstract class represents an interface to GNSS blocks.
virtual void start()
Start the flow of samples if needed.