// net_fdm_mini.hxx -- defines a simple subset I/O interface to the flight // dynamics model variables // // Written by Curtis Olson, started January 2002. // // Copyright (C) 2002 Curtis L. Olson - curt@flightgear.com // // This program is free software; you can redistribute it and/or // modify it under the terms of the GNU General Public License as // published by the Free Software Foundation; either version 2 of the // License, or (at your option) any later version. // // This program is distributed in the hope that it will be useful, but // WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // General Public License for more details. // // You should have received a copy of the GNU General Public License // along with this program; if not, write to the Free Software // Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. // // $Id$ #ifndef _NET_FDM_MINI_HXX #define _NET_FDM_MINI_HXX #ifndef __cplusplus # error This library requires C++ #endif const int FG_NET_FDM_MINI_VERSION = 1; // Define a structure containing the top level flight dynamics model // parameters class FGNetMiniFDM { public: enum { FG_MAX_ENGINES = 4, FG_MAX_WHEELS = 3, FG_MAX_TANKS = 4 }; int version; // increment when data values change int pad; // keep doubles 64-bit aligned for some // hardware platforms, such as the Sun // SPARC, which don't like misaligned // data // Positions double longitude; // geodetic (radians) double latitude; // geodetic (radians) double altitude; // above sea level (meters) double agl; // above ground level (meters) double phi; // roll (radians) double theta; // pitch (radians) double psi; // yaw or true heading (radians) // Consumables int num_tanks; // Max number of fuel tanks double fuel_quantity[FG_MAX_TANKS]; // Environment time_t cur_time; // current unix time long int warp; // offset in seconds to unix time }; #endif // _NET_FDM_MINI_HXX