zip-writer.c: Fix incorrect big-endian handling.
authorJohn Darrington <john@darrington.wattle.id.au>
Thu, 1 Mar 2012 20:48:09 +0000 (21:48 +0100)
committerJohn Darrington <john@darrington.wattle.id.au>
Thu, 1 Mar 2012 20:48:09 +0000 (21:48 +0100)
src/libpspp/zip-writer.c

index e93ec887e8be952e08a3db28cd79c4b139ec8249..01c11d77c0469643e66bc6fe972ae1bbbc1ff14e 100644 (file)
@@ -23,8 +23,6 @@
 #include <stdlib.h>
 #include <time.h>
 
-#include "libpspp/integer-format.h"
-
 #include "gl/crc.h"
 #include "gl/error.h"
 #include "gl/fwriteerror.h"
@@ -63,16 +61,18 @@ put_bytes (struct zip_writer *zw, const void *p, size_t n)
 static void
 put_u16 (struct zip_writer *zw, uint16_t x)
 {
-  if (INTEGER_NATIVE != INTEGER_LSB_FIRST)
-    integer_convert (INTEGER_NATIVE, &x, INTEGER_MSB_FIRST, &x, sizeof x);
+#ifdef WORDS_BIGENDIAN
+  x = bswap_16 (x);
+#endif
   put_bytes (zw, &x, sizeof x);
 }
 
 static void
 put_u32 (struct zip_writer *zw, uint32_t x)
 {
-  if (INTEGER_NATIVE != INTEGER_LSB_FIRST)
-    integer_convert (INTEGER_NATIVE, &x, INTEGER_MSB_FIRST, &x, sizeof x);
+#ifdef WORDS_BIGENDIAN
+  x = bswap_32 (x);
+#endif
   put_bytes (zw, &x, sizeof x);
 }