undefined-inline.cpp
2.07 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
// RUN: %clang_cc1 -fsyntax-only -triple i686-pc-win32 -verify -std=c++11 %s
// PR14993
namespace test1 {
inline void f(); // expected-warning{{inline function 'test1::f' is not defined}}
void test() { f(); } // expected-note{{used here}}
}
namespace test2 {
inline int f();
void test() { (void)sizeof(f()); }
}
namespace test3 {
void f(); // expected-warning{{inline function 'test3::f' is not defined}}
inline void f();
void test() { f(); } // expected-note{{used here}}
}
namespace test4 {
inline void error_on_zero(int); // expected-warning{{inline function 'test4::error_on_zero' is not defined}}
inline void error_on_zero(char*) {}
void test() { error_on_zero(0); } // expected-note{{used here}}
}
namespace test5 {
struct X { void f(); };
void test(X &x) { x.f(); }
}
namespace test6 {
struct X { inline void f(); }; // expected-warning{{inline function 'test6::X::f' is not defined}}
void test(X &x) { x.f(); } // expected-note{{used here}}
}
namespace test7 {
void f(); // expected-warning{{inline function 'test7::f' is not defined}}
void test() { f(); } // no used-here note.
inline void f();
}
namespace test8 {
inline void foo() __attribute__((gnu_inline)); // expected-warning {{'gnu_inline' attribute without 'extern' in C++ treated as externally available, this changed in Clang 10}}
void test() { foo(); }
}
namespace test9 {
void foo();
void test() { foo(); }
inline void foo() __attribute__((gnu_inline)); // expected-warning {{'gnu_inline' attribute without 'extern' in C++ treated as externally available, this changed in Clang 10}}
}
namespace test10 {
inline void foo();
void test() { foo(); }
inline void foo() __attribute__((gnu_inline)); // expected-warning {{'gnu_inline' attribute without 'extern' in C++ treated as externally available, this changed in Clang 10}}
}
namespace test11 {
inline void foo() __attribute__((dllexport));
inline void bar() __attribute__((dllimport));
void test() { foo(); bar(); }
}
namespace test12 {
template<typename> constexpr int _S_chk(int *);
decltype(_S_chk<int>(nullptr)) n;
}