X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=src%2FNetwork%2Fnative.cxx;h=0057040537e30b8450a46e80afc373b3fc60efc5;hb=4be1661305609819703015360b79bbb7e4ae87d6;hp=07da1e73cb739c66d811f4dc77b77eee95d674e3;hpb=32528d0cd65eb1aec904f25b692b2f961c028bfa;p=flightgear.git diff --git a/src/Network/native.cxx b/src/Network/native.cxx index 07da1e73c..005704053 100644 --- a/src/Network/native.cxx +++ b/src/Network/native.cxx @@ -2,7 +2,7 @@ // // Written by Curtis Olson, started November 1999. // -// Copyright (C) 1999 Curtis L. Olson - curt@flightgear.org +// Copyright (C) 1999 Curtis L. Olson - http://www.flightgear.org/~curt // // This program is free software; you can redistribute it and/or // modify it under the terms of the GNU General Public License as @@ -16,16 +16,20 @@ // // 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. +// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // // $Id$ +#ifdef HAVE_CONFIG_H +# include +#endif #include #include #include "native.hxx" +#include FGNative::FGNative() { } @@ -37,7 +41,7 @@ FGNative::~FGNative() { // open hailing frequencies bool FGNative::open() { if ( is_enabled() ) { - FG_LOG( FG_IO, FG_ALERT, "This shouldn't happen, but the channel " + SG_LOG( SG_IO, SG_ALERT, "This shouldn't happen, but the channel " << "is already in use, ignoring" ); return false; } @@ -45,7 +49,7 @@ bool FGNative::open() { SGIOChannel *io = get_io_channel(); if ( ! io->open( get_direction() ) ) { - FG_LOG( FG_IO, FG_ALERT, "Error opening channel communication layer." ); + SG_LOG( SG_IO, SG_ALERT, "Error opening channel communication layer." ); return false; } @@ -54,29 +58,35 @@ bool FGNative::open() { return true; } +/** + * The design of FGNative requires direct, memcpy access to FGInterface, + * unfortunately. Since this is the only remaining place that does, the + * extern lives here, rather than a header file. + * + */ +extern FGInterface* evil_global_fdm_state; // process work for this port bool FGNative::process() { SGIOChannel *io = get_io_channel(); - int length = sizeof(*cur_fdm_state); + int length = sizeof(FGInterface); if ( get_direction() == SG_IO_OUT ) { - // cout << "size of cur_fdm_state = " << length << endl; - buf = *cur_fdm_state; + buf = *evil_global_fdm_state; if ( ! io->write( (char *)(& buf), length ) ) { - FG_LOG( FG_IO, FG_ALERT, "Error writing data." ); + SG_LOG( SG_IO, SG_ALERT, "Error writing data." ); return false; } } else if ( get_direction() == SG_IO_IN ) { if ( io->get_type() == sgFileType ) { if ( io->read( (char *)(& buf), length ) == length ) { - FG_LOG( FG_IO, FG_ALERT, "Success reading data." ); - *cur_fdm_state = buf; + SG_LOG( SG_IO, SG_DEBUG, "Success reading data." ); + *evil_global_fdm_state = buf; } } else { while ( io->read( (char *)(& buf), length ) == length ) { - FG_LOG( FG_IO, FG_ALERT, "Success reading data." ); - *cur_fdm_state = buf; + SG_LOG( SG_IO, SG_DEBUG, "Success reading data." ); + *evil_global_fdm_state = buf; } } }