[PATCH] Make Clang error on enum increment/decrement in C++

Richard Trieu rtrieu at google.com
Tue Jul 23 17:59:35 PDT 2013


Patch for PR16394, new error for enum increment/decrement.

http://llvm-reviews.chandlerc.com/D1205

Files:
  lib/Sema/SemaExpr.cpp
  test/SemaCXX/enum-increment.cpp
  include/clang/Basic/DiagnosticSemaKinds.td

Index: lib/Sema/SemaExpr.cpp
===================================================================
--- lib/Sema/SemaExpr.cpp
+++ lib/Sema/SemaExpr.cpp
@@ -8302,6 +8302,10 @@
     }
     // Increment of bool sets it to true, but is deprecated.
     S.Diag(OpLoc, diag::warn_increment_bool) << Op->getSourceRange();
+  } else if (S.getLangOpts().CPlusPlus && ResType->isEnumeralType()) {
+    // Error on enum increments and decrements in C++ mode
+    S.Diag(OpLoc, diag::err_increment_decrement_enum) << IsInc << ResType;
+    return QualType();
   } else if (ResType->isRealType()) {
     // OK!
   } else if (ResType->isPointerType()) {
Index: test/SemaCXX/enum-increment.cpp
===================================================================
--- test/SemaCXX/enum-increment.cpp
+++ test/SemaCXX/enum-increment.cpp
@@ -0,0 +1,14 @@
+// RUN: %clang_cc1 -fsyntax-only -x c++ %s -verify
+
+// Increment/decrement of enums is allowed in C.
+// RUN: %clang_cc1 -fsyntax-only -x c %s
+
+enum A { A1, A2, A3 };
+typedef enum A A;
+void test() {
+  A a;
+  a++;  // expected-error{{cannot increment expression of type 'A'}}
+  a--;  // expected-error{{cannot decrement expression of type 'A'}}
+  ++a;  // expected-error{{cannot increment expression of type 'A'}}
+  --a;  // expected-error{{cannot decrement expression of type 'A'}}
+}
Index: include/clang/Basic/DiagnosticSemaKinds.td
===================================================================
--- include/clang/Basic/DiagnosticSemaKinds.td
+++ include/clang/Basic/DiagnosticSemaKinds.td
@@ -4843,6 +4843,8 @@
 def err_decrement_bool : Error<"cannot decrement expression of type bool">;
 def warn_increment_bool : Warning<
   "incrementing expression of type bool is deprecated">, InGroup<Deprecated>;
+def err_increment_decrement_enum : Error<
+  "cannot %select{decrement|increment}0 expression of type %1">;
 def err_catch_incomplete_ptr : Error<
   "cannot catch pointer to incomplete type %0">;
 def err_catch_incomplete_ref : Error<
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D1205.1.patch
Type: text/x-patch
Size: 1993 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/cfe-commits/attachments/20130723/3f657008/attachment.bin>


More information about the cfe-commits mailing list