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 40 using gnss_shared_ptr = std::shared_ptr<T>;
41 template <
typename C,
typename... Args>
42 gnss_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> 50 using gnss_shared_ptr = boost::shared_ptr<T>;
51 template <
typename C,
typename... Args>
52 gnss_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);
107 #endif // GNSS_SDR_GNSS_BLOCK_INTERFACE_H virtual void start()
Start the flow of samples if needed.
This abstract class represents an interface to GNSS blocks.