summaryrefslogtreecommitdiff
path: root/clang-tools-extra/docs/clang-tidy/checks/modernize-use-default-member-init.rst
blob: 2d3ed3801493739ad15c84d96b66aa75ac5ade22 (plain)
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
.. title:: clang-tidy - modernize-use-default-member-init

modernize-use-default-member-init
=================================

This check converts constructors' member initializers into the new
default member initializers in C++11. Other member initializers that match the
default member initializer are removed. This can reduce repeated code or allow
use of '= default'.

.. code-block:: c++

  struct A {
    A() : i(5), j(10.0) {}
    A(int i) : i(i), j(10.0) {}
    int i;
    double j;
  };

  // becomes

  struct A {
    A() {}
    A(int i) : i(i) {}
    int i{5};
    double j{10.0};
  };

.. note::
  Only converts member initializers for built-in types, enums, and pointers.
  The `readability-redundant-member-init` check will remove redundant member
  initializers for classes.

Options
-------

.. option:: UseAssignment

   If this option is set to `true` (default is `false`), the check will initialize
   members with an assignment. For example:

.. code-block:: c++

  struct A {
    A() {}
    A(int i) : i(i) {}
    int i = 5;
    double j = 10.0;
  };

.. option:: IgnoreMacros

   If this option is set to `true` (default is `true`), the check will not warn
   about members declared inside macros.