From 32a9e831c27dd18e388e02a6bf1e95aae240c575 Mon Sep 17 00:00:00 2001 From: Stuart Hastings Date: Mon, 2 Aug 2010 22:09:53 +0000 Subject: [PATCH] Testcase for r110043. Radar 8246180. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@110070 91177308-0d34-0410-b5e6-96231b3b80d8 --- .../2010-08-02-NonPODObjectValue.mm | 24 +++++++++++++++++++ 1 file changed, 24 insertions(+) create mode 100644 test/FrontendObjC++/2010-08-02-NonPODObjectValue.mm diff --git a/test/FrontendObjC++/2010-08-02-NonPODObjectValue.mm b/test/FrontendObjC++/2010-08-02-NonPODObjectValue.mm new file mode 100644 index 00000000000..216286302ca --- /dev/null +++ b/test/FrontendObjC++/2010-08-02-NonPODObjectValue.mm @@ -0,0 +1,24 @@ +// RUN: not %llvmgcc %s -S -emit-llvm -o - |& FileCheck %s +// This tests for a specific diagnostic in LLVM-GCC. +// Clang compiles this correctly with no diagnostic, +// ergo this test will fail with a Clang-based front-end. +class TFENodeVector { +public: + TFENodeVector(const TFENodeVector& inNodeVector); + TFENodeVector(); +}; + +@interface TWindowHistoryEntry {} +@property (assign, nonatomic) TFENodeVector targetPath; +@end + +@implementation TWindowHistoryEntry +@synthesize targetPath; +- (void) initWithWindowController { + TWindowHistoryEntry* entry; + TFENodeVector newPath; + // CHECK: setting a C++ non-POD object value is not implemented + entry.targetPath = newPath; + [entry setTargetPath:newPath]; +} +@end