diff options
author | Chandler Carruth <chandlerc@gmail.com> | 2015-03-26 08:32:49 +0000 |
---|---|---|
committer | Chandler Carruth <chandlerc@gmail.com> | 2015-03-26 08:32:49 +0000 |
commit | f85d98285e8eb6bcf42c2821e3b03abfc22ffac9 (patch) | |
tree | 611357433af1c908392bcd691daa41a33b1bfc9b /clang/test/Modules/stress1.cpp | |
parent | 23536d92c75dfebd65afa5ce1e588470e908b594 (diff) | |
download | bcm5719-llvm-f85d98285e8eb6bcf42c2821e3b03abfc22ffac9.tar.gz bcm5719-llvm-f85d98285e8eb6bcf42c2821e3b03abfc22ffac9.zip |
[Modules] Make "#pragma weak" undeclared identifiers be tracked
deterministically.
This fixes a latent issue where even Clang's Sema (and diagnostics) were
non-deterministic in the face of this pragma. The fix is super simple --
just use a MapVector so we track the order in which these are parsed (or
imported). Especially considering how rare they are, this seems like the
perfect tradeoff. I've also simplified the client code with judicious
use of auto and range based for loops.
I've added some pretty hilarious code to my stress test which now
survives the binary diff without issue.
llvm-svn: 233261
Diffstat (limited to 'clang/test/Modules/stress1.cpp')
-rw-r--r-- | clang/test/Modules/stress1.cpp | 5 |
1 files changed, 5 insertions, 0 deletions
diff --git a/clang/test/Modules/stress1.cpp b/clang/test/Modules/stress1.cpp index 55d9533b7ae..e03e538a3ce 100644 --- a/clang/test/Modules/stress1.cpp +++ b/clang/test/Modules/stress1.cpp @@ -98,3 +98,8 @@ #include "merge00.h" int f() { return N01::S00('a').method00('b') + (int)N00::S00(42) + function00(42) + g(); } + +int f2() { + return pragma_weak00() + pragma_weak01() + pragma_weak02() + + pragma_weak03 + pragma_weak04 + pragma_weak05; +} |