зеркало из https://github.com/mozilla/gecko-dev.git
Bug 1331957 - Part 7: Reapply LLVM r285657 to work around bug 1291397 on clang 3.9; r=froydnj
This commit is contained in:
Родитель
39988b4058
Коммит
6606a301b5
|
@ -23,19 +23,22 @@
|
|||
"llvm-debug-frame.patch",
|
||||
"compiler-rt-cross-compile.patch",
|
||||
"pr28831-r280042.patch",
|
||||
"r277806.patch"
|
||||
"r277806.patch",
|
||||
"r285657.patch"
|
||||
],
|
||||
"linux64": [
|
||||
"llvm-debug-frame.patch",
|
||||
"compiler-rt-cross-compile.patch",
|
||||
"pr28831-r280042.patch",
|
||||
"r277806.patch"
|
||||
"r277806.patch",
|
||||
"r285657.patch"
|
||||
],
|
||||
"linux32": [
|
||||
"llvm-debug-frame.patch",
|
||||
"compiler-rt-cross-compile.patch",
|
||||
"pr28831-r280042.patch",
|
||||
"r277806.patch"
|
||||
"r277806.patch",
|
||||
"r285657.patch"
|
||||
]
|
||||
}
|
||||
}
|
||||
|
|
|
@ -0,0 +1,64 @@
|
|||
commit 783f98e4a55266c40b6ecee9b41381353f37013b
|
||||
Author: Tim Shen <timshen91@gmail.com>
|
||||
Date: Tue Nov 1 00:19:04 2016 +0000
|
||||
|
||||
[ReachableCode] Skip over ExprWithCleanups in isConfigurationValue
|
||||
|
||||
Summary: Fixes pr29152.
|
||||
|
||||
Reviewers: rsmith, pirama, krememek
|
||||
|
||||
Subscribers: cfe-commits
|
||||
|
||||
Differential Revision: https://reviews.llvm.org/D24010
|
||||
|
||||
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@285657 91177308-0d34-0410-b5e6-96231b3b80d8
|
||||
|
||||
diff --git a/clang/include/clang/AST/Stmt.h a/clang/include/clang/AST/Stmt.h
|
||||
index 9381a44985..e28675d6a8 100644
|
||||
--- a/clang/include/clang/AST/Stmt.h
|
||||
+++ a/clang/include/clang/AST/Stmt.h
|
||||
@@ -387,6 +387,9 @@ public:
|
||||
/// Skip past any implicit AST nodes which might surround this
|
||||
/// statement, such as ExprWithCleanups or ImplicitCastExpr nodes.
|
||||
Stmt *IgnoreImplicit();
|
||||
+ const Stmt *IgnoreImplicit() const {
|
||||
+ return const_cast<Stmt *>(this)->IgnoreImplicit();
|
||||
+ }
|
||||
|
||||
/// \brief Skip no-op (attributed, compound) container stmts and skip captured
|
||||
/// stmt at the top, if \a IgnoreCaptured is true.
|
||||
diff --git a/clang/lib/Analysis/ReachableCode.cpp a/clang/lib/Analysis/ReachableCode.cpp
|
||||
index 8165b09f40..69d000c03b 100644
|
||||
--- a/clang/lib/Analysis/ReachableCode.cpp
|
||||
+++ a/clang/lib/Analysis/ReachableCode.cpp
|
||||
@@ -164,6 +164,8 @@ static bool isConfigurationValue(const Stmt *S,
|
||||
if (!S)
|
||||
return false;
|
||||
|
||||
+ S = S->IgnoreImplicit();
|
||||
+
|
||||
if (const Expr *Ex = dyn_cast<Expr>(S))
|
||||
S = Ex->IgnoreCasts();
|
||||
|
||||
diff --git a/clang/test/SemaCXX/PR29152.cpp a/clang/test/SemaCXX/PR29152.cpp
|
||||
new file mode 100644
|
||||
index 0000000000..63c9c9bed5
|
||||
--- /dev/null
|
||||
+++ a/clang/test/SemaCXX/PR29152.cpp
|
||||
@@ -0,0 +1,15 @@
|
||||
+// RUN: %clang_cc1 -fsyntax-only -Wunreachable-code -verify %s
|
||||
+
|
||||
+static const bool False = false;
|
||||
+
|
||||
+struct A {
|
||||
+ ~A();
|
||||
+ operator bool();
|
||||
+};
|
||||
+void Bar();
|
||||
+
|
||||
+void Foo() {
|
||||
+ if (False && A()) {
|
||||
+ Bar(); // expected-no-diagnostics
|
||||
+ }
|
||||
+}
|
Загрузка…
Ссылка в новой задаче