// RUN: not %clang_cc1 -fsyntax-only -fmacro-backtrace-limit 0 %s 2>&1 | FileCheck %s --check-prefix=ALL // RUN: not %clang_cc1 -fsyntax-only -fmacro-backtrace-limit 2 %s 2>&1 | FileCheck %s --check-prefix=SKIP #define F(x) x + 1 #define G(x) F(x) + 2 #define ADD(x,y) G(x) + y #define LEVEL4(x) ADD(p,x) #define LEVEL3(x) LEVEL4(x) #define LEVEL2(x) LEVEL3(x) #define LEVEL1(x) LEVEL2(x) int a = LEVEL1(b); // ALL: {{.*}}:12:9: error: use of undeclared identifier 'p' // ALL-NEXT: int a = LEVEL1(b); // ALL-NEXT: ^ // ALL-NEXT: {{.*}}:10:19: note: expanded from macro 'LEVEL1' // ALL-NEXT: #define LEVEL1(x) LEVEL2(x) // ALL-NEXT: ^ // ALL-NEXT: {{.*}}:9:19: note: expanded from macro 'LEVEL2' // ALL-NEXT: #define LEVEL2(x) LEVEL3(x) // ALL-NEXT: ^ // ALL-NEXT: {{.*}}:8:19: note: expanded from macro 'LEVEL3' // ALL-NEXT: #define LEVEL3(x) LEVEL4(x) // ALL-NEXT: ^ // ALL-NEXT: {{.*}}:7:23: note: expanded from macro 'LEVEL4' // ALL-NEXT: #define LEVEL4(x) ADD(p,x) // ALL-NEXT: ^ // ALL-NEXT: {{.*}}:12:16: error: use of undeclared identifier 'b' // ALL-NEXT: int a = LEVEL1(b); // ALL-NEXT: ^ // ALL-NEXT: 2 errors generated. // SKIP: {{.*}}:12:9: error: use of undeclared identifier 'p' // SKIP-NEXT: int a = LEVEL1(b); // SKIP-NEXT: ^ // SKIP-NEXT: {{.*}}:10:19: note: expanded from macro 'LEVEL1' // SKIP-NEXT: #define LEVEL1(x) LEVEL2(x) // SKIP-NEXT: ^ // SKIP-NEXT: note: (skipping 2 expansions in backtrace; use -fmacro-backtrace-limit=0 to see all) // SKIP-NEXT: {{.*}}:7:23: note: expanded from macro 'LEVEL4' // SKIP-NEXT: #define LEVEL4(x) ADD(p,x) // SKIP-NEXT: ^ // SKIP-NEXT: {{.*}}:12:16: error: use of undeclared identifier 'b' // SKIP-NEXT: int a = LEVEL1(b); // SKIP-NEXT: ^ // SKIP-NEXT: 2 errors generated.