Work-around clang weirdness by adding a newline.
authorAustin Seipp <aseipp@pobox.com>
Mon, 17 Jun 2013 10:36:29 +0000 (05:36 -0500)
committerAustin Seipp <aseipp@pobox.com>
Mon, 17 Jun 2013 10:54:33 +0000 (05:54 -0500)
I really wish this were a joke, but alas...

This gets me a working stage1 compiler on Linux with Clang with no
modifications. Unfortunately it won't get much farther than that for
various other reasons.

Signed-off-by: Austin Seipp <aseipp@pobox.com>
compiler/parser/Parser.y.pp

index 34c0bc6..483ed87 100644 (file)
@@ -26,8 +26,16 @@ throw away inlinings as it would normally do in -O0 mode.
 
 -- CPP tricks because we want the directives in the output of the
 -- first CPP pass.
+--
+-- Clang note, 6/17/2013 by aseipp: It is *extremely* important (for
+-- some reason) that there be a line of whitespace between the two
+-- definitions here, and the subsequent use of __IF_GHC_77__ - this
+-- seems to be a bug in clang or something, where having the line of
+-- whitespace will make the preprocessor correctly format the rendered
+-- lines in the 'two step' CPP pass. No, this is not a joke.
 #define __IF_GHC_77__ #if __GLASGOW_HASKELL__ >= 707
-#define __ENDIF__     #endif
+#define __ENDIF__ #endif
+
 __IF_GHC_77__
 -- Required on x86 to avoid the register allocator running out of
 -- stack slots when compiling this module with -fPIC -dynamic.