// save.cxx -- class to save and restore a flight. // // Written by Curtis Olson, started November 1999. // // Copyright (C) 1999 David Megginson - david@megginson.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$ /* TODO: - use a separate options object so that we can roll back on error - use proper FGFS logging - add view direction, and other stuff */ #ifdef HAVE_CONFIG_H # include #endif #include #include #include #include "bfi.hxx" FG_USING_NAMESPACE(std); #define SAVE(name, value) { output << name << ": " << value << endl; } /** * Save the current state of the simulator to a stream. */ bool fgSaveFlight (ostream &output) { output << "#!fgfs" << endl; // // Simulation // SAVE("flight-model", FGBFI::getFlightModel()); SAVE("time", FGBFI::getTimeGMT()); SAVE("hud", FGBFI::getHUDVisible()); SAVE("panel", FGBFI::getPanelVisible()); // // Location // SAVE("latitude", FGBFI::getLatitude()); SAVE("longitude", FGBFI::getLongitude()); SAVE("altitude", FGBFI::getAltitude()); // // Orientation // SAVE("heading", FGBFI::getHeading()); SAVE("pitch", FGBFI::getPitch()); SAVE("roll", FGBFI::getRoll()); // // Velocities // SAVE("speed-north", FGBFI::getSpeedNorth()); SAVE("speed-east", FGBFI::getSpeedEast()); SAVE("speed-down", FGBFI::getSpeedDown()); // // Primary controls // SAVE("elevator", FGBFI::getElevator()); SAVE("aileron", FGBFI::getAileron()); SAVE("rudder", FGBFI::getRudder()); // FIXME: save each throttle separately SAVE("throttle", FGBFI::getThrottle()); // // Secondary controls // SAVE("elevator-trim", FGBFI::getElevatorTrim()); SAVE("flaps", FGBFI::getFlaps()); // FIXME: save each brake separately SAVE("brake", FGBFI::getBrake()); // // Navigation. // if (FGBFI::getTargetAirport().length() > 0) { SAVE("target-airport", FGBFI::getTargetAirport()); } SAVE("autopilot-altitude-lock", FGBFI::getAPAltitudeLock()); SAVE("autopilot-altitude", FGBFI::getAPAltitude()); SAVE("autopilot-heading-lock", FGBFI::getAPHeadingLock()); SAVE("autopilot-heading", FGBFI::getAPHeading()); SAVE("autopilot-gps-lock", FGBFI::getGPSLock()); SAVE("autopilot-gps-lat", FGBFI::getGPSTargetLatitude()); SAVE("autopilot-gps-lon", FGBFI::getGPSTargetLongitude()); // // Environment. // SAVE("visibility", FGBFI::getVisibility()); return true; } /** * Restore the current state of the simulator from a stream. */ bool fgLoadFlight (istream &input) { // FGInterface * f = current_aircraft.fdm_state; string text; double n; long int i; if (!input.good() || input.eof()) { cout << "Stream is no good!\n"; return false; } input >> text; if (text != "#!fgfs") { cerr << "Bad save file format!\n"; return false; } while (input.good() && !input.eof()) { input >> text; // // Simulation. // if (text == "flight-model:") { input >> i; cout << "flight model is " << i << endl; FGBFI::setFlightModel(i); } else if (text == "time:") { input >> i; cout << "saved time is " << i << endl; FGBFI::setTimeGMT(i); } else if (text == "hud:") { input >> i; cout << "hud status is " << i << endl; FGBFI::setHUDVisible(i); } else if (text == "panel:") { input >> i; cout << "panel status is " << i << endl; FGBFI::setPanelVisible(i); } // // Location // else if (text == "latitude:") { input >> n; cout << "latitude is " << n << endl; FGBFI::setLatitude(n); } else if (text == "longitude:") { input >> n; cout << "longitude is " << n << endl; FGBFI::setLongitude(n); } else if (text == "altitude:") { input >> n; cout << "altitude is " << n << endl; FGBFI::setAltitude(n); } // // Orientation // else if (text == "heading:") { input >> n; cout << "heading is " << n << endl; FGBFI::setHeading(n); } else if (text == "pitch:") { input >> n; cout << "pitch is " << n << endl; FGBFI::setPitch(n); } else if (text == "roll:") { input >> n; cout << "roll is " << n << endl; FGBFI::setRoll(n); } // // Velocities // else if (text == "speed-north:") { input >> n; cout << "speed north is " << n << endl; FGBFI::setSpeedNorth(n); } else if (text == "speed-east:") { input >> n; cout << "speed east is " << n << endl; FGBFI::setSpeedEast(n); } else if (text == "speed-down:") { input >> n; cout << "speed down is " << n << endl; FGBFI::setSpeedDown(n); } // // Primary controls // else if (text == "elevator:") { input >> n; cout << "elevator is " << n << endl; FGBFI::setElevator(n); } else if (text == "aileron:") { input >> n; cout << "aileron is " << n << endl; FGBFI::setAileron(n); } else if (text == "rudder:") { input >> n; cout << "rudder is " << n << endl; FGBFI::setRudder(n); } // FIXME: assumes single engine else if (text == "throttle:") { input >> n; cout << "throttle is " << n << endl; FGBFI::setThrottle(n); } // // Secondary controls else if (text == "elevator-trim:") { input >> n; cout << "elevator trim is " << n << endl; FGBFI::setElevatorTrim(n); } else if (text == "flaps:") { input >> n; cout << "flaps are " << n << endl; FGBFI::setFlaps(n); } else if (text == "brake:") { input >> n; cout << "brake is " << n << endl; FGBFI::setBrake(n); } // // Navigation. // else if (text == "target-airport:") { input >> text; cout << "target airport is " << text << endl; FGBFI::setTargetAirport(text); } else if (text == "autopilot-altitude-lock:") { input >> i; cout << "autopilot altitude lock is " << i << endl; FGBFI::setAPAltitudeLock(i); } else if (text == "autopilot-altitude:") { input >> n; cout << "autopilot altitude is " << n << endl; FGBFI::setAPAltitude(n); } else if (text == "autopilot-heading-lock:") { input >> i; cout << "autopilot heading lock is " << i << endl; FGBFI::setAPHeadingLock(i); } else if (text == "autopilot-heading:") { input >> n; cout << "autopilot heading is " << n << endl; FGBFI::setAPHeading(n); } else if (text == "autopilot-gps-lock:") { input >> i; cout << "autopilot GPS lock is " << i << endl; FGBFI::setGPSLock(i); } else if (text == "autopilot-gps-lat:") { input >> n; cout << "GPS target latitude is " << n << endl; FGBFI::setGPSTargetLatitude(n); } else if (text == "autopilot-gps-lon:") { input >> n; cout << "GPS target longitude is " << n << endl; FGBFI::setGPSTargetLongitude(n); } // // Environment. // else if (text == "visibility:") { input >> n; cout << "visibility is " << n << endl; FGBFI::setVisibility(n); } // // Don't die if we don't recognize something // else { cerr << "Skipping unknown field: " << text << endl; input >> text; } } FGBFI::update(); return true; } // end of save.cxx