aboutsummaryrefslogtreecommitdiffstats
path: root/awk.h
diff options
context:
space:
mode:
authorArnold D. Robbins <arnold@skeeve.com>2017-04-20 05:58:35 +0300
committerArnold D. Robbins <arnold@skeeve.com>2017-04-20 05:58:35 +0300
commit780c96b8a827fd1780e611cd41d59d80033eff46 (patch)
tree191e174567c4f5e692c06550a068f4fcd3be4819 /awk.h
parent67f4d070335e12622af1363b71c68489c64f5bc7 (diff)
downloadegawk-780c96b8a827fd1780e611cd41d59d80033eff46.tar.gz
egawk-780c96b8a827fd1780e611cd41d59d80033eff46.tar.bz2
egawk-780c96b8a827fd1780e611cd41d59d80033eff46.zip
Fix 64-bit compilation without MPFR.
Diffstat (limited to 'awk.h')
-rw-r--r--awk.h24
1 files changed, 17 insertions, 7 deletions
diff --git a/awk.h b/awk.h
index 127eb927..33ea980d 100644
--- a/awk.h
+++ b/awk.h
@@ -365,6 +365,21 @@ typedef struct exp_node {
} nodep;
struct {
+ // April 2017:
+ // The NODE union will be the death of me yet. :-(
+ //
+ // On 64 bit Intel systems, at least, if compiling
+ // without MPFR, the pointers need to come before the
+ // the double. Otherwise things break pretty
+ // badly. This doesn't happen on 32 bit compiles.
+ // I saw this on GCC 5.4.0, GCC 6.3.0, PCC, TCC
+ // and clang 3.8.0. It's way too much work to
+ // try to figure out why. So I just put pointers,
+ // then the double, then the size_t's, and then
+ // the rest. Sigh.
+ char *sp;
+ wchar_t *wsp;
+ struct exp_node *typre;
#ifdef HAVE_MPFR
union {
AWKNUM fltnum;
@@ -372,17 +387,12 @@ typedef struct exp_node {
mpz_t mpi;
} nm;
#else
- AWKNUM fltnum; /* this is here for optimal packing of
- * the structure on many machines
- */
+ AWKNUM fltnum;
#endif
- char *sp;
size_t slen;
+ size_t wslen;
long sref;
int idx;
- wchar_t *wsp;
- size_t wslen;
- struct exp_node *typre;
} val;
} sub;
NODETYPE type;