summaryrefslogtreecommitdiffstats
path: root/clang/test/SemaCXX/undefined-internal.cpp
diff options
context:
space:
mode:
authorRichard Smith <richard-llvm@metafoo.co.uk>2017-01-06 22:52:53 +0000
committerRichard Smith <richard-llvm@metafoo.co.uk>2017-01-06 22:52:53 +0000
commite5945871cfb954d80cbeb9c99a26f02b41decae6 (patch)
tree20598a89710fa1f1c7f89b98a972933153da7d49 /clang/test/SemaCXX/undefined-internal.cpp
parent1fb895e890b095e9b155239d28ec21340aa538de (diff)
downloadbcm5719-llvm-e5945871cfb954d80cbeb9c99a26f02b41decae6.tar.gz
bcm5719-llvm-e5945871cfb954d80cbeb9c99a26f02b41decae6.zip
Revisit PR10177: don't instantiate a variable if it's only referenced in a
dependent context and can't be used in a constant expression. Per C++ [temp.inst]p2, "the instantiation of a static data member does not occur unless the static data member is used in a way that requires the definition to exist". This doesn't /quite/ match that, as we still instantiate static data members that are usable in constant expressions even if the use doesn't require a definition. A followup patch will fix that for both variables and functions. llvm-svn: 291295
Diffstat (limited to 'clang/test/SemaCXX/undefined-internal.cpp')
-rw-r--r--clang/test/SemaCXX/undefined-internal.cpp11
1 files changed, 8 insertions, 3 deletions
diff --git a/clang/test/SemaCXX/undefined-internal.cpp b/clang/test/SemaCXX/undefined-internal.cpp
index 59e6fdf9af0..32151b71ea1 100644
--- a/clang/test/SemaCXX/undefined-internal.cpp
+++ b/clang/test/SemaCXX/undefined-internal.cpp
@@ -186,10 +186,15 @@ namespace OverloadUse {
namespace {
void f();
void f(int); // expected-warning {{function 'OverloadUse::(anonymous namespace)::f' has internal linkage but is not defined}}
+ void f(int, int); // expected-warning {{function 'OverloadUse::(anonymous namespace)::f' has internal linkage but is not defined}}
+ }
+ template<void x()> void t() { x(); }
+ template<void x(int)> void t(int*) { x(10); }
+ template<void x(int, int)> void t(int*, int*) {}
+ void g(int n) {
+ t<f>(&n); // expected-note {{used here}}
+ t<f>(&n, &n); // expected-note {{used here}}
}
- template<void x()> void t(int*) { x(); }
- template<void x(int)> void t(long*) { x(10); } // expected-note {{used here}}
- void g() { long a; t<f>(&a); }
}
namespace test7 {
OpenPOWER on IntegriCloud