|
GNU Radio 3.6.5 C++ API
|
#include <tagged_stream_mux_impl.h>

Public Member Functions | |
| tagged_stream_mux_impl (size_t itemsize, const std::string &lengthtagname) | |
| ~tagged_stream_mux_impl () | |
| int | work (int noutput_items, gr_vector_int &ninput_items, gr_vector_const_void_star &input_items, gr_vector_void_star &output_items) |
| Just like gr_block::general_work, but makes sure the input is valid. More... | |
Protected Member Functions | |
| int | calculate_output_stream_length (const std::vector< int > &ninput_items) |
| Calculate the number of output items. More... | |
Additional Inherited Members | |
Public Types inherited from gr::blocks::tagged_stream_mux | |
| typedef boost::shared_ptr < tagged_stream_mux > | sptr |
Static Public Member Functions inherited from gr::blocks::tagged_stream_mux | |
| static sptr | make (size_t itemsize, const std::string &lengthtagname) |
Protected Types inherited from gr_basic_block | |
| enum | vcolor { WHITE, GREY, BLACK } |
Protected Attributes inherited from gr_tagged_stream_block | |
| std::string | d_length_tag_key_str |
| gr::blocks::tagged_stream_mux_impl::tagged_stream_mux_impl | ( | size_t | itemsize, |
| const std::string & | lengthtagname | ||
| ) |
| gr::blocks::tagged_stream_mux_impl::~tagged_stream_mux_impl | ( | ) |
|
protectedvirtual |
Calculate the number of output items.
This is basically the inverse function to forecast(): Given a number of input items, it returns the maximum number of output items.
You most likely need to override this function, unless your block is a sync block or integer interpolator/decimator.
Reimplemented from gr_tagged_stream_block.
|
virtual |
Just like gr_block::general_work, but makes sure the input is valid.
The user must override work to define the signal processing code. Check the documentation for general_work() to see what happens here.
Like gr_sync_block, this calls consume() for you (it consumes ninput_items[i] items from the i-th port).
A note on tag propagation: The PDU length tags are handled by other functions, but all other tags are handled just as in any other gr_block. So, most likely, you either set the tag propagation policy to TPP_DONT and handle the tag propagation manually, or you propagate tags through the scheduler and don't do anything here.
| noutput_items | The size of the writable output buffer |
| ninput_items | The exact size of the items on every input for this particular PDU. These will be consumed if a length tag key is provided! |
| input_items | See gr_block |
| output_items | See gr_block |
Implements gr_tagged_stream_block.