Skip to content

Commit 5d12b13

Browse files
committed
[clang-tidy] Dump effective diagnostics level in YAML output
Before this patch YAML output had default diagnostic level instead of effective level reported to the user on stdout. Wrapper scripts for clang-tidy usually use YAML output and they pick wrong diagnostics level without this patch. Test Plan: check-clang-tools Differential Revision: https://reviews.llvm.org/D135367
1 parent 2a26a44 commit 5d12b13

File tree

2 files changed

+19
-3
lines changed

2 files changed

+19
-3
lines changed

clang-tools-extra/clang-tidy/ClangTidyDiagnosticConsumer.cpp

+2
Original file line numberDiff line numberDiff line change
@@ -403,6 +403,8 @@ void ClangTidyDiagnosticConsumer::HandleDiagnostic(
403403

404404
bool IsWarningAsError = DiagLevel == DiagnosticsEngine::Warning &&
405405
Context.treatAsError(CheckName);
406+
if (IsWarningAsError)
407+
Level = ClangTidyError::Error;
406408
Errors.emplace_back(CheckName, Level, Context.getCurrentBuildDirectory(),
407409
IsWarningAsError);
408410
}

clang-tools-extra/test/clang-tidy/infrastructure/export-diagnostics.cpp

+17-3
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,5 @@
11
// RUN: grep -Ev "// *[A-Z-]+:" %s > %t-input.cpp
2-
// RUN: not clang-tidy %t-input.cpp -checks='-*,google-explicit-constructor,clang-diagnostic-missing-prototypes,clang-diagnostic-zero-length-array' -export-fixes=%t.yaml -- -Wmissing-prototypes -Wzero-length-array > %t.msg 2>&1
2+
// RUN: not clang-tidy %t-input.cpp -checks='-*,google-explicit-constructor,clang-diagnostic-missing-prototypes,clang-diagnostic-zero-length-array' --warnings-as-errors='clang-diagnostic-missing-prototypes,google-explicit-constructor' -export-fixes=%t.yaml -- -Wmissing-prototypes -Wzero-length-array > %t.msg 2>&1
33
// RUN: FileCheck -input-file=%t.msg -check-prefix=CHECK-MESSAGES %s -implicit-check-not='{{warning|error|note}}:'
44
// RUN: FileCheck -input-file=%t.yaml -check-prefix=CHECK-YAML %s
55
#define X(n) void n ## n() {}
@@ -10,9 +10,10 @@ int b[0];
1010
void test(x);
1111
struct Foo {
1212
member;
13+
Foo(int) {}
1314
};
1415

15-
// CHECK-MESSAGES: -input.cpp:2:1: warning: no previous prototype for function 'ff' [clang-diagnostic-missing-prototypes]
16+
// CHECK-MESSAGES: -input.cpp:2:1: error: no previous prototype for function 'ff' [clang-diagnostic-missing-prototypes,-warnings-as-errors]
1617
// CHECK-MESSAGES: -input.cpp:1:19: note: expanded from macro 'X'
1718
// CHECK-MESSAGES: {{^}}note: expanded from here{{$}}
1819
// CHECK-MESSAGES: -input.cpp:2:1: note: declare 'static' if the function is not intended to be used outside of this translation unit
@@ -21,6 +22,7 @@ struct Foo {
2122
// CHECK-MESSAGES: -input.cpp:4:7: warning: zero size arrays are an extension [clang-diagnostic-zero-length-array]
2223
// CHECK-MESSAGES: -input.cpp:6:11: error: unknown type name 'x' [clang-diagnostic-error]
2324
// CHECK-MESSAGES: -input.cpp:8:3: error: a type specifier is required for all declarations [clang-diagnostic-error]
25+
// CHECK-MESSAGES: -input.cpp:9:3: error: single-argument constructors must be marked explicit to avoid unintentional implicit conversions [google-explicit-constructor,-warnings-as-errors]
2426

2527
// CHECK-YAML: ---
2628
// CHECK-YAML-NEXT: MainSourceFile: '{{.*}}-input.cpp'
@@ -52,7 +54,7 @@ struct Foo {
5254
// CHECK-YAML-NEXT: FilePath: '{{.*}}-input.cpp'
5355
// CHECK-YAML-NEXT: FileOffset: 13
5456
// CHECK-YAML-NEXT: Replacements: []
55-
// CHECK-YAML-NEXT: Level: Warning
57+
// CHECK-YAML-NEXT: Level: Error
5658
// CHECK-YAML-NEXT: BuildDirectory: '{{.*}}'
5759
// CHECK-YAML-NEXT: - DiagnosticName: clang-diagnostic-error
5860
// CHECK-YAML-NEXT: DiagnosticMessage:
@@ -94,4 +96,16 @@ struct Foo {
9496
// CHECK-YAML-NEXT: Replacements: []
9597
// CHECK-YAML-NEXT: Level: Error
9698
// CHECK-YAML-NEXT: BuildDirectory: '{{.*}}'
99+
// CHECK-YAML-NEXT: - DiagnosticName: google-explicit-constructor
100+
// CHECK-YAML-NEXT: DiagnosticMessage:
101+
// CHECK-YAML-NEXT: Message: single-argument constructors must be marked explicit to avoid unintentional implicit conversions
102+
// CHECK-YAML-NEXT: FilePath: '{{.*}}-input.cpp'
103+
// CHECK-YAML-NEXT: FileOffset: 96
104+
// CHECK-YAML-NEXT: Replacements:
105+
// CHECK-YAML-NEXT: - FilePath: '{{.*}}-input.cpp'
106+
// CHECK-YAML-NEXT: Offset: 96
107+
// CHECK-YAML-NEXT: Length: 0
108+
// CHECK-YAML-NEXT: ReplacementText: 'explicit '
109+
// CHECK-YAML-NEXT: Level: Error
110+
// CHECK-YAML-NEXT: BuildDirectory: '{{.*}}'
97111
// CHECK-YAML-NEXT: ...

0 commit comments

Comments
 (0)