When compiling the following snippet, both gcc and clang only issue a warning. Notice space after \\
next to int
:
#include
You quoted text from the standard that says what happens when a backslash is followed by a newline.
That text does not tell us what the compiler (or C implementation generally) must do when there is a backslash followed by a space.
I do not see any particular rule for that in the C 2011 standard. A backslash outside of its proper place simply does not conform to the general syntax and grammar of C, so it becomes some sort of violation of those, depending on where it appears.
C 2011 5.1.1.3 says:
A conforming implementation shall produce at least one diagnostic message (identified in an implementation-defined manner) if a preprocessing translation unit or translation unit contains a violation of any syntax rule or constraint,…
GCC did that; it produces a diagnostic message. (A warning is a diagnostic.) So it conformed to C 2011 in this regard.
The compiler is allowed to extend the language as long as the document the change which gcc
does in their docs in section 6.21 Slightly Looser Rules for Escaped Newlines.
Recently, the preprocessor has relaxed its treatment of escaped newlines. Previously, the newline had to immediately follow a backslash. The current implementation allows whitespace in the form of spaces, horizontal and vertical tabs, and form feeds between the backslash and the subsequent newline. The preprocessor issues a warning, but treats it as a valid escaped newline and combines the two lines to form a single logical line. This works within comments and tokens, as well as between tokens. Comments are not treated as whitespace for the purposes of this relaxation, since they have not yet been replaced with spaces.
and clang
strives to support gcc
extensions and points to the gcc
docs on them:
this document describes the language extensions provided by Clang. In addition to the language extensions listed here, Clang aims to support a broad range of GCC extensions. Please see the GCC manual for more information on these extensions.
So their obligations with respect to the standard are fulfilled. In fact Linux depends on many gcc extensions. We can see this by looking at the draft C99 standard section 4.
Conformance paragraphs 6 which say:
[...]A conforming implementation may have extensions (including additional library functions), provided they do not alter the behavior of any strictly conforming program.3)
footnote 3 says:
This implies that a conforming implementation reserves no identifiers other than those explicitly reserved in this International Standard.
and paragraph 8:
An implementation shall be accompanied by a document that defines all implementation defined and locale-specific characteristics and all extensions.
gcc
also documents that you can use the -pedantic
flag to generate a warning when using extensions and you can use -pedantic-errors
flag to make it an error:
[...] to obtain all the diagnostics required by the standard, you should also specify -pedantic (or -pedantic-errors if you want them to be errors rather than warnings).
A warning is generated when this happens. Don't write code that depends on this behavior; it is provided because trailing whitespace is significant (almost) nowhere else, and we get much better error recovery if we treat them as line continuations. Especially don't write code that depends on being able to put a comment after a line continuation, that is an accident of the implementation and will change in the future.
If you want to disable extensions, like the other answer says, enable warnings and use -pedantic-errors
. Otherwise, feel free to use whatever features the compiler gives you as long as you understand the implications and what benefits they provide. If you want C99 mode, make sure to add -std=c99
to the command line.
Compile with the right options and gcc
and clang
will refuse to do the translation:
$ gcc -Wall -Werror -std=c11 -pedantic tst.c
tst.c: In function ‘main’:
tst.c:6:9: error: backslash and newline separated by space [-Werror]
cc1: all warnings being treated as errors
$
By default gcc
compiles in c89 mode with GNU extensions enabled and is pretty indulgent.