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 <grgsm/api.h>
28 #include <gnuradio/block.h>
29 #include <vector>
30 
31 namespace gr {
32  namespace gsm {
33 
34  /*!
35  * \brief <+description of block+>
36  * \ingroup gsm
37  *
38  */
39  class GRGSM_API extract_system_info : virtual public gr::block
40  {
41  public:
42  typedef boost::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 
gr::gsm::extract_system_info::get_chans
virtual std::vector< int > get_chans()=0
gr::gsm::extract_system_info::get_cell_arfcns
virtual std::vector< int > get_cell_arfcns(int chan_id)=0
gr::gsm::extract_system_info::get_cell_id
virtual std::vector< int > get_cell_id()=0
gr::gsm::extract_system_info::sptr
boost::shared_ptr< extract_system_info > sptr
Definition: extract_system_info.h:42
gr::gsm::extract_system_info::get_mnc
virtual std::vector< int > get_mnc()=0
gr::gsm::extract_system_info::get_ccch_conf
virtual std::vector< int > get_ccch_conf()=0
gr::gsm::extract_system_info::get_pwrs
virtual std::vector< int > get_pwrs()=0
gr::gsm::extract_system_info::get_mcc
virtual std::vector< int > get_mcc()=0
gr::gsm::extract_system_info
<+description of block+>
Definition: extract_system_info.h:40
gr::gsm::extract_system_info::reset
virtual void reset()=0
gr
Definition: constants.h:29
gr::gsm::extract_system_info::get_lac
virtual std::vector< int > get_lac()=0
GRGSM_API
#define GRGSM_API
Definition: api.h:31
gr::gsm::extract_system_info::get_neighbours
virtual std::vector< int > get_neighbours(int chan_id)=0
gr::gsm::extract_system_info::make
static sptr make()
Return a shared_ptr to a new instance of gsm::extract_system_info.
api.h