xref: /llvm-project/clang-tools-extra/test/clang-tidy/checkers/modernize/use-auto-new-remove-stars.cpp (revision e8a3ddafe063c970df9c23e803812369abde4c82)
189a1d03eSRichard // RUN: %check_clang_tidy %s modernize-use-auto %t -- \
2*e8a3ddafSNathan James // RUN:   -config="{CheckOptions: {modernize-use-auto.RemoveStars: 'true', modernize-use-auto.MinTypeNameLength: '0'}}"
389a1d03eSRichard 
489a1d03eSRichard class MyType {};
589a1d03eSRichard 
689a1d03eSRichard class MyDerivedType : public MyType {};
789a1d03eSRichard 
889a1d03eSRichard // FIXME: the replacement sometimes results in two consecutive spaces after
989a1d03eSRichard // the word 'auto' (due to the presence of spaces at both sides of '*').
auto_new()1089a1d03eSRichard void auto_new() {
1189a1d03eSRichard   MyType *a_new = new MyType();
1289a1d03eSRichard   // CHECK-MESSAGES: :[[@LINE-1]]:3: warning: use auto when initializing with new
1389a1d03eSRichard   // CHECK-FIXES: auto a_new = new MyType();
1489a1d03eSRichard 
1589a1d03eSRichard   static MyType *a_static = new MyType();
1689a1d03eSRichard   // CHECK-MESSAGES: :[[@LINE-1]]:10: warning: use auto when initializing with new
1789a1d03eSRichard   // CHECK-FIXES: static auto a_static = new MyType();
1889a1d03eSRichard 
1989a1d03eSRichard   MyType *derived = new MyDerivedType();
2089a1d03eSRichard 
2189a1d03eSRichard   void *vd = new MyType();
2289a1d03eSRichard 
2389a1d03eSRichard   // CV-qualifier tests.
2489a1d03eSRichard   //
2589a1d03eSRichard   // NOTE : the form "type const" is expected here because of a deficiency in
2689a1d03eSRichard   // TypeLoc where CV qualifiers are not considered part of the type location
2789a1d03eSRichard   // info. That is, all that is being replaced in each case is "MyType *" and
2889a1d03eSRichard   // not "MyType * const".
2989a1d03eSRichard   static MyType * const d_static = new MyType();
3089a1d03eSRichard   // CHECK-MESSAGES: :[[@LINE-1]]:10: warning: use auto when initializing with new
3189a1d03eSRichard   // CHECK-FIXES: static auto  const d_static = new MyType();
3289a1d03eSRichard 
3389a1d03eSRichard   MyType * const a_const = new MyType();
3489a1d03eSRichard   // CHECK-MESSAGES: :[[@LINE-1]]:3: warning: use auto when initializing with new
3589a1d03eSRichard   // CHECK-FIXES: auto  const a_const = new MyType();
3689a1d03eSRichard 
3789a1d03eSRichard   MyType * volatile vol = new MyType();
3889a1d03eSRichard   // CHECK-MESSAGES: :[[@LINE-1]]:3: warning: use auto when initializing with new
3989a1d03eSRichard   // CHECK-FIXES: auto  volatile vol = new MyType();
4089a1d03eSRichard 
4189a1d03eSRichard   struct SType {} *stype = new SType;
4289a1d03eSRichard 
4389a1d03eSRichard   int (**func)(int, int) = new (int(*[5])(int,int));
4489a1d03eSRichard 
4589a1d03eSRichard   int *array = new int[5];
4689a1d03eSRichard   // CHECK-MESSAGES: :[[@LINE-1]]:3: warning: use auto when initializing with new
4789a1d03eSRichard   // CHECK-FIXES: auto array = new int[5];
4889a1d03eSRichard 
4989a1d03eSRichard   MyType *ptr(new MyType);
5089a1d03eSRichard   // CHECK-MESSAGES: :[[@LINE-1]]:3: warning: use auto when initializing with new
5189a1d03eSRichard   // CHECK-FIXES: auto ptr(new MyType);
5289a1d03eSRichard 
5389a1d03eSRichard   MyType *ptr2{new MyType};
5489a1d03eSRichard 
5589a1d03eSRichard   {
5689a1d03eSRichard     // Test for declaration lists.
5789a1d03eSRichard     MyType *a = new MyType(), *b = new MyType(), *c = new MyType();
5889a1d03eSRichard     // CHECK-MESSAGES: :[[@LINE-1]]:5: warning: use auto when initializing with new
5989a1d03eSRichard     // CHECK-FIXES: auto a = new MyType(), b = new MyType(), c = new MyType();
6089a1d03eSRichard 
6189a1d03eSRichard     // Non-initialized declaration should not be transformed.
6289a1d03eSRichard     MyType *d = new MyType(), *e;
6389a1d03eSRichard 
6489a1d03eSRichard     MyType **f = new MyType*(), **g = new MyType*();
6589a1d03eSRichard     // CHECK-MESSAGES: :[[@LINE-1]]:5: warning: use auto when initializing with new
6689a1d03eSRichard     // CHECK-FIXES: auto f = new MyType*(), g = new MyType*();
6789a1d03eSRichard 
6889a1d03eSRichard     // Mismatching types in declaration lists should not be transformed.
6989a1d03eSRichard     MyType *h = new MyType(), **i = new MyType*();
7089a1d03eSRichard 
7189a1d03eSRichard     // '*' shouldn't be removed in case of mismatching types with multiple
7289a1d03eSRichard     // declarations.
7389a1d03eSRichard     MyType *j = new MyType(), *k = new MyType(), **l = new MyType*();
7489a1d03eSRichard   }
7589a1d03eSRichard 
7689a1d03eSRichard   {
7789a1d03eSRichard     // Test for typedefs.
7889a1d03eSRichard     typedef int * int_p;
7989a1d03eSRichard     // CHECK-FIXES: typedef int * int_p;
8089a1d03eSRichard 
8189a1d03eSRichard     int_p a = new int;
8289a1d03eSRichard     // CHECK-MESSAGES: :[[@LINE-1]]:5: warning: use auto when initializing with new
8389a1d03eSRichard     // CHECK-FIXES: auto  a = new int;
8489a1d03eSRichard     int_p *b = new int*;
8589a1d03eSRichard     // CHECK-MESSAGES: :[[@LINE-1]]:5: warning: use auto when initializing with new
8689a1d03eSRichard     // CHECK-FIXES: auto b = new int*;
8789a1d03eSRichard 
8889a1d03eSRichard     // Test for typedefs in declarations lists.
8989a1d03eSRichard     int_p c = new int, d = new int;
9089a1d03eSRichard     // CHECK-MESSAGES: :[[@LINE-1]]:5: warning: use auto when initializing with new
9189a1d03eSRichard     // CHECK-FIXES: auto  c = new int, d = new int;
9289a1d03eSRichard 
9389a1d03eSRichard     // Different types should not be transformed.
9489a1d03eSRichard     int_p e = new int, *f = new int_p;
9589a1d03eSRichard 
9689a1d03eSRichard     int_p *g = new int*, *h = new int_p;
9789a1d03eSRichard     // CHECK-MESSAGES: :[[@LINE-1]]:5: warning: use auto when initializing with new
9889a1d03eSRichard     // CHECK-FIXES: auto g = new int*, h = new int_p;
9989a1d03eSRichard   }
10089a1d03eSRichard 
10189a1d03eSRichard   // Don't warn when 'auto' is already being used.
10289a1d03eSRichard   auto aut = new MyType();
10389a1d03eSRichard   auto *paut = new MyType();
10489a1d03eSRichard   const auto *pcaut = new MyType();
10589a1d03eSRichard }
106