X-Git-Url: http://git.kpe.io/?p=ctsim.git;a=blobdiff_plain;f=include%2Ffnetorderstream.h;h=158bc3c63984f4590cbac4f9232be0958afa742a;hp=b682105b9dfecb322a6f06163148193e5b67a7db;hb=8a7697ce57b56cdc43698cd1241ad98d49f9b5ac;hpb=f313b7708626e8900c4eeea6cf73d4507057a1c6 diff --git a/include/fnetorderstream.h b/include/fnetorderstream.h index b682105..158bc3c 100644 --- a/include/fnetorderstream.h +++ b/include/fnetorderstream.h @@ -1,3 +1,31 @@ +/***************************************************************************** +** FILE IDENTIFICATION +** +** Name: fnetorderstream.h +** Purpose: Network-order file stream header +** Programmer: Kevin Rosenberg +** Date Started: Sep 2000 +** +** This is part of the CTSim program +** Copyright (c) 1983-2001 Kevin Rosenberg +** +** $Id$ +** +** This program is free software; you can redistribute it and/or modify +** it under the terms of the GNU General Public License (version 2) as +** published by the Free Software Foundation. +** +** 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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA +******************************************************************************/ + + #ifndef NETORDER_H #define NETORDER_H @@ -8,7 +36,6 @@ #include #include #include -using namespace std; inline bool NativeBigEndian (void) @@ -61,15 +88,38 @@ SwapBytes8 (void* buffer) p[4] = temp; } +inline void +SwapBytes2IfLittleEndian (void* buffer) +{ +#ifndef WORDS_BIGENDIAN + SwapBytes2 (buffer); +#endif +} + +inline void +SwapBytes4IfLittleEndian (void* buffer) +{ +#ifndef WORDS_BIGENDIAN + SwapBytes4 (buffer); +#endif +} + +inline void +SwapBytes8IfLittleEndian (void* buffer) +{ +#ifndef WORDS_BIGENDIAN + SwapBytes8 (buffer); +#endif +} void ConvertNetworkOrder (void* buffer, size_t bytes); void ConvertReverseNetworkOrder (void* buffer, size_t bytes); - +using std::fstream; class fnetorderstream : public fstream { public: - fnetorderstream (const char* filename, int mode) - : fstream (filename, mode) {} + fnetorderstream (const char* filename, std::ios::openmode mode) + : fstream (filename, mode) {} ~fnetorderstream (void) {} @@ -88,7 +138,7 @@ class fnetorderstream : public fstream { class frnetorderstream : public fnetorderstream { public: - frnetorderstream (const char* filename, int mode) + frnetorderstream (const char* filename, std::ios::openmode mode) : fnetorderstream (filename, mode) {} virtual void writeInt16 (kuint16 n);