-
Notifications
You must be signed in to change notification settings - Fork 1
/
.clang-tidy
187 lines (187 loc) · 7.55 KB
/
.clang-tidy
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
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
# Blacklist instead of whitelist
# Reasoning for disabled checks:
# - altera: Altera are FPGA chips, not relevant for us
# - cppcoreguidelines-avoid-magic-numbers: We try to avoid magic numbers, but sometimes it's just easier to read
# - cppcoreguidelines-pro-type-reinterpret-cast: We use reinterpret_cast for type punning
# - cppcoreguidelines-pro-type-union-access: We use unions for type punning
# - fuchsia: Fuchsia is a Google OS with its own coding style
# - google-build-using-namespace: using namespace is fine in .cpp files, especially for unit tests
# - google-readability-braces-around-statements: We don't want braces around single line if statements
# - hicpp-braces-around-statements: Same as above
# - llvm-header-guard: We use #pragma once
# - llvmlibc: checks only relevant for LLVM libc
# - misc-include-cleaner: good idea but too much bother in practice
# - misc-non-private-member-variables-in-classes: I like using structs
# - misc-use-anonymous-namespace: doctest macros emit a warning with this check
# - readability-braces-around-statements: Same as above
# - readability-identifier-length: Who decided that 1 letter variable names are bad? It depends on the context
# - readability-magic-numbers: Same as above
# - readability-uppercase-literal-suffix: I don't see a problem with 1.0f
Checks: >-
*,
-altera-*,
-cppcoreguidelines-avoid-magic-numbers,
-cppcoreguidelines-pro-type-reinterpret-cast,
-cppcoreguidelines-pro-type-union-access,
-fuchsia-*,
fuchsia-multiple-inheritance,
-google-build-using-namespace,
-google-readability-braces-around-statements,
-hicpp-braces-around-statements,
-llvm-header-guard,
-llvmlibc-*,
-misc-include-cleaner,
-misc-non-private-member-variables-in-classes,
-misc-use-anonymous-namespace,
-readability-braces-around-statements,
-readability-identifier-length,
-readability-magic-numbers,
-readability-uppercase-literal-suffix
WarningsAsErrors: ''
CheckOptions:
- key: bugprone-argument-comment.StrictMode
value: 'true'
# Prefer using enum classes with 2 values for parameters instead of bools
- key: bugprone-argument-comment.CommentBoolLiterals
value: 'true'
- key: bugprone-misplaced-widening-cast.CheckImplicitCasts
value: 'true'
- key: bugprone-sizeof-expression.WarnOnSizeOfIntegerExpression
value: 'true'
- key: bugprone-suspicious-string-compare.WarnOnLogicalNotComparison
value: 'true'
- key: readability-simplify-boolean-expr.ChainedConditionalReturn
value: 'true'
- key: readability-simplify-boolean-expr.ChainedConditionalAssignment
value: 'true'
- key: readability-uniqueptr-delete-release.PreferResetCall
value: 'true'
- key: cppcoreguidelines-init-variables.MathHeader
value: <cmath>
- key: cppcoreguidelines-narrowing-conversions.PedanticMode
value: 'true'
- key: cppcoreguidelines-avoid-do-while.IgnoreMacros
value: 'true'
- key: readability-else-after-return.WarnOnUnfixable
value: 'true'
- key: readability-else-after-return.WarnOnConditionVariables
value: 'true'
- key: readability-inconsistent-declaration-parameter-name.Strict
value: 'true'
- key: readability-qualified-auto.AddConstToQualified
value: 'true'
- key: readability-redundant-access-specifiers.CheckFirstDeclaration
value: 'true'
- key: readability-function-cognitive-complexity.IgnoreMacros
value: 'true'
# Identifier styles
- key: readability-identifier-naming.AbstractClassCase
value: CamelCase
- key: readability-identifier-naming.ClassCase
value: CamelCase
- key: readability-identifier-naming.ClassConstantCase
value: lower_case
- key: readability-identifier-naming.ClassMemberCase
value: lower_case
- key: readability-identifier-naming.ClassMethodCase
value: lower_case
- key: readability-identifier-naming.ConstantCase
value: lower_case
- key: readability-identifier-naming.ConstantPrefix
value: k_
- key: readability-identifier-naming.ConstantMemberCase
value: lower_case
- key: readability-identifier-naming.ConstantParameterCase
value: lower_case
- key: readability-identifier-naming.ConstantPointerParameterCase
value: lower_case
- key: readability-identifier-naming.ConstexprFunctionCase
value: lower_case
- key: readability-identifier-naming.ConstexprMethodCase
value: lower_case
- key: readability-identifier-naming.ConstexprVariableCase
value: lower_case
- key: readability-identifier-naming.EnumCase
value: CamelCase
- key: readability-identifier-naming.EnumConstantCase
value: aNy_CasE
- key: readability-identifier-naming.FunctionCase
value: lower_case
- key: readability-identifier-naming.GlobalConstantCase
value: lower_case
- key: readability-identifier-naming.GlobalConstantPrefix
value: k_
- key: readability-identifier-naming.GlobalConstantPointerCase
value: lower_case
- key: readability-identifier-naming.GlobalFunctionCase
value: lower_case
- key: readability-identifier-naming.GlobalPointerCase
value: lower_case
- key: readability-identifier-naming.GlobalVariableCase
value: lower_case
- key: readability-identifier-naming.InlineNamespaceCase
value: lower_case
- key: readability-identifier-naming.LocalConstantCase
value: lower_case
- key: readability-identifier-naming.LocalConstantPointerCase
value: lower_case
- key: readability-identifier-naming.LocalPointerCase
value: lower_case
- key: readability-identifier-naming.LocalVariableCase
value: lower_case
- key: readability-identifier-naming.MacroDefinitionCase
value: UPPER_CASE
- key: readability-identifier-naming.MemberCase
value: lower_case
- key: readability-identifier-naming.MethodCase
value: lower_case
- key: readability-identifier-naming.NamespaceCase
value: lower_case
- key: readability-identifier-naming.ParameterCase
value: lower_case
- key: readability-identifier-naming.ParameterPackCase
value: lower_case
- key: readability-identifier-naming.PointerParameterCase
value: lower_case
- key: readability-identifier-naming.PrivateMemberCase
value: lower_case
- key: readability-identifier-naming.PrivateMemberSuffix
value: _
- key: readability-identifier-naming.PrivateMethodCase
value: lower_case
- key: readability-identifier-naming.ProtectedMemberCase
value: lower_case
- key: readability-identifier-naming.ProtectedMemberSuffix
value: _
- key: readability-identifier-naming.ProtectedMethodCase
value: lower_case
- key: readability-identifier-naming.PublicMemberCase
value: lower_case
- key: readability-identifier-naming.PublicMethodCase
value: lower_case
- key: readability-identifier-naming.ScopedEnumConstantCase
value: aNy_CasE
- key: readability-identifier-naming.StaticConstantCase
value: lower_case
- key: readability-identifier-naming.StaticVariableCase
value: lower_case
- key: readability-identifier-naming.StructCase
value: CamelCase
- key: readability-identifier-naming.TemplateParameterCase
value: CamelCase
- key: readability-identifier-naming.TemplateTemplateParameterCase
value: CamelCase
- key: readability-identifier-naming.TypeAliasCase
value: aNy_CasE
- key: readability-identifier-naming.TypedefCase
value: aNy_CasE
- key: readability-identifier-naming.TypeTemplateParameterCase
value: CamelCase
- key: readability-identifier-naming.UnionCase
value: lower_case
- key: readability-identifier-naming.ValueTemplateParameterCase
value: CamelCase
- key: readability-identifier-naming.VariableCase
value: lower_case
- key: readability-identifier-naming.VirtualMethodCase
value: lower_case