]> git.mxchange.org Git - flightgear.git/blob - src/ATCDCL/atis.hxx
Merge branch 'next' of gitorious.org:fg/flightgear into next
[flightgear.git] / src / ATCDCL / atis.hxx
1 // atis.hxx -- ATIS class
2 //
3 // Written by David Luff, started October 2001.
4 // Based on nav.hxx by Curtis Olson, started April 2000.
5 //
6 // Copyright (C) 2001  David C. Luff - david.luff@nottingham.ac.uk
7 //
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.
12 //
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.
17 //
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., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
21
22
23 #ifndef _FG_ATIS_HXX
24 #define _FG_ATIS_HXX
25
26 #include <string>
27 #include <iosfwd>
28
29 #include <simgear/compiler.h>
30 #include <simgear/timing/sg_time.hxx>
31
32 #include "ATC.hxx"
33
34 //DCL - a complete guess for now.
35 #define FG_ATIS_DEFAULT_RANGE 30
36         
37 typedef std::map<std::string,std::string> MSS;
38
39 class FGATIS : public FGATC {
40         
41         //atc_type type;
42         std::string transmission;       // The actual ATIS transmission
43         // This is not stored in default.atis but is generated
44         // from the prevailing conditions when required.
45         
46         // for failure modeling
47         std::string trans_ident;                // transmitted ident
48         double old_volume;
49         bool atis_failed;               // atis failed?
50         time_t msg_time;                // for moderating error messages
51         time_t cur_time;
52         int msg_OK;
53         int attention;
54         
55         bool _prev_display;             // Previous value of _display flag
56         MSS _remap;                     // abbreviations to be expanded
57
58         // Aircraft position
59         // ATIS is actually a special case in that unlike other ATC eg.tower it doesn't actually know about
60         // or the whereabouts of the aircraft it is transmitting to.  However, to ensure consistancy of
61         // operation with the other ATC classes the ATIS class must calculate range to the aircraft in order
62         // to decide whether to render the transmission - hence the users plane details must be stored.
63         //SGPropertyNode_ptr airplane_lon_node; 
64         //SGPropertyNode_ptr airplane_lat_node;
65         //SGPropertyNode_ptr airplane_elev_node; 
66         
67         public:
68         
69         FGATIS(void);
70         ~FGATIS(void);
71         virtual void Init();
72         void attend (int);
73
74         //run the ATIS instance
75         void Update(double dt);
76         
77         //inline void set_type(const atc_type tp) {type = tp;}
78         inline const std::string& get_trans_ident() { return trans_ident; }
79         inline void set_refname(const std::string& r) { refname = r; } 
80         
81         private:
82         
83         std::string refname;            // Holds the refname of a transmission in progress
84         
85         int GenTransmission(const int regen, 
86                 const int special);             // Generate the transmission string
87         
88         friend std::istream& operator>> ( std::istream&, FGATIS& );
89 };
90
91 typedef int (FGATIS::*int_getter)() const;
92
93 #endif // _FG_ATIS_HXX