From e0fb3518db373a0f5a6d49711c11610ffc648c90 Mon Sep 17 00:00:00 2001 From: Carles Fernandez Date: Sun, 18 Nov 2018 13:29:54 +0100 Subject: [PATCH] Restore old behavior to gnss_valve if the same constructor is used (Fix tests) --- src/algorithms/libs/gnss_sdr_valve.cc | 23 ++++++++++++++--------- src/algorithms/libs/gnss_sdr_valve.h | 3 ++- 2 files changed, 16 insertions(+), 10 deletions(-) diff --git a/src/algorithms/libs/gnss_sdr_valve.cc b/src/algorithms/libs/gnss_sdr_valve.cc index 3b8b3a56d..c8d0e1385 100644 --- a/src/algorithms/libs/gnss_sdr_valve.cc +++ b/src/algorithms/libs/gnss_sdr_valve.cc @@ -40,13 +40,14 @@ gnss_sdr_valve::gnss_sdr_valve(size_t sizeof_stream_item, unsigned long long nitems, - gr::msg_queue::sptr queue, bool stop_flowgraph) : gr::sync_block("valve", - gr::io_signature::make(1, 1, sizeof_stream_item), - gr::io_signature::make(1, 1, sizeof_stream_item)), - d_nitems(nitems), - d_ncopied_items(0), - d_queue(queue), - d_stop_flowgraph(stop_flowgraph) + gr::msg_queue::sptr queue, + bool stop_flowgraph) : gr::sync_block("valve", + gr::io_signature::make(1, 1, sizeof_stream_item), + gr::io_signature::make(1, 1, sizeof_stream_item)), + d_nitems(nitems), + d_ncopied_items(0), + d_queue(queue), + d_stop_flowgraph(stop_flowgraph) { d_open_valve = false; } @@ -58,16 +59,20 @@ boost::shared_ptr gnss_sdr_make_valve(size_t sizeof_stream_item, unsi return valve_; } + boost::shared_ptr gnss_sdr_make_valve(size_t sizeof_stream_item, unsigned long long nitems, gr::msg_queue::sptr queue) { - boost::shared_ptr valve_(new gnss_sdr_valve(sizeof_stream_item, nitems, queue, false)); + boost::shared_ptr valve_(new gnss_sdr_valve(sizeof_stream_item, nitems, queue, true)); return valve_; } + void gnss_sdr_valve::open_valve() { d_open_valve = true; } + + int gnss_sdr_valve::work(int noutput_items, gr_vector_const_void_star &input_items, gr_vector_void_star &output_items) @@ -87,7 +92,7 @@ int gnss_sdr_valve::work(int noutput_items, else { usleep(1000000); - return 0; //do not produce or consume + return 0; // do not produce or consume } } unsigned long long n = std::min(d_nitems - d_ncopied_items, static_cast(noutput_items)); diff --git a/src/algorithms/libs/gnss_sdr_valve.h b/src/algorithms/libs/gnss_sdr_valve.h index 32d17fd89..8fe7140b6 100644 --- a/src/algorithms/libs/gnss_sdr_valve.h +++ b/src/algorithms/libs/gnss_sdr_valve.h @@ -41,10 +41,12 @@ boost::shared_ptr gnss_sdr_make_valve(size_t sizeof_stream_item, unsigned long long nitems, gr::msg_queue::sptr queue); + boost::shared_ptr gnss_sdr_make_valve(size_t sizeof_stream_item, unsigned long long nitems, gr::msg_queue::sptr queue, bool stop_flowgraph); + /*! * \brief Implementation of a GNU Radio block that sends a STOP message to the * control queue right after a specific number of samples have passed through it. @@ -59,7 +61,6 @@ class gnss_sdr_valve : public gr::sync_block gr::msg_queue::sptr queue, bool stop_flowgraph); - unsigned long long d_nitems; unsigned long long d_ncopied_items; gr::msg_queue::sptr d_queue;