blob: 8905d1c87b8292db88b5b0e19e128caac94afaec [file] [log] [blame]
Dominic Chen2cfd9012017-03-03 18:02:02 +00001// RUN: %clang_analyze_cc1 -analyzer-checker=core -std=c++11 -verify %s
Anna Zaks719b4292012-05-18 22:47:43 +00002
3// radar://11485149, PR12871
4class PlotPoint {
5 bool valid;
6};
7
8PlotPoint limitedFit () {
9 PlotPoint fit0;
10 fit0 = limitedFit ();
11 return fit0;
12}
Anna Zaks671e3bc2012-05-19 00:22:11 +000013
14// radar://11487541, NamespaceAlias
15namespace boost {namespace filesystem3 {
16class path {
17public:
18 path(){}
19};
20
21}}
22namespace boost
23{
24 namespace filesystem
25 {
26 using filesystem3::path;
27 }
28}
29
30void radar11487541() {
31 namespace fs = boost::filesystem;
32 fs::path p;
33}
Anna Zaks13dd47a2012-05-21 22:07:00 +000034
Anna Zaks98553e82012-05-24 17:31:54 +000035// PR12873 radar://11499139
Anna Zaks13dd47a2012-05-21 22:07:00 +000036void testFloatInitializer() {
37 const float ysize={0.015}, xsize={0.01};
38}
Anna Zaks17eb65f2012-05-24 17:31:57 +000039
40
41// PR12874, radar://11487525
42template<class T> struct addr_impl_ref {
43 T & v_;
44 inline addr_impl_ref( T & v ): v_( v ) {
45 }
46 inline operator T& () const {return v_;}
47};
48template<class T> struct addressof_impl {
49 static inline T * f( T & v, long ) {
50 return reinterpret_cast<T*>(&const_cast<char&>(reinterpret_cast<const volatile char &>(v)));
51 }
52};
53template<class T> T * addressof( T & v ) {
54 return addressof_impl<T>::f( addr_impl_ref<T>( v ), 0 );
55}
56void testRadar11487525_1(){
57 bool s[25];
58 addressof(s);
59}
Anna Zakse41458c2012-05-25 16:02:16 +000060
61// radar://11487525 Don't crash on CK_LValueBitCast.
62bool begin(double *it) {
63 typedef bool type[25];
64 bool *a = reinterpret_cast<type &>(*( reinterpret_cast<char *>( it )));
65 return *a;
66}
Anna Zaksbd345202013-06-18 23:16:20 +000067
68// radar://14164698 Don't crash on "assuming" a ComoundVal.
69class JSONWireProtocolInputStream {
70public:
71 virtual ~JSONWireProtocolInputStream();
72};
73class JSONWireProtocolReader {
74public:
75 JSONWireProtocolReader(JSONWireProtocolInputStream& istream)
76 : _istream{istream} {} // On evaluating a bind here,
77 // the dereference checker issues an assume on a CompoundVal.
78~JSONWireProtocolReader();
79private:
80JSONWireProtocolInputStream& _istream;
81};
82class SocketWireProtocolStream : public JSONWireProtocolInputStream {
83};
84void test() {
85 SocketWireProtocolStream stream{};
86 JSONWireProtocolReader reader{stream};
Pavel Labathed2e2de2013-07-02 09:38:48 +000087}
88
89// This crashed because the analyzer did not understand AttributedStmts.
90void fallthrough() {
91 switch (1) {
92 case 1:
Richard Smith14b538d2016-03-08 00:32:55 +000093 [[clang::fallthrough]]; // expected-error {{does not directly precede}}
Pavel Labathed2e2de2013-07-02 09:38:48 +000094 }
95}