]> git.mxchange.org Git - flightgear.git/blob - Aircraft/aircraft.cxx
Converted to new logstream debugging facility. This allows release
[flightgear.git] / Aircraft / aircraft.cxx
1 // aircraft.cxx -- various aircraft routines
2 //
3 // Written by Curtis Olson, started May 1997.
4 //
5 // Copyright (C) 1997  Curtis L. Olson  - curt@infoplane.com
6 //
7 // This program is free software; you can redistribute it and/or
8 // modify it under the terms of the GNU General Public License as
9 // published by the Free Software Foundation; either version 2 of the
10 // License, or (at your option) any later version.
11 //
12 // This program is distributed in the hope that it will be useful, but
13 // WITHOUT ANY WARRANTY; without even the implied warranty of
14 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
15 // General Public License for more details.
16 //
17 // You should have received a copy of the GNU General Public License
18 // along with this program; if not, write to the Free Software
19 // Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
20 //
21 // $Id$
22 // (Log is kept at end of this file)
23
24
25 #include <stdio.h>
26
27 #include "aircraft.hxx"
28 #include <Debug/logstream.hxx>
29 #include <Include/fg_constants.h>
30
31 // This is a record containing all the info for the aircraft currently
32 // being operated
33 fgAIRCRAFT current_aircraft;
34
35
36 // Initialize an Aircraft structure
37 void fgAircraftInit( void ) {
38     FG_LOG( FG_AIRCRAFT, FG_INFO, "Initializing Aircraft structure" );
39
40     current_aircraft.flight   = &cur_flight_params;
41     current_aircraft.controls = &controls;
42 }
43
44
45 // Display various parameters to stdout
46 void fgAircraftOutputCurrent(fgAIRCRAFT *a) {
47     fgFLIGHT *f;
48
49     f = a->flight;
50
51     FG_LOG( FG_FLIGHT, FG_DEBUG,
52             "Pos = ("
53             << (FG_Longitude * 3600.0 * RAD_TO_DEG) << "," 
54             << (FG_Latitude  * 3600.0 * RAD_TO_DEG) << ","
55             << FG_Altitude 
56             << ")  (Phi,Theta,Psi)=("
57             << FG_Phi << "," << FG_Theta << "," << FG_Psi << ")" );
58
59     FG_LOG( FG_FLIGHT, FG_DEBUG,
60             "Kts = " << FG_V_equiv_kts 
61             << "  Elev = " << controls.get_elevator() 
62             << "  Aileron = " << controls.get_aileron() 
63             << "  Rudder = " << controls.get_rudder() 
64             << "  Power = " << controls.get_throttle( 0 ) );
65 }
66
67
68 // $Log$
69 // Revision 1.4  1998/11/06 21:17:31  curt
70 // Converted to new logstream debugging facility.  This allows release
71 // builds with no messages at all (and no performance impact) by using
72 // the -DFG_NDEBUG flag.
73 //
74 // Revision 1.3  1998/10/25 14:08:37  curt
75 // Turned "struct fgCONTROLS" into a class, with inlined accessor functions.
76 //
77 // Revision 1.2  1998/10/17 01:33:52  curt
78 // C++ ifying ...
79 //
80 // Revision 1.1  1998/10/16 23:26:47  curt
81 // C++-ifying.
82 //
83 // Revision 1.19  1998/04/25 22:06:24  curt
84 // Edited cvs log messages in source files ... bad bad bad!
85 //
86 // Revision 1.18  1998/04/18 04:13:56  curt
87 // Moved fg_debug.c to it's own library.
88 //
89 // Revision 1.17  1998/02/12 21:59:31  curt
90 // Incorporated code changes contributed by Charlie Hotchkiss
91 // <chotchkiss@namg.us.anritsu.com>
92 //
93 // Revision 1.16  1998/02/07 15:29:31  curt
94 // Incorporated HUD changes and struct/typedef changes from Charlie Hotchkiss
95 // <chotchkiss@namg.us.anritsu.com>
96 //
97 // Revision 1.15  1998/01/27 00:47:46  curt
98 // Incorporated Paul Bleisch's <pbleisch@acm.org> new debug message
99 // system and commandline/config file processing code.
100 //
101 // Revision 1.14  1998/01/19 19:26:56  curt
102 // Merged in make system changes from Bob Kuehne <rpk@sgi.com>
103 // This should simplify things tremendously.
104 //
105 // Revision 1.13  1997/12/15 23:54:30  curt
106 // Add xgl wrappers for debugging.
107 // Generate terrain normals on the fly.
108 //
109 // Revision 1.12  1997/12/10 22:37:37  curt
110 // Prepended "fg" on the name of all global structures that didn't have it yet.
111 // i.e. "struct WEATHER {}" became "struct fgWEATHER {}"
112 //
113 // Revision 1.11  1997/09/13 02:00:05  curt
114 // Mostly working on stars and generating sidereal time for accurate star
115 // placement.
116 //
117 // Revision 1.10  1997/08/27 03:29:56  curt
118 // Changed naming scheme of basic shared structures.
119 //
120 // Revision 1.9  1997/07/19 22:39:08  curt
121 // Moved PI to ../constants.h
122 //
123 // Revision 1.8  1997/06/25 15:39:45  curt
124 // Minor changes to compile with rsxnt/win32.
125 //
126 // Revision 1.7  1997/06/02 03:01:39  curt
127 // Working on views (side, front, back, transitions, etc.)
128 //
129 // Revision 1.6  1997/05/31 19:16:26  curt
130 // Elevator trim added.
131 //
132 // Revision 1.5  1997/05/30 19:30:14  curt
133 // The LaRCsim flight model is starting to look like it is working.
134 //
135 // Revision 1.4  1997/05/30 03:54:11  curt
136 // Made a bit more progress towards integrating the LaRCsim flight model.
137 //
138 // Revision 1.3  1997/05/29 22:39:56  curt
139 // Working on incorporating the LaRCsim flight model.
140 //
141 // Revision 1.2  1997/05/23 15:40:29  curt
142 // Added GNU copyright headers.
143 //
144 // Revision 1.1  1997/05/16 15:58:24  curt
145 // Initial revision.
146 //
147