1 // atislist.hxx -- atis management class
3 // Written by David Luff, started October 2001.
4 // Based on navlist.hxx by Curtis Olson, started April 2000.
6 // Copyright (C) 2000 Curtis L. Olson - curt@flightgear.org
8 // This program is free software; you can redistribute it and/or
9 // modify it under the terms of the GNU General Public License as
10 // published by the Free Software Foundation; either version 2 of the
11 // License, or (at your option) any later version.
13 // This program is distributed in the hope that it will be useful, but
14 // WITHOUT ANY WARRANTY; without even the implied warranty of
15 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16 // General Public License for more details.
18 // You should have received a copy of the GNU General Public License
19 // along with this program; if not, write to the Free Software
20 // Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
23 #ifndef _FG_ATISLIST_HXX
24 #define _FG_ATISLIST_HXX
27 #include <simgear/compiler.h>
28 #include <simgear/misc/sg_path.hxx>
44 typedef vector < FGATIS > atis_list_type;
45 typedef atis_list_type::iterator atis_list_iterator;
46 typedef atis_list_type::const_iterator atis_list_const_iterator;
48 // typedef map < int, atis_list_type, less<int> > atis_map_type;
49 typedef map < int, atis_list_type > atis_map_type;
50 typedef atis_map_type::iterator atis_map_iterator;
51 typedef atis_map_type::const_iterator atis_map_const_iterator;
53 atis_map_type atislist;
55 // Add structure and map for storing a log of atis transmissions
56 // made in this session of FlightGear. This allows the callsign
57 // to be allocated correctly wrt time.
62 } atis_transmission_type;
64 typedef map < string, atis_transmission_type > atis_log_type;
65 typedef atis_log_type::iterator atis_log_iterator;
66 typedef atis_log_type::const_iterator atis_log_const_iterator;
68 atis_log_type atislog;
75 // load all atis and build the map
76 bool init( SGPath path );
78 // query the database for the specified frequency, lon and lat are
79 // in degrees, elev is in meters
80 bool query( double lon, double lat, double elev, double freq, FGATIS *a );
82 // Return the callsign for a transmission given transmission time and airpord id
83 int GetCallSign( string apt_id, int hours, int mins );
87 extern FGATISList *current_atislist;
90 #endif // _FG_ATISLIST_HXX