internal.h included after math.h in complex.c
r51313 modified complex.c to include internal.h after math.h, so that ruby/missing.h (included from internal.h) can test whether
M_PI is defined or not in math.h. Unfortunately, ruby/config.h, which is included from internal.h, defines
_LARGE_FILES, which must be defined before sys/types.h is included from math.h. Otherwise, in AIX,
off_t would be incorrectly defined as a 32-bit integer even when large files are used.
--- complex.c (revision 51312) +++ complex.c (revision 51313) @@ -5,12 +5,12 @@ which is written in ruby. */ -#include "internal.h" #if defined _MSC_VER /* Microsoft Visual C does not define M_PI and others by default */ # define _USE_MATH_DEFINES 1 #endif #include <math.h> +#include "internal.h" #define NDEBUG #include <assert.h>
There would be a couple of workarounds to fix this problem, but since I am relatively new to the Ruby core, I am wondering what would be the most acceptable way.