X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=src%2FNetwork%2Fnative.cxx;h=0057040537e30b8450a46e80afc373b3fc60efc5;hb=dc76290d6e7d2f24d6c352d8f9da4b0f9f1e5f40;hp=f60f0cc90ae308816e4bf2ed25c08f74aff9b2e2;hpb=0ffa19cd32c02405d0e740393b37f4009ed5a312;p=flightgear.git diff --git a/src/Network/native.cxx b/src/Network/native.cxx index f60f0cc90..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,17 +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 -#include "iochannel.hxx" #include "native.hxx" +#include FGNative::FGNative() { } @@ -38,15 +41,15 @@ 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; } - FGIOChannel *io = get_io_channel(); + 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; } @@ -55,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() { - FGIOChannel *io = get_io_channel(); - int length = sizeof(*cur_fdm_state); + SGIOChannel *io = get_io_channel(); + int length = sizeof(FGInterface); - if ( get_direction() == out ) { - // cout << "size of cur_fdm_state = " << length << endl; - buf = *cur_fdm_state; + if ( get_direction() == SG_IO_OUT ) { + 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() == in ) { - if ( io->get_type() == fgFileType ) { + } 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; } } } @@ -88,7 +97,7 @@ bool FGNative::process() { // close the channel bool FGNative::close() { - FGIOChannel *io = get_io_channel(); + SGIOChannel *io = get_io_channel(); set_enabled( false );