]> granicus.if.org Git - clang/commitdiff
Make suggestions for mismatched enum arguments to printf/scanf.
authorJordan Rose <jordan_rose@apple.com>
Mon, 4 Jun 2012 22:49:02 +0000 (22:49 +0000)
committerJordan Rose <jordan_rose@apple.com>
Mon, 4 Jun 2012 22:49:02 +0000 (22:49 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@157962 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Analysis/PrintfFormatString.cpp
lib/Analysis/ScanfFormatString.cpp
test/FixIt/format.m

index 3b3a0b176e9dec0a162e7659c62c292450508ca6..aa6d7424c0a56bf20beebfe9653a8cb21f95c3ff 100644 (file)
@@ -381,6 +381,10 @@ bool PrintfSpecifier::fixType(QualType QT, const LangOptions &LangOpt,
     return true;
   }
 
+  // If it's an enum, get its underlying type.
+  if (const EnumType *ETy = QT->getAs<EnumType>())
+    QT = ETy->getDecl()->getIntegerType();
+
   // We can only work with builtin types.
   const BuiltinType *BT = QT->getAs<BuiltinType>();
   if (!BT)
index 6bc4adb4f3c62613e509d62145eb3f16aa50e0c4..066d5d6fa13e62dd158cf68c62b0ab3b61973837 100644 (file)
@@ -316,6 +316,11 @@ bool ScanfSpecifier::fixType(QualType QT, const LangOptions &LangOpt,
     return false;
 
   QualType PT = QT->getPointeeType();
+
+  // If it's an enum, get its underlying type.
+  if (const EnumType *ETy = QT->getAs<EnumType>())
+    QT = ETy->getDecl()->getIntegerType();
+  
   const BuiltinType *BT = PT->getAs<BuiltinType>();
   if (!BT)
     return false;
index d9589a0148d45aef82222bf47840d01de63a8852..c4747019b2df6badbb9948c62bc3a28e5d22ccfd 100644 (file)
@@ -79,3 +79,17 @@ void test_class_correction (Class x) {
   // CHECK: fix-it:"{{.*}}":{75:11-75:14}:"%@"
 }
 
+
+typedef enum : int { NSUTF8StringEncoding = 8 } NSStringEncoding;
+void test_fixed_enum_correction(NSStringEncoding x) {
+  NSLog(@"%@", x); // expected-warning{{format specifies type 'id' but the argument has type 'NSStringEncoding'}}
+  // CHECK: fix-it:"{{.*}}":{85:11-85:13}:"%d"
+}
+
+typedef __SIZE_TYPE__ size_t;
+enum SomeSize : size_t { IntegerSize = sizeof(int) };
+void test_named_fixed_enum_correction(enum SomeSize x) {
+  NSLog(@"%@", x); // expected-warning{{format specifies type 'id' but the argument has type 'enum SomeSize'}}
+  // CHECK: fix-it:"{{.*}}":{92:11-92:13}:"%zu"
+}
+