GNU Radio Radar Toolbox
split_cc_impl.h
Go to the documentation of this file.
1 /* -*- c++ -*- */
2 /*
3  * Copyright 2014 Communications Engineering Lab, KIT.
4  *
5  * This is free software; you can redistribute it and/or modify
6  * it under the terms of the GNU General Public License as published by
7  * the Free Software Foundation; either version 3, or (at your option)
8  * any later version.
9  *
10  * This software is distributed in the hope that it will be useful,
11  * but WITHOUT ANY WARRANTY; without even the implied warranty of
12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13  * GNU General Public License for more details.
14  *
15  * You should have received a copy of the GNU General Public License
16  * along with this software; see the file COPYING. If not, write to
17  * the Free Software Foundation, Inc., 51 Franklin Street,
18  * Boston, MA 02110-1301, USA.
19  */
20 
21 #ifndef INCLUDED_RADAR_SPLIT_CC_IMPL_H
22 #define INCLUDED_RADAR_SPLIT_CC_IMPL_H
23 
24 #include <radar/split_cc.h>
25 
26 namespace gr {
27 namespace radar {
28 
29 class split_cc_impl : public split_cc
30 {
31 private:
32  // Nothing to declare in this block.
33 
34 protected:
35  int calculate_output_stream_length(const gr_vector_int& ninput_items);
36 
37 public:
38  split_cc_impl(int packet_num,
39  const std::vector<int> packet_parts,
40  const std::string& len_key);
42 
44  std::vector<int> d_packet_parts;
45  std::vector<tag_t> d_tags;
46 
47  // Where all the action really happens
48  int work(int noutput_items,
49  gr_vector_int& ninput_items,
50  gr_vector_const_void_star& input_items,
51  gr_vector_void_star& output_items);
52 };
53 
54 } // namespace radar
55 } // namespace gr
56 
57 #endif /* INCLUDED_RADAR_SPLIT_CC_IMPL_H */
Definition: split_cc_impl.h:30
std::vector< tag_t > d_tags
Definition: split_cc_impl.h:45
split_cc_impl(int packet_num, const std::vector< int > packet_parts, const std::string &len_key)
std::vector< int > d_packet_parts
Definition: split_cc_impl.h:44
int calculate_output_stream_length(const gr_vector_int &ninput_items)
int d_offset
Definition: split_cc_impl.h:43
int work(int noutput_items, gr_vector_int &ninput_items, gr_vector_const_void_star &input_items, gr_vector_void_star &output_items)
int d_packet_num
Definition: split_cc_impl.h:43
This block splits a tagged stream into segments. As packet_parts you give the structure of the packet...
Definition: split_cc.h:44
Definition: crop_matrix_vcvc.h:28