1 // AIMgr.hxx - definition of FGAIMgr
2 // - a global management class for FlightGear generated AI traffic
4 // Written by David Luff, started March 2002.
6 // Copyright (C) 2002 David C Luff - david.luff@nottingham.ac.uk
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.
22 /*****************************************************************
24 * WARNING - Curt has some ideas about AI traffic so anything in here
25 * may get rewritten or scrapped. Contact Curt curt@flightgear.org
26 * before spending any time or effort on this code!!!
28 ******************************************************************/
33 #include <Main/fgfs.hxx>
34 #include <Main/fg_props.hxx>
38 #include "AIEntity.hxx"
42 class FGAIMgr : public FGSubsystem
47 // A list of pointers to all currently active AI stuff
48 typedef list <FGAIEntity*> ai_list_type;
49 typedef ai_list_type::iterator ai_list_iterator;
50 typedef ai_list_type::const_iterator ai_list_const_iterator;
52 // Everything put in this list should be created dynamically
53 // on the heap and ***DELETED WHEN REMOVED!!!!!***
55 ai_list_iterator ai_list_itr;
56 // Any member function of FGATCMgr is permitted to leave this iterator pointing
57 // at any point in or at the end of the list.
58 // Hence any new access must explicitly first check for atc_list.end() before dereferencing.
60 // Position of the Users Aircraft
61 // (This may be needed to calculate the distance from the user when deciding which 3D model to render)
65 // Pointers to current users position
66 SGPropertyNode *current_lon_node;
67 SGPropertyNode *current_lat_node;
68 SGPropertyNode *current_elev_node;
73 //FGApproach approach;
74 //FGDeparture departure;
87 void update(double dt);
91 // Remove a class from the ai_list and delete it from memory
92 //void RemoveFromList(const char* id, atc_type tp);
96 #endif // _FG_AIMGR_HXX