1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
|
/* Copyright (C) 2000, 2001, 2003 Free Software Foundation, Inc. */
/* { dg-do preprocess } */
/* { dg-options "-P" } */
/* This tests correct spacing of macro expansion output, as well as
the line it falls on. This is quite subtle; it involves newlines
within macro arguments becoming spaces, but not if it turns out to
not be a macro invocation. Also, multiple macro invocations spread
across many lines.
Neil Booth, 1 Dec 2000, 23 Sep 2001. */
/* The actual location of the expansion of a multi-line macro
invocation is not defined: we might consider them to be in the same
line as the initial token of the invocation, or as the final token
of the invocation, or even anything in between. We choose to make
it the initial token, such that everything that is in a logical
line ends up in a single line after preprocessing.
Alexandre Oliva, Sept 13, 2003. */
#define str(x) #x
#define f(x) x
#define glue(x, y) x ## y
#define EMPTY
/* These are based on PR 4492, we mustn't lose padding tokens when
scanning ahead for a '(' and failing to find it. */
#define A(x) B x
#define B(x)
#define C A
#define D() A
/* The correct output is shown here. Note the spaces, and the way
everything after the invocation of f appears on the same line.
44 ;
B Q B Q A Q A:
f
bar
A
bad
g "1 2" bam baz
*/
glue (EMPTY 4, 4) EMPTY;
A(Q) C(Q) D()Q D():
f
bar
A
bad
f (g) str
(
1
2
) f
(bam) baz
/* { dg-final { scan-file spacing1.i " 44 ;" } }
{ dg-final { scan-file spacing1.i "B Q B Q A Q A:" } }
{ dg-final { scan-file-not spacing1.i "f\[^\n\]*bar" } }
{ dg-final { scan-file spacing1.i "(^|\n)bar" } }
{ dg-final { scan-file spacing1.i "(^|\n)A($|\n)" } }
{ dg-final { scan-file spacing1.i "(^|\n)bad($|\n)" } }
{ dg-final { scan-file spacing1.i "g \"1 2\" bam baz" } } */
|