From 222e2a7620e6520ffaf4fc4e69d79c18da31542e Mon Sep 17 00:00:00 2001 From: "Zancanaro; Carlo" Date: Mon, 24 Sep 2012 09:58:17 +1000 Subject: Add the clang library to the repo (with some of my changes, too). --- .../SemaTemplate/instantiate-member-pointers.cpp | 67 ++++++++++++++++++++++ 1 file changed, 67 insertions(+) create mode 100644 clang/test/SemaTemplate/instantiate-member-pointers.cpp (limited to 'clang/test/SemaTemplate/instantiate-member-pointers.cpp') diff --git a/clang/test/SemaTemplate/instantiate-member-pointers.cpp b/clang/test/SemaTemplate/instantiate-member-pointers.cpp new file mode 100644 index 0000000..0db90e3 --- /dev/null +++ b/clang/test/SemaTemplate/instantiate-member-pointers.cpp @@ -0,0 +1,67 @@ +// RUN: %clang_cc1 -fsyntax-only -verify %s +struct Y { + int x; +}; + +template +struct X1 { + int f(T* ptr, int T::*pm) { // expected-error{{member pointer}} + return ptr->*pm; + } +}; + +template struct X1; +template struct X1; // expected-note{{instantiation}} + +template +struct X2 { + T f(Class &obj, T Class::*pm) { // expected-error{{to a reference}} \ + // expected-error{{member pointer to void}} + return obj.*pm; + } +}; + +template struct X2; +template struct X2; // expected-note{{instantiation}} +template struct X2; // expected-note{{instantiation}} + +template +struct X3 { + X3 &operator=(const T& value) { + return *this; + } +}; + +X3 x3; + +typedef int Y::*IntMember; + +template +struct X4 { + X3 member; + + int &getMember(Y& y) { return y.*Member; } +}; + +int &get_X4(X4<&Y::x> x4, Y& y) { + return x4.getMember(y); +} + +template +void accept_X4(X4); + +void test_accept_X4(X4<&Y::x> x4) { + accept_X4(x4); +} + +namespace ValueDepMemberPointer { + template struct instantiate_function {}; + template struct S { + static void instantiate(); + typedef instantiate_function<&S::instantiate> x; // expected-note{{instantiation}} + }; + template void S::instantiate() { + int a[(int)sizeof(T)-42]; // expected-error{{array with a negative size}} + } + S s; +} -- cgit v1.2.3