blob: e87422d91625b70e1bcaa37dc1a27a405b14df05 [file] [log] [blame]
Roman Khassrafb8942892015-07-21 10:53:41 +02001/* -*- c++ -*- */
2/* @file
Piotr Krysika6268a52017-08-23 16:02:19 +02003 * @author (C) 2015 by Roman Khassraf <rkhassraf@gmail.com>
Roman Khassrafb8942892015-07-21 10:53:41 +02004 * @section LICENSE
5 *
6 * Gr-gsm is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; either version 3, or (at your option)
9 * any later version.
10 *
11 * Gr-gsm is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
15 *
16 * You should have received a copy of the GNU General Public License
17 * along with gr-gsm; see the file COPYING. If not, write to
18 * the Free Software Foundation, Inc., 51 Franklin Street,
19 * Boston, MA 02110-1301, USA.
20 *
21 */
22
Roman Khassraf1ce44692015-08-03 11:16:10 +020023#ifndef INCLUDED_GSM_BURST_SINK_IMPL_H
24#define INCLUDED_GSM_BURST_SINK_IMPL_H
Roman Khassrafb8942892015-07-21 10:53:41 +020025
Roman Khassraf1ce44692015-08-03 11:16:10 +020026#include <grgsm/qa_utils/burst_sink.h>
Roman Khassrafb8942892015-07-21 10:53:41 +020027#include <fstream>
28
29namespace gr {
30 namespace gsm {
31
Roman Khassraf1ce44692015-08-03 11:16:10 +020032 class burst_sink_impl : public burst_sink
Roman Khassrafb8942892015-07-21 10:53:41 +020033 {
34 private:
35 std::vector<int> d_framenumbers;
36 std::vector<int> d_timeslots;
37 std::vector<std::string> d_burst_data;
Piotr Krysikebf88802017-09-19 08:07:14 +020038 pmt::pmt_t d_bursts;
Roman Khassrafb8942892015-07-21 10:53:41 +020039 public:
Roman Khassraf1ce44692015-08-03 11:16:10 +020040 burst_sink_impl();
41 ~burst_sink_impl();
Roman Khassrafb8942892015-07-21 10:53:41 +020042 void process_burst(pmt::pmt_t msg);
43 virtual std::vector<int> get_framenumbers();
44 virtual std::vector<int> get_timeslots();
45 virtual std::vector<std::string> get_burst_data();
Piotr Krysikebf88802017-09-19 08:07:14 +020046 virtual pmt::pmt_t get_bursts();
Roman Khassrafb8942892015-07-21 10:53:41 +020047 };
48
49 } // namespace gsm
50} // namespace gr
51
Roman Khassraf1ce44692015-08-03 11:16:10 +020052#endif /* INCLUDED_GSM_BURST_SINK_IMPL_H */
Roman Khassrafb8942892015-07-21 10:53:41 +020053