blob: 5a94c00c969fb969ed611f580e905c3bcbc3e72a (
plain)
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
67
68
69
70
71
72
73
74
75
76
77
78
79
80
|
/* Clang supports a very limited subset of -traditional-cpp, basically we only
* intend to add support for things that people actually rely on when doing
* things like using /usr/bin/cpp to preprocess non-source files. */
/*
RUN: %clang_cc1 -traditional-cpp %s -E -o %t
RUN: FileCheck -strict-whitespace < %t %s
*/
/* CHECK: {{^}}foo // bar{{$}}
*/
foo // bar
/* The lines in this file contain hard tab characters and trailing whitespace;
* do not change them! */
/* CHECK: {{^}} indented!{{$}}
* CHECK: {{^}}tab separated values{{$}}
*/
indented!
tab separated values
#define bracket(x) >>>x<<<
bracket(| spaces |)
/* CHECK: {{^}}>>>| spaces |<<<{{$}}
*/
/* This is still a preprocessing directive. */
# define foo bar
foo!
-
foo! foo!
/* CHECK: {{^}}bar!{{$}}
* CHECK: {{^}} bar! bar! {{$}}
*/
/* Deliberately check a leading newline with spaces on that line. */
# define foo bar
foo!
-
foo! foo!
/* CHECK: {{^}}bar!{{$}}
* CHECK: {{^}} bar! bar! {{$}}
*/
/* FIXME: -traditional-cpp should not consider this a preprocessing directive
* because the # isn't in the first column.
*/
#define foo2 bar
foo2!
/* If this were working, both of these checks would be on.
* CHECK-NOT: {{^}} #define foo2 bar{{$}}
* CHECK-NOT: {{^}}foo2!{{$}}
*/
/* FIXME: -traditional-cpp should not homogenize whitespace in macros.
*/
#define bracket2(x) >>> x <<<
bracket2(spaces)
/* If this were working, this check would be on.
* CHECK-NOT: {{^}}>>> spaces <<<{{$}}
*/
/* Check that #if 0 blocks work as expected */
#if 0
#error "this is not an error"
#if 1
a b c in skipped block
#endif
/* Comments are whitespace too */
#endif
/* CHECK-NOT: {{^}}a b c in skipped block{{$}}
* CHECK-NOT: {{^}}/* Comments are whitespace too
*/
|