X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=simgear%2Fio%2Flowlevel.cxx;h=74b9f93b368f7230ee5a2a77f4415e2bdd29baf0;hb=aefe9bc11682f39b3936b9f01a0d37e9d6428078;hp=19909b7d5e9d2d2f07f329e846f54e30427728ba;hpb=dcb95d131bc6aef1abe25d1f415e309f06e52436;p=simgear.git diff --git a/simgear/io/lowlevel.cxx b/simgear/io/lowlevel.cxx index 19909b7d..74b9f93b 100644 --- a/simgear/io/lowlevel.cxx +++ b/simgear/io/lowlevel.cxx @@ -55,21 +55,25 @@ void sgWriteChar ( gzFile fd, const char var ) void sgReadFloat ( gzFile fd, float *var ) { - if ( gzread ( fd, var, sizeof(float) ) != sizeof(float) ) { + union { float v; uint32_t u; } buf; + if ( gzread ( fd, &buf.u, sizeof(float) ) != sizeof(float) ) { read_error = true ; } if ( sgIsBigEndian() ) { - sgEndianSwap( (uint32_t *)var); + sgEndianSwap( &buf.u ); } + *var = buf.v; } void sgWriteFloat ( gzFile fd, const float var ) { + union { float v; uint32_t u; } buf; + buf.v = var; if ( sgIsBigEndian() ) { - sgEndianSwap( (uint32_t *)&var); + sgEndianSwap( &buf.u ); } - if ( gzwrite ( fd, (void *)(&var), sizeof(float) ) != sizeof(float) ) { + if ( gzwrite ( fd, (void *)(&buf.u), sizeof(float) ) != sizeof(float) ) { write_error = true ; } } @@ -77,21 +81,25 @@ void sgWriteFloat ( gzFile fd, const float var ) void sgReadDouble ( gzFile fd, double *var ) { - if ( gzread ( fd, var, sizeof(double) ) != sizeof(double) ) { + union { double v; uint64_t u; } buf; + if ( gzread ( fd, &buf.u, sizeof(double) ) != sizeof(double) ) { read_error = true ; } if ( sgIsBigEndian() ) { - sgEndianSwap( (uint64_t *)var); + sgEndianSwap( &buf.u ); } + *var = buf.v; } void sgWriteDouble ( gzFile fd, const double var ) { + union { double v; uint64_t u; } buf; + buf.v = var; if ( sgIsBigEndian() ) { - sgEndianSwap( (uint64_t *)&var); + sgEndianSwap( &buf.u ); } - if ( gzwrite ( fd, (void *)(&var), sizeof(double) ) != sizeof(double) ) { + if ( gzwrite ( fd, (void *)(&buf.u), sizeof(double) ) != sizeof(double) ) { write_error = true ; } }