]> granicus.if.org Git - clang/commitdiff
Add a (currently failing) RTTI layout test.
authorAnders Carlsson <andersca@mac.com>
Thu, 17 Dec 2009 04:41:05 +0000 (04:41 +0000)
committerAnders Carlsson <andersca@mac.com>
Thu, 17 Dec 2009 04:41:05 +0000 (04:41 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@91580 91177308-0d34-0410-b5e6-96231b3b80d8

test/CodeGenCXX/rtti-layout.cpp [new file with mode: 0644]

diff --git a/test/CodeGenCXX/rtti-layout.cpp b/test/CodeGenCXX/rtti-layout.cpp
new file mode 100644 (file)
index 0000000..fb12f3a
--- /dev/null
@@ -0,0 +1,47 @@
+// RUN: %clang_cc1 %s -triple=x86_64-apple-darwin10 -emit-llvm -O3 -o - | FileCheck %s
+#include <typeinfo>
+
+class __pbase_type_info : public std::type_info {
+public:
+  unsigned int __flags;
+  const std::type_info *__pointee;
+
+  enum __masks {
+    __const_mask = 0x1,
+    __volatile_mask = 0x2,
+    __restrict_mask = 0x4,
+    __incomplete_mask = 0x8,
+    __incomplete_class_mask = 0x10
+  };
+};
+
+template<typename T> const T& to(const std::type_info &info) {
+return static_cast<const T&>(info);
+}
+struct Incomplete;
+
+// CHECK: define i32 @_Z1fv()
+int f() {
+  if (to<__pbase_type_info>(typeid(Incomplete *)).__flags != __pbase_type_info::__incomplete_mask)
+    return 1;
+    
+  // Success!
+  return 0;
+}
+
+#ifdef HARNESS
+extern "C" void printf(const char *, ...);
+
+int main() {
+  int result = f();
+  
+  if (result == 0)
+    printf("success!\n");
+  else
+    printf("test %d failed!\n", result);
+
+  return result;
+}
+#endif
+
+