blob: bcf6eb60d0d74ae7b44ea58ba88c9aea14b8bd03 [file] [log] [blame]
Manuel Klimekb91bee02015-10-22 11:31:44 +00001// RUN: %check_clang_tidy %s google-runtime-int %t
Benjamin Kramer06e323a2014-08-29 14:38:46 +00002
3long a();
Alexander Kornienko106c8e02014-10-26 02:58:07 +00004// CHECK-MESSAGES: [[@LINE-1]]:1: warning: consider replacing 'long' with 'int{{..}}'
Benjamin Kramer06e323a2014-08-29 14:38:46 +00005
6typedef unsigned long long uint64; // NOLINT
7
8long b(long = 1);
Alexander Kornienko106c8e02014-10-26 02:58:07 +00009// CHECK-MESSAGES: [[@LINE-1]]:1: warning: consider replacing 'long' with 'int{{..}}'
10// CHECK-MESSAGES: [[@LINE-2]]:8: warning: consider replacing 'long' with 'int{{..}}'
Benjamin Kramer06e323a2014-08-29 14:38:46 +000011
12template <typename T>
13void tmpl() {
14 T i;
15}
16
17short bar(const short, unsigned short) {
Alexander Kornienko106c8e02014-10-26 02:58:07 +000018// CHECK-MESSAGES: [[@LINE-1]]:1: warning: consider replacing 'short' with 'int16'
19// CHECK-MESSAGES: [[@LINE-2]]:17: warning: consider replacing 'short' with 'int16'
20// CHECK-MESSAGES: [[@LINE-3]]:24: warning: consider replacing 'unsigned short' with 'uint16'
Benjamin Kramer06e323a2014-08-29 14:38:46 +000021 long double foo = 42;
22 uint64 qux = 42;
23 unsigned short port;
24
25 const unsigned short bar = 0;
Alexander Kornienko106c8e02014-10-26 02:58:07 +000026// CHECK-MESSAGES: [[@LINE-1]]:9: warning: consider replacing 'unsigned short' with 'uint16'
Benjamin Kramer06e323a2014-08-29 14:38:46 +000027 long long *baar;
Alexander Kornienko106c8e02014-10-26 02:58:07 +000028// CHECK-MESSAGES: [[@LINE-1]]:3: warning: consider replacing 'long long' with 'int64'
Benjamin Kramer06e323a2014-08-29 14:38:46 +000029 const unsigned short &bara = bar;
Alexander Kornienko106c8e02014-10-26 02:58:07 +000030// CHECK-MESSAGES: [[@LINE-1]]:9: warning: consider replacing 'unsigned short' with 'uint16'
Benjamin Kramer06e323a2014-08-29 14:38:46 +000031 long const long moo = 1;
Alexander Kornienko106c8e02014-10-26 02:58:07 +000032// CHECK-MESSAGES: [[@LINE-1]]:3: warning: consider replacing 'long long' with 'int64'
Benjamin Kramer06e323a2014-08-29 14:38:46 +000033 long volatile long wat = 42;
Alexander Kornienko106c8e02014-10-26 02:58:07 +000034// CHECK-MESSAGES: [[@LINE-1]]:3: warning: consider replacing 'long long' with 'int64'
Benjamin Kramer06e323a2014-08-29 14:38:46 +000035 unsigned long y;
Alexander Kornienko106c8e02014-10-26 02:58:07 +000036// CHECK-MESSAGES: [[@LINE-1]]:3: warning: consider replacing 'unsigned long' with 'uint{{..}}'
Benjamin Kramer06e323a2014-08-29 14:38:46 +000037 unsigned long long **const *tmp;
Alexander Kornienko106c8e02014-10-26 02:58:07 +000038// CHECK-MESSAGES: [[@LINE-1]]:3: warning: consider replacing 'unsigned long long' with 'uint64'
Benjamin Kramer06e323a2014-08-29 14:38:46 +000039 unsigned long long **const *&z = tmp;
Alexander Kornienko106c8e02014-10-26 02:58:07 +000040// CHECK-MESSAGES: [[@LINE-1]]:3: warning: consider replacing 'unsigned long long' with 'uint64'
Benjamin Kramer06e323a2014-08-29 14:38:46 +000041 unsigned short porthole;
Alexander Kornienko106c8e02014-10-26 02:58:07 +000042// CHECK-MESSAGES: [[@LINE-1]]:3: warning: consider replacing 'unsigned short' with 'uint16'
Benjamin Kramer06e323a2014-08-29 14:38:46 +000043
Benjamin Kramer35008452014-09-02 09:46:43 +000044 uint64 cast = (short)42;
Alexander Kornienko106c8e02014-10-26 02:58:07 +000045// CHECK-MESSAGES: [[@LINE-1]]:18: warning: consider replacing 'short' with 'int16'
Benjamin Kramer35008452014-09-02 09:46:43 +000046
Benjamin Kramer06e323a2014-08-29 14:38:46 +000047#define l long
48 l x;
49
50 tmpl<short>();
Alexander Kornienko106c8e02014-10-26 02:58:07 +000051// CHECK-MESSAGES: [[@LINE-1]]:8: warning: consider replacing 'short' with 'int16'
Alexander Kornienko4d48e1e2015-09-16 15:08:46 +000052 return 0;
Benjamin Kramer06e323a2014-08-29 14:38:46 +000053}
54
Benjamin Kramer35008452014-09-02 09:46:43 +000055void p(unsigned short port);
56
Benjamin Kramer06e323a2014-08-29 14:38:46 +000057void qux() {
58 short port;
Alexander Kornienko106c8e02014-10-26 02:58:07 +000059// CHECK-MESSAGES: [[@LINE-1]]:3: warning: consider replacing 'short' with 'int16'
Benjamin Kramer06e323a2014-08-29 14:38:46 +000060}
Alexander Kornienko4d48e1e2015-09-16 15:08:46 +000061
62// FIXME: This shouldn't warn, as UD-literal operators require one of a handful
63// of types as an argument.
64struct some_value {};
65constexpr some_value operator"" _some_literal(unsigned long long int i);
66// CHECK-MESSAGES: [[@LINE-1]]:47: warning: consider replacing 'unsigned long long'
67