macro-backtrace.c 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. // Tests for macro expansion backtraces. The RUN and CHECK lines are grouped
  2. // below the test code to reduce noise when updating them.
  3. #define M1(A, B) ((A) < (B))
  4. #define M2(A, B) M1(A, B)
  5. #define M3(A, B) M2(A, B)
  6. #define M4(A, B) M3(A, B)
  7. #define M5(A, B) M4(A, B)
  8. #define M6(A, B) M5(A, B)
  9. #define M7(A, B) M6(A, B)
  10. #define M8(A, B) M7(A, B)
  11. #define M9(A, B) M8(A, B)
  12. #define M10(A, B) M9(A, B)
  13. #define M11(A, B) M10(A, B)
  14. #define M12(A, B) M11(A, B)
  15. void f(int *ip, float *fp) {
  16. if (M12(ip, fp)) { }
  17. // RUN: %clang_cc1 -fsyntax-only -fmacro-backtrace-limit 5 %s 2>&1 \
  18. // RUN: | FileCheck %s -check-prefix=CHECK-LIMIT
  19. // CHECK-LIMIT: macro-backtrace.c:18:7: warning: comparison of distinct pointer types ('int *' and 'float *')
  20. // CHECK-LIMIT: if (M12(ip, fp)) { }
  21. // CHECK-LIMIT: macro-backtrace.c:15:19: note: expanded from macro 'M12'
  22. // CHECK-LIMIT: #define M12(A, B) M11(A, B)
  23. // CHECK-LIMIT: macro-backtrace.c:14:19: note: expanded from macro 'M11'
  24. // CHECK-LIMIT: #define M11(A, B) M10(A, B)
  25. // CHECK-LIMIT: note: (skipping 7 expansions in backtrace; use -fmacro-backtrace-limit=0 to see all)
  26. // CHECK-LIMIT: macro-backtrace.c:6:18: note: expanded from macro 'M3'
  27. // CHECK-LIMIT: #define M3(A, B) M2(A, B)
  28. // CHECK-LIMIT: macro-backtrace.c:5:18: note: expanded from macro 'M2'
  29. // CHECK-LIMIT: #define M2(A, B) M1(A, B)
  30. // CHECK-LIMIT: macro-backtrace.c:4:23: note: expanded from macro 'M1'
  31. // CHECK-LIMIT: #define M1(A, B) ((A) < (B))
  32. // RUN: %clang_cc1 -fsyntax-only -fno-caret-diagnostics %s 2>&1 \
  33. // RUN: | FileCheck %s -check-prefix=CHECK-NO-CARETS
  34. // CHECK-NO-CARETS: macro-backtrace.c:18:7: warning: comparison of distinct pointer types ('int *' and 'float *')
  35. // CHECK-NO-CARETS-NEXT: macro-backtrace.c:15:19: note: expanded from macro 'M12'
  36. // CHECK-NO-CARETS-NEXT: macro-backtrace.c:14:19: note: expanded from macro 'M11'
  37. // CHECK-NO-CARETS-NEXT: macro-backtrace.c:13:19: note: expanded from macro 'M10'
  38. // CHECK-NO-CARETS-NEXT: note: (skipping 6 expansions in backtrace; use -fmacro-backtrace-limit=0 to see all)
  39. // CHECK-NO-CARETS-NEXT: macro-backtrace.c:6:18: note: expanded from macro 'M3'
  40. // CHECK-NO-CARETS-NEXT: macro-backtrace.c:5:18: note: expanded from macro 'M2'
  41. // CHECK-NO-CARETS-NEXT: macro-backtrace.c:4:23: note: expanded from macro 'M1'
  42. // Check that the expansion notes respect the same formatting options as
  43. // other diagnostics.
  44. // RUN: %clang_cc1 -fsyntax-only -fdiagnostics-format vi %s 2>&1 \
  45. // RUN: | FileCheck %s -check-prefix=CHECK-NOTE-FORMAT
  46. // CHECK-NOTE-FORMAT: macro-backtrace.c +18:7: warning:
  47. // CHECK-NOTE-FORMAT: macro-backtrace.c +15:19: note:
  48. // CHECK-NOTE-FORMAT: macro-backtrace.c +14:19: note:
  49. // CHECK-NOTE-FORMAT: note:
  50. // CHECK-NOTE-FORMAT: macro-backtrace.c +6:18: note:
  51. // CHECK-NOTE-FORMAT: macro-backtrace.c +5:18: note:
  52. // CHECK-NOTE-FORMAT: macro-backtrace.c +4:23: note:
  53. }