[cfe-commits] r108232 - /cfe/trunk/test/SemaCXX/conversion.cpp

John McCall rjmccall at apple.com
Mon Jul 12 23:26:23 PDT 2010


Author: rjmccall
Date: Tue Jul 13 01:26:23 2010
New Revision: 108232

URL: http://llvm.org/viewvc/llvm-project?rev=108232&view=rev
Log:
Check in this -Wconversion C++ test case that's been sitting on my machine
for awhile.


Added:
    cfe/trunk/test/SemaCXX/conversion.cpp

Added: cfe/trunk/test/SemaCXX/conversion.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/test/SemaCXX/conversion.cpp?rev=108232&view=auto
==============================================================================
--- cfe/trunk/test/SemaCXX/conversion.cpp (added)
+++ cfe/trunk/test/SemaCXX/conversion.cpp Tue Jul 13 01:26:23 2010
@@ -0,0 +1,45 @@
+// RUN: %clang_cc1 -triple x86_64-apple-darwin -fsyntax-only -Wconversion -verify %s
+
+typedef   signed char  int8_t;
+typedef   signed short int16_t;
+typedef   signed int   int32_t;
+typedef   signed long  int64_t;
+
+typedef unsigned char  uint8_t;
+typedef unsigned short uint16_t;
+typedef unsigned int   uint32_t;
+typedef unsigned long  uint64_t;
+
+// <rdar://problem/7909130>
+namespace test0 {
+  int32_t test1_positive(char *I, char *E) {
+    return (E - I); // expected-warning {{implicit conversion loses integer precision}}
+  }
+
+  int32_t test1_negative(char *I, char *E) {
+    return static_cast<int32_t>(E - I);
+  }
+
+  uint32_t test2_positive(uint64_t x) {
+    return x; // expected-warning {{implicit conversion loses integer precision}}
+  }
+
+  uint32_t test2_negative(uint64_t x) {
+    return (uint32_t) x;
+  }
+}
+
+namespace test1 {
+  uint64_t test1(int x, unsigned y) {
+    return sizeof(x == y);
+  }
+
+  uint64_t test2(int x, unsigned y) {
+    return __alignof(x == y);
+  }
+
+  void * const foo();
+  bool test2(void *p) {
+    return p == foo();
+  }
+}





More information about the cfe-commits mailing list