-
Notifications
You must be signed in to change notification settings - Fork 10.8k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[clang][modules] Avoid serializing all diag mappings in non-determini…
…stic order When writing a pcm, we serialize diagnostic mappings in order to accurately reproduce the diagnostic environment inside any headers from that module. However, the diagnostic state mapping table contains entries for every diagnostic ID ever accessed, while we only want to serialize the ones that are actually modified from their default value. Futher, we need to serialize them in a deterministic order. rdar://111477511 Differential Revision: https://reviews.llvm.org/D154016
- Loading branch information
1 parent
92fbb60
commit 1ede7b4
Showing
5 changed files
with
141 additions
and
22 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,94 @@ | ||
// Test that diagnostic mappings are emitted only when needed and in order of | ||
// diagnostic ID rather than non-deterministically. This test passes 3 | ||
// -W options and expects exactly 3 mappings to be emitted in the pcm. The -W | ||
// options are chosen to be far apart in ID (see DiagnosticIDs.h) so we can | ||
// check they are ordered. We also intentionally trigger several other warnings | ||
// inside the module and ensure they do not show up in the pcm as mappings. | ||
|
||
// RUN: rm -rf %t | ||
// RUN: split-file %s %t | ||
|
||
// RUN: %clang_cc1 -fmodules -fimplicit-module-maps \ | ||
// RUN: -fmodules-cache-path=%t/cache -triple x86_64-apple-macosx10.11.0 \ | ||
// RUN: %t/main.m -fdisable-module-hash \ | ||
// RUN: -Werror=stack-protector -Werror=empty-translation-unit -Werror=float-equal | ||
|
||
// RUN: mv %t/cache/A.pcm %t/A1.pcm | ||
|
||
// RUN: llvm-bcanalyzer --dump --disable-histogram %t/A1.pcm | FileCheck %s | ||
|
||
// CHECK: <DIAG_PRAGMA_MAPPINGS | ||
|
||
// == Initial mappings | ||
// Number of mappings = 3 | ||
// CHECK-SAME: op2=3 | ||
// Common diag id is < 1000 (see DiagnosticIDs.h) | ||
// CHECK-SAME: op3=[[STACK_PROT:[0-9][0-9]?[0-9]?]] op4= | ||
// Parse diag id is somewhere in 1000..2999, leaving room for changes | ||
// CHECK-SAME: op5=[[EMPTY_TU:[12][0-9][0-9][0-9]]] op6= | ||
// Sema diag id is > 2000 | ||
// CHECK-SAME: op7=[[FLOAT_EQ:[2-9][0-9][0-9][0-9]]] op8= | ||
|
||
// == Pragmas: | ||
// Each pragma creates a mapping table; and each copies the previous table. The | ||
// initial mappings are copied as well, but are not serialized since they have | ||
// isPragma=false. | ||
|
||
// == ignored "-Wfloat-equal" | ||
// CHECK-SAME: op{{[0-9]+}}=1 | ||
// CHECK-SAME: op{{[0-9]+}}=[[FLOAT_EQ]] op{{[0-9]+}}= | ||
|
||
// == ignored "-Wstack-protector" | ||
// CHECK-SAME: op{{[0-9]+}}=2 | ||
// CHECK-SAME: op{{[0-9]+}}=[[STACK_PROT]] op{{[0-9]+}}= | ||
// CHECK-SAME: op{{[0-9]+}}=[[FLOAT_EQ]] op{{[0-9]+}}= | ||
|
||
// == warning "-Wempty-translation-unit" | ||
// CHECK-SAME: op{{[0-9]+}}=3 | ||
// CHECK-SAME: op{{[0-9]+}}=[[STACK_PROT]] op{{[0-9]+}}= | ||
// CHECK-SAME: op{{[0-9]+}}=[[EMPTY_TU]] op{{[0-9]+}}= | ||
// CHECK-SAME: op{{[0-9]+}}=[[FLOAT_EQ]] op{{[0-9]+}}= | ||
|
||
// == warning "-Wstack-protector" | ||
// CHECK-SAME: op{{[0-9]+}}=3 | ||
// CHECK-SAME: op{{[0-9]+}}=[[STACK_PROT]] op{{[0-9]+}}= | ||
// CHECK-SAME: op{{[0-9]+}}=[[EMPTY_TU]] op{{[0-9]+}}= | ||
// CHECK-SAME: op{{[0-9]+}}=[[FLOAT_EQ]] op{{[0-9]+}}= | ||
|
||
// RUN: %clang_cc1 -fmodules -fimplicit-module-maps \ | ||
// RUN: -fmodules-cache-path=%t/cache -triple x86_64-apple-macosx10.11.0 \ | ||
// RUN: %t/main.m -fdisable-module-hash \ | ||
// RUN: -Werror=stack-protector -Werror=empty-translation-unit -Werror=float-equal | ||
|
||
// RUN: diff %t/cache/A.pcm %t/A1.pcm | ||
|
||
//--- module.modulemap | ||
module A { header "a.h" } | ||
|
||
//--- a.h | ||
// Lex warning | ||
#warning "w" | ||
|
||
static inline void f() { | ||
// Parse warning | ||
; | ||
} | ||
|
||
#pragma clang diagnostic push | ||
#pragma clang diagnostic ignored "-Wfloat-equal" | ||
#pragma clang diagnostic ignored "-Wstack-protector" | ||
|
||
static inline void g() { | ||
// Sema warning | ||
int x; | ||
} | ||
|
||
#pragma clang diagnostic push | ||
#pragma clang diagnostic warning "-Wempty-translation-unit" | ||
#pragma clang diagnostic warning "-Wstack-protector" | ||
|
||
#pragma clang diagnostic pop | ||
#pragma clang diagnostic pop | ||
|
||
//--- main.m | ||
#import "a.h" |