GNU Radio's GSM Package
extract_system_info.h
Go to the documentation of this file.
1/* -*- c++ -*- */
2/*
3 * @file
4 * @author (C) 2014 by Piotr Krysik <ptrkrysik@gmail.com>
5 * @section LICENSE
6 *
7 * Gr-gsm is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License as published by
9 * the Free Software Foundation; either version 3, or (at your option)
10 * any later version.
11 *
12 * Gr-gsm is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU General Public License for more details.
16 *
17 * You should have received a copy of the GNU General Public License
18 * along with gr-gsm; see the file COPYING. If not, write to
19 * the Free Software Foundation, Inc., 51 Franklin Street,
20 * Boston, MA 02110-1301, USA.
21 */
22
23
24#ifndef INCLUDED_GSM_EXTRACT_SYSTEM_INFO_H
25#define INCLUDED_GSM_EXTRACT_SYSTEM_INFO_H
26
27#include <gsm/api.h>
28#include <gnuradio/block.h>
29#include <vector>
30
31namespace gr {
32 namespace gsm {
33
34 /*!
35 * \brief <+description of block+>
36 * \ingroup gsm
37 *
38 */
39 class GSM_API extract_system_info : virtual public gr::block
40 {
41 public:
42 typedef std::shared_ptr<extract_system_info> sptr;
43
44 /*!
45 * \brief Return a shared_ptr to a new instance of gsm::extract_system_info.
46 *
47 * To avoid accidental use of raw pointers, gsm::extract_system_info's
48 * constructor is in a private implementation
49 * class. gsm::extract_system_info::make is the public interface for
50 * creating new instances.
51 */
52 static sptr make();
53 virtual std::vector<int> get_chans() = 0;
54 virtual std::vector<int> get_pwrs() = 0;
55 virtual std::vector<int> get_lac() = 0;
56 virtual std::vector<int> get_cell_id() = 0;
57 virtual std::vector<int> get_mcc() = 0;
58 virtual std::vector<int> get_mnc() = 0;
59 virtual std::vector<int> get_ccch_conf() = 0;
60 virtual std::vector<int> get_cell_arfcns(int chan_id) = 0;
61 virtual std::vector<int> get_neighbours(int chan_id) = 0;
62 virtual void reset() = 0;
63 };
64
65 } // namespace gsm
66} // namespace gr
67
68#endif /* INCLUDED_GSM_EXTRACT_SYSTEM_INFO_H */
69
#define GSM_API
Definition api.h:19
<+description of block+>
Definition extract_system_info.h:40
virtual std::vector< int > get_lac()=0
virtual std::vector< int > get_cell_arfcns(int chan_id)=0
virtual std::vector< int > get_mcc()=0
virtual std::vector< int > get_neighbours(int chan_id)=0
virtual std::vector< int > get_mnc()=0
std::shared_ptr< extract_system_info > sptr
Definition extract_system_info.h:42
virtual std::vector< int > get_cell_id()=0
virtual std::vector< int > get_pwrs()=0
virtual std::vector< int > get_ccch_conf()=0
virtual std::vector< int > get_chans()=0
static sptr make()
Return a shared_ptr to a new instance of gsm::extract_system_info.
Definition constants.h:29