From 2c4eda6ab9b83e3d5853408c354d344d0255e0f0 Mon Sep 17 00:00:00 2001 From: Philippe Teuwen Date: Wed, 13 May 2020 02:09:03 +0200 Subject: [PATCH] Fix 2 issues in proxendian.h, see details: Only some OSes include endian.h from sys/types.h, not Termux, so let's include endian.h directly. Moreover the past logic defined BYTE_ORDER to an undef macro, so BYTE_ORDER was not undef but def to 0 and BYTE_ORDER != LITTLE_ENDIAN && BYTE_ORDER != BIG_ENDIAN was always false as (0!=0 && 0!=0) --- Makefile.defs | 2 -- client/src/proxendian.h | 27 ++++++++++++++++----------- 2 files changed, 16 insertions(+), 13 deletions(-) diff --git a/Makefile.defs b/Makefile.defs index 88b746e5e..be504caa9 100644 --- a/Makefile.defs +++ b/Makefile.defs @@ -51,8 +51,6 @@ DEFCFLAGS += -Wbad-function-cast -Wredundant-decls -Wmissing-prototypes -Wchar-s # Some more warnings we need first to eliminate, so temporarely tolerated: DEFCFLAGS += -Wcast-align -Wno-error=cast-align DEFCFLAGS += -Wswitch-enum -Wno-error=switch-enum -# Termux on-device __BYTE_ORDER and __LITTLE_ENDIAN undef in src/proxendian.h, see #730 -DEFCFLAGS += -Wno-error=undef ifeq ($(platform),Darwin) # their readline has strict-prototype issues diff --git a/client/src/proxendian.h b/client/src/proxendian.h index fde5126b1..3a025b7ac 100644 --- a/client/src/proxendian.h +++ b/client/src/proxendian.h @@ -16,17 +16,22 @@ #ifdef _WIN32 # define HOST_LITTLE_ENDIAN #else -# include -# ifndef BYTE_ORDER -# define BYTE_ORDER __BYTE_ORDER -# define LITTLE_ENDIAN __LITTLE_ENDIAN -# define BIG_ENDIAN __BIG_ENDIAN -# endif -# if !defined(BYTE_ORDER) || (BYTE_ORDER != LITTLE_ENDIAN && BYTE_ORDER != BIG_ENDIAN) -# error Define BYTE_ORDER to be equal to either LITTLE_ENDIAN or BIG_ENDIAN -# endif -# if BYTE_ORDER == LITTLE_ENDIAN -# define HOST_LITTLE_ENDIAN +// Only some OSes include endian.h from sys/types.h, not Termux, so let's include endian.h directly +# include +# if !defined(BYTE_ORDER) +# if !defined(__BYTE_ORDER) || (__BYTE_ORDER != __LITTLE_ENDIAN && __BYTE_ORDER != __BIG_ENDIAN) +# error Define BYTE_ORDER to be equal to either LITTLE_ENDIAN or BIG_ENDIAN +# endif +# if __BYTE_ORDER == __LITTLE_ENDIAN +# define HOST_LITTLE_ENDIAN +# endif +# else +# if BYTE_ORDER != LITTLE_ENDIAN && BYTE_ORDER != BIG_ENDIAN +# error Define BYTE_ORDER to be equal to either LITTLE_ENDIAN or BIG_ENDIAN +# endif +# if BYTE_ORDER == LITTLE_ENDIAN +# define HOST_LITTLE_ENDIAN +# endif # endif #endif