]> granicus.if.org Git - clang/commitdiff
PR4700 - remove shift by 0 warning
authorRyan Flynn <pizza@parseerror.com>
Sat, 8 Aug 2009 19:18:23 +0000 (19:18 +0000)
committerRyan Flynn <pizza@parseerror.com>
Sat, 8 Aug 2009 19:18:23 +0000 (19:18 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@78488 91177308-0d34-0410-b5e6-96231b3b80d8

include/clang/Basic/DiagnosticSemaKinds.td
lib/Sema/SemaExpr.cpp
test/Sema/shift.c

index 591cf0a28ac374c0115cec1a028d0cde7f83ea59..fb36a717f429a786eb13b30f9d5ec1acd49cd72e 100644 (file)
@@ -1241,9 +1241,6 @@ def warn_shift_negative : Warning<
   "shift count is negative">;
 def warn_shift_gt_typewidth : Warning<
   "shift count >= width of type">;
-def warn_op_no_effect : Warning<
-  "operation has no effect">,
-  InGroup<DiagGroup<"all">>, DefaultIgnore;
 
 def err_sizeof_nonfragile_interface : Error<
   "invalid application of '%select{alignof|sizeof}1' to interface %0 in "
index cec1aeafac53ea3cbb345de154818dfa9011df7b..f00ab5412d32fba115ef733db2543ca1cb022f89 100644 (file)
@@ -4136,16 +4136,7 @@ QualType Sema::CheckShiftOperands(Expr *&lex, Expr *&rex, SourceLocation Loc,
   llvm::APSInt Right;
   // Check right/shifter operand
   if (rex->isIntegerConstantExpr(Right, Context)) {
-    // Check left/shiftee operand
-    llvm::APSInt Left;
-    if (lex->isIntegerConstantExpr(Left, Context)) {
-      if (Left == 0 && Right != 0)
-        Diag(Loc, diag::warn_op_no_effect)
-          << lex->getSourceRange() << rex->getSourceRange();
-    }
-    if (isCompAssign && Right == 0)
-      Diag(Loc, diag::warn_op_no_effect) << rex->getSourceRange();
-    else if (Right.isNegative())
+    if (Right.isNegative())
       Diag(Loc, diag::warn_shift_negative) << rex->getSourceRange();
     else {
       llvm::APInt LeftBits(Right.getBitWidth(),
index 4c2b88a7f01d1c3223af4be08e709672a54a0370..2516d1b861072513777819d23a86bd4a68d22949 100644 (file)
@@ -12,15 +12,15 @@ void test() {
   char c;
 
   c = 0 << 0;
-  c = 0 << 1; // expected-warning {{no effect}}
+  c = 0 << 1;
   c = 1 << 0;
   c = 1 << -0;
   c = 1 >> -0;
   c = 1 << -1; // expected-warning {{shift count is negative}}
   c = 1 >> -1; // expected-warning {{shift count is negative}}
   c = 1 << c;
-  c <<= 0; // expected-warning {{no effect}}
-  c >>= 0; // expected-warning {{no effect}}
+  c <<= 0;
+  c >>= 0;
   c <<= 1;
   c >>= 1;
   c <<= -1; // expected-warning {{shift count is negative}}
@@ -33,3 +33,8 @@ void test() {
   c >>= CHAR_BIT+1; // expected-warning {{shift count >= width of type}}
   (void)((long)c << CHAR_BIT);
 }
+
+#define a 0
+#define ashift 8
+enum { b = (a << ashift) };
+