2015-12-23 01:36:49 +08:00
|
|
|
.. title:: clang-tidy - readability-identifier-naming
|
|
|
|
|
2015-08-28 02:10:07 +08:00
|
|
|
readability-identifier-naming
|
|
|
|
=============================
|
|
|
|
|
|
|
|
Checks for identifiers naming style mismatch.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
This check will try to enforce coding guidelines on the identifiers naming. It
|
|
|
|
supports one of the following casing types and tries to convert from one to
|
|
|
|
another if a mismatch is detected
|
2015-08-28 02:10:07 +08:00
|
|
|
|
2020-01-04 23:28:41 +08:00
|
|
|
Casing types include:
|
2019-01-16 06:06:49 +08:00
|
|
|
|
|
|
|
- ``lower_case``,
|
|
|
|
- ``UPPER_CASE``,
|
|
|
|
- ``camelBack``,
|
|
|
|
- ``CamelCase``,
|
|
|
|
- ``camel_Snake_Back``,
|
|
|
|
- ``Camel_Snake_Case``,
|
|
|
|
- ``aNy_CasE``.
|
|
|
|
|
|
|
|
It also supports a fixed prefix and suffix that will be prepended or appended
|
|
|
|
to the identifiers, regardless of the casing.
|
2015-08-28 02:10:07 +08:00
|
|
|
|
|
|
|
Many configuration options are available, in order to be able to create
|
2019-01-16 06:06:49 +08:00
|
|
|
different rules for different kinds of identifiers. In general, the rules are
|
|
|
|
falling back to a more generic rule if the specific case is not configured.
|
|
|
|
|
2019-08-28 20:08:57 +08:00
|
|
|
The naming of virtual methods is reported where they occur in the base class,
|
|
|
|
but not where they are overridden, as it can't be fixed locally there.
|
|
|
|
This also applies for pseudo-override patterns like CRTP.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
Options
|
|
|
|
-------
|
|
|
|
|
|
|
|
The following options are describe below:
|
|
|
|
|
2021-08-02 06:20:12 +08:00
|
|
|
- :option:`AbstractClassCase`, :option:`AbstractClassPrefix`, :option:`AbstractClassSuffix`, :option:`AbstractClassIgnoredRegexp`, :option:`AbstractClassHungarianPrefix`
|
[clang-tidy] RenamerClangTidy now renames dependent member expr when the member can be resolved
Summary:
Sometimes in templated code Member references are reported as `DependentScopeMemberExpr` because that's what the standard dictates, however in many trivial cases it is easy to resolve the reference to its actual Member.
Take this code:
```
template<typename T>
class A{
int value;
A& operator=(const A& Other){
value = Other.value;
this->value = Other.value;
return *this;
}
};
```
When ran with `clang-tidy file.cpp -checks=readability-identifier-naming --config="{CheckOptions: [{key: readability-identifier-naming.MemberPrefix, value: m_}]}" -fix`
Current behaviour:
```
template<typename T>
class A{
int m_value;
A& operator=(const A& Other){
m_value = Other.value;
this->value = Other.value;
return *this;
}
};
```
As `this->value` and `Other.value` are Dependent they are ignored when creating the fix-its, however this can easily be resolved.
Proposed behaviour:
```
template<typename T>
class A{
int m_value;
A& operator=(const A& Other){
m_value = Other.m_value;
this->m_value = Other.m_value;
return *this;
}
};
```
Reviewers: aaron.ballman, JonasToth, alexfh, hokein, gribozavr2
Reviewed By: aaron.ballman
Subscribers: merge_guards_bot, xazax.hun, cfe-commits
Tags: #clang, #clang-tools-extra
Differential Revision: https://reviews.llvm.org/D73052
2020-05-09 02:30:18 +08:00
|
|
|
- :option:`AggressiveDependentMemberLookup`
|
2021-08-02 06:20:12 +08:00
|
|
|
- :option:`ClassCase`, :option:`ClassPrefix`, :option:`ClassSuffix`, :option:`ClassIgnoredRegexp`, :option:`ClassHungarianPrefix`
|
|
|
|
- :option:`ClassConstantCase`, :option:`ClassConstantPrefix`, :option:`ClassConstantSuffix`, :option:`ClassConstantIgnoredRegexp`, :option:`ClassConstantHungarianPrefix`
|
|
|
|
- :option:`ClassMemberCase`, :option:`ClassMemberPrefix`, :option:`ClassMemberSuffix`, :option:`ClassMemberIgnoredRegexp`, :option:`ClassMemberHungarianPrefix`
|
2020-11-25 09:18:38 +08:00
|
|
|
- :option:`ClassMethodCase`, :option:`ClassMethodPrefix`, :option:`ClassMethodSuffix`, :option:`ClassMethodIgnoredRegexp`
|
2021-08-02 06:20:12 +08:00
|
|
|
- :option:`ConstantCase`, :option:`ConstantPrefix`, :option:`ConstantSuffix`, :option:`ConstantIgnoredRegexp`, :option:`ConstantHungarianPrefix`
|
|
|
|
- :option:`ConstantMemberCase`, :option:`ConstantMemberPrefix`, :option:`ConstantMemberSuffix`, :option:`ConstantMemberIgnoredRegexp`, :option:`ConstantMemberHungarianPrefix`
|
|
|
|
- :option:`ConstantParameterCase`, :option:`ConstantParameterPrefix`, :option:`ConstantParameterSuffix`, :option:`ConstantParameterIgnoredRegexp`, :option:`ConstantParameterHungarianPrefix`
|
|
|
|
- :option:`ConstantPointerParameterCase`, :option:`ConstantPointerParameterPrefix`, :option:`ConstantPointerParameterSuffix`, :option:`ConstantPointerParameterIgnoredRegexp`, :option:`ConstantPointerParameterHungarianPrefix`
|
2020-11-25 09:18:38 +08:00
|
|
|
- :option:`ConstexprFunctionCase`, :option:`ConstexprFunctionPrefix`, :option:`ConstexprFunctionSuffix`, :option:`ConstexprFunctionIgnoredRegexp`
|
|
|
|
- :option:`ConstexprMethodCase`, :option:`ConstexprMethodPrefix`, :option:`ConstexprMethodSuffix`, :option:`ConstexprMethodIgnoredRegexp`
|
2021-08-02 06:20:12 +08:00
|
|
|
- :option:`ConstexprVariableCase`, :option:`ConstexprVariablePrefix`, :option:`ConstexprVariableSuffix`, :option:`ConstexprVariableIgnoredRegexp`, :option:`ConstexprVariableHungarianPrefix`
|
2020-11-25 09:18:38 +08:00
|
|
|
- :option:`EnumCase`, :option:`EnumPrefix`, :option:`EnumSuffix`, :option:`EnumIgnoredRegexp`
|
2021-08-02 06:20:12 +08:00
|
|
|
- :option:`EnumConstantCase`, :option:`EnumConstantPrefix`, :option:`EnumConstantSuffix`, :option:`EnumConstantIgnoredRegexp`, :option:`EnumConstantHungarianPrefix`
|
2020-11-25 09:18:38 +08:00
|
|
|
- :option:`FunctionCase`, :option:`FunctionPrefix`, :option:`FunctionSuffix`, :option:`FunctionIgnoredRegexp`
|
2020-08-01 17:35:13 +08:00
|
|
|
- :option:`GetConfigPerFile`
|
2021-08-02 06:20:12 +08:00
|
|
|
- :option:`GlobalConstantCase`, :option:`GlobalConstantPrefix`, :option:`GlobalConstantSuffix`, :option:`GlobalConstantIgnoredRegexp`, :option:`GlobalConstantHungarianPrefix`
|
|
|
|
- :option:`GlobalConstantPointerCase`, :option:`GlobalConstantPointerPrefix`, :option:`GlobalConstantPointerSuffix`, :option:`GlobalConstantPointerIgnoredRegexp`, :option:`GlobalConstantPointerHungarianPrefix`
|
2020-11-25 09:18:38 +08:00
|
|
|
- :option:`GlobalFunctionCase`, :option:`GlobalFunctionPrefix`, :option:`GlobalFunctionSuffix`, :option:`GlobalFunctionIgnoredRegexp`
|
2021-08-02 06:20:12 +08:00
|
|
|
- :option:`GlobalPointerCase`, :option:`GlobalPointerPrefix`, :option:`GlobalPointerSuffix`, :option:`GlobalPointerIgnoredRegexp`, :option:`GlobalPointerHungarianPrefix`
|
|
|
|
- :option:`GlobalVariableCase`, :option:`GlobalVariablePrefix`, :option:`GlobalVariableSuffix`, :option:`GlobalVariableIgnoredRegexp`, :option:`GlobalVariableHungarianPrefix`
|
[clang-tidy] readability-identifier-naming disregards parameters restrictions on main like functions
Summary:
Typically most main functions have the signature:
```
int main(int argc, char *argv[])
```
To stick with convention when renaming parameters we should ignore the `argc` and `argv` names even if the parameter style says they should be renamed. This patch addresses this by checking all ParmVarDecls if they form part of a function with a signature that matches main `int name(int argc, char * argv[], (optional char *env[]))`
Reviewers: aaron.ballman, JonasToth, alexfh, hokein
Reviewed By: aaron.ballman
Subscribers: Mordante, merge_guards_bot, xazax.hun, kristof.beyls, cfe-commits
Tags: #clang, #clang-tools-extra
Differential Revision: https://reviews.llvm.org/D73098
2020-01-28 07:46:53 +08:00
|
|
|
- :option:`IgnoreMainLikeFunctions`
|
2020-11-25 09:18:38 +08:00
|
|
|
- :option:`InlineNamespaceCase`, :option:`InlineNamespacePrefix`, :option:`InlineNamespaceSuffix`, :option:`InlineNamespaceIgnoredRegexp`
|
2021-08-02 06:20:12 +08:00
|
|
|
- :option:`LocalConstantCase`, :option:`LocalConstantPrefix`, :option:`LocalConstantSuffix`, :option:`LocalConstantIgnoredRegexp`, :option:`LocalConstantHungarianPrefix`
|
|
|
|
- :option:`LocalConstantPointerCase`, :option:`LocalConstantPointerPrefix`, :option:`LocalConstantPointerSuffix`, :option:`LocalConstantPointerIgnoredRegexp`, :option:`LocalConstantPointerHungarianPrefix`
|
|
|
|
- :option:`LocalPointerCase`, :option:`LocalPointerPrefix`, :option:`LocalPointerSuffix`, :option:`LocalPointerIgnoredRegexp`, :option:`LocalPointerHungarianPrefix`
|
|
|
|
- :option:`LocalVariableCase`, :option:`LocalVariablePrefix`, :option:`LocalVariableSuffix`, :option:`LocalVariableIgnoredRegexp`, :option:`LocalVariableHungarianPrefix`
|
2020-11-25 09:18:38 +08:00
|
|
|
- :option:`MacroDefinitionCase`, :option:`MacroDefinitionPrefix`, :option:`MacroDefinitionSuffix`, :option:`MacroDefinitionIgnoredRegexp`
|
2021-08-02 06:20:12 +08:00
|
|
|
- :option:`MemberCase`, :option:`MemberPrefix`, :option:`MemberSuffix`, :option:`MemberIgnoredRegexp`, :option:`MemberHungarianPrefix`
|
2020-11-25 09:18:38 +08:00
|
|
|
- :option:`MethodCase`, :option:`MethodPrefix`, :option:`MethodSuffix`, :option:`MethodIgnoredRegexp`
|
|
|
|
- :option:`NamespaceCase`, :option:`NamespacePrefix`, :option:`NamespaceSuffix`, :option:`NamespaceIgnoredRegexp`
|
2021-08-02 06:20:12 +08:00
|
|
|
- :option:`ParameterCase`, :option:`ParameterPrefix`, :option:`ParameterSuffix`, :option:`ParameterIgnoredRegexp`, :option:`ParameterHungarianPrefix`
|
2020-11-25 09:18:38 +08:00
|
|
|
- :option:`ParameterPackCase`, :option:`ParameterPackPrefix`, :option:`ParameterPackSuffix`, :option:`ParameterPackIgnoredRegexp`
|
2021-08-02 06:20:12 +08:00
|
|
|
- :option:`PointerParameterCase`, :option:`PointerParameterPrefix`, :option:`PointerParameterSuffix`, :option:`PointerParameterIgnoredRegexp`, :option:`PointerParameterHungarianPrefix`
|
|
|
|
- :option:`PrivateMemberCase`, :option:`PrivateMemberPrefix`, :option:`PrivateMemberSuffix`, :option:`PrivateMemberIgnoredRegexp`, :option:`PrivateMemberHungarianPrefix`
|
2020-11-25 09:18:38 +08:00
|
|
|
- :option:`PrivateMethodCase`, :option:`PrivateMethodPrefix`, :option:`PrivateMethodSuffix`, :option:`PrivateMethodIgnoredRegexp`
|
2021-08-02 06:20:12 +08:00
|
|
|
- :option:`ProtectedMemberCase`, :option:`ProtectedMemberPrefix`, :option:`ProtectedMemberSuffix`, :option:`ProtectedMemberIgnoredRegexp`, :option:`ProtectedMemberHungarianPrefix`
|
2020-11-25 09:18:38 +08:00
|
|
|
- :option:`ProtectedMethodCase`, :option:`ProtectedMethodPrefix`, :option:`ProtectedMethodSuffix`, :option:`ProtectedMethodIgnoredRegexp`
|
2021-08-02 06:20:12 +08:00
|
|
|
- :option:`PublicMemberCase`, :option:`PublicMemberPrefix`, :option:`PublicMemberSuffix`, :option:`PublicMemberIgnoredRegexp`, :option:`PublicMemberHungarianPrefix`
|
2020-11-25 09:18:38 +08:00
|
|
|
- :option:`PublicMethodCase`, :option:`PublicMethodPrefix`, :option:`PublicMethodSuffix`, :option:`PublicMethodIgnoredRegexp`
|
|
|
|
- :option:`ScopedEnumConstantCase`, :option:`ScopedEnumConstantPrefix`, :option:`ScopedEnumConstantSuffix`, :option:`ScopedEnumConstantIgnoredRegexp`
|
2021-08-02 06:20:12 +08:00
|
|
|
- :option:`StaticConstantCase`, :option:`StaticConstantPrefix`, :option:`StaticConstantSuffix`, :option:`StaticConstantIgnoredRegexp`, :option:`StaticConstantHungarianPrefix`
|
|
|
|
- :option:`StaticVariableCase`, :option:`StaticVariablePrefix`, :option:`StaticVariableSuffix`, :option:`StaticVariableIgnoredRegexp`, :option:`StaticVariableHungarianPrefix`
|
2020-11-25 09:18:38 +08:00
|
|
|
- :option:`StructCase`, :option:`StructPrefix`, :option:`StructSuffix`, :option:`StructIgnoredRegexp`
|
|
|
|
- :option:`TemplateParameterCase`, :option:`TemplateParameterPrefix`, :option:`TemplateParameterSuffix`, :option:`TemplateParameterIgnoredRegexp`
|
|
|
|
- :option:`TemplateTemplateParameterCase`, :option:`TemplateTemplateParameterPrefix`, :option:`TemplateTemplateParameterSuffix`, :option:`TemplateTemplateParameterIgnoredRegexp`
|
|
|
|
- :option:`TypeAliasCase`, :option:`TypeAliasPrefix`, :option:`TypeAliasSuffix`, :option:`TypeAliasIgnoredRegexp`
|
|
|
|
- :option:`TypedefCase`, :option:`TypedefPrefix`, :option:`TypedefSuffix`, :option:`TypedefIgnoredRegexp`
|
|
|
|
- :option:`TypeTemplateParameterCase`, :option:`TypeTemplateParameterPrefix`, :option:`TypeTemplateParameterSuffix`, :option:`TypeTemplateParameterIgnoredRegexp`
|
|
|
|
- :option:`UnionCase`, :option:`UnionPrefix`, :option:`UnionSuffix`, :option:`UnionIgnoredRegexp`
|
|
|
|
- :option:`ValueTemplateParameterCase`, :option:`ValueTemplateParameterPrefix`, :option:`ValueTemplateParameterSuffix`, :option:`ValueTemplateParameterIgnoredRegexp`
|
2021-08-02 06:20:12 +08:00
|
|
|
- :option:`VariableCase`, :option:`VariablePrefix`, :option:`VariableSuffix`, :option:`VariableIgnoredRegexp`, :option:`VariableHungarianPrefix`
|
2020-11-25 09:18:38 +08:00
|
|
|
- :option:`VirtualMethodCase`, :option:`VirtualMethodPrefix`, :option:`VirtualMethodSuffix`, :option:`VirtualMethodIgnoredRegexp`
|
2019-01-16 06:06:49 +08:00
|
|
|
|
|
|
|
.. option:: AbstractClassCase
|
|
|
|
|
|
|
|
When defined, the check will ensure abstract class names conform to the
|
|
|
|
selected casing.
|
|
|
|
|
|
|
|
.. option:: AbstractClassPrefix
|
|
|
|
|
|
|
|
When defined, the check will ensure abstract class names will add the
|
|
|
|
prefixed with the given value (regardless of casing).
|
|
|
|
|
2020-11-25 09:18:38 +08:00
|
|
|
.. option:: AbstractClassIgnoredRegexp
|
|
|
|
|
|
|
|
Identifier naming checks won't be enforced for abstract class names
|
|
|
|
matching this regular expression.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
.. option:: AbstractClassSuffix
|
|
|
|
|
|
|
|
When defined, the check will ensure abstract class names will add the
|
|
|
|
suffix with the given value (regardless of casing).
|
|
|
|
|
2021-08-02 06:20:12 +08:00
|
|
|
.. option:: AbstractClassHungarianPrefix
|
|
|
|
|
|
|
|
When enabled, the check ensures that the declared identifier will
|
|
|
|
have a Hungarian notation prefix based on the declared type.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
For example using values of:
|
|
|
|
|
|
|
|
- AbstractClassCase of ``lower_case``
|
|
|
|
- AbstractClassPrefix of ``pre_``
|
|
|
|
- AbstractClassSuffix of ``_post``
|
2021-08-02 06:20:12 +08:00
|
|
|
- AbstractClassHungarianPrefix of ``On``
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
|
|
|
|
Identifies and/or transforms abstract class names as follows:
|
|
|
|
|
|
|
|
Before:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
class ABSTRACT_CLASS {
|
|
|
|
public:
|
|
|
|
ABSTRACT_CLASS();
|
|
|
|
};
|
|
|
|
|
|
|
|
After:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
class pre_abstract_class_post {
|
|
|
|
public:
|
|
|
|
pre_abstract_class_post();
|
|
|
|
};
|
|
|
|
|
[clang-tidy] RenamerClangTidy now renames dependent member expr when the member can be resolved
Summary:
Sometimes in templated code Member references are reported as `DependentScopeMemberExpr` because that's what the standard dictates, however in many trivial cases it is easy to resolve the reference to its actual Member.
Take this code:
```
template<typename T>
class A{
int value;
A& operator=(const A& Other){
value = Other.value;
this->value = Other.value;
return *this;
}
};
```
When ran with `clang-tidy file.cpp -checks=readability-identifier-naming --config="{CheckOptions: [{key: readability-identifier-naming.MemberPrefix, value: m_}]}" -fix`
Current behaviour:
```
template<typename T>
class A{
int m_value;
A& operator=(const A& Other){
m_value = Other.value;
this->value = Other.value;
return *this;
}
};
```
As `this->value` and `Other.value` are Dependent they are ignored when creating the fix-its, however this can easily be resolved.
Proposed behaviour:
```
template<typename T>
class A{
int m_value;
A& operator=(const A& Other){
m_value = Other.m_value;
this->m_value = Other.m_value;
return *this;
}
};
```
Reviewers: aaron.ballman, JonasToth, alexfh, hokein, gribozavr2
Reviewed By: aaron.ballman
Subscribers: merge_guards_bot, xazax.hun, cfe-commits
Tags: #clang, #clang-tools-extra
Differential Revision: https://reviews.llvm.org/D73052
2020-05-09 02:30:18 +08:00
|
|
|
.. option:: AggressiveDependentMemberLookup
|
|
|
|
|
2020-12-07 20:13:56 +08:00
|
|
|
When set to `true` the check will look in dependent base classes for dependent
|
[clang-tidy] RenamerClangTidy now renames dependent member expr when the member can be resolved
Summary:
Sometimes in templated code Member references are reported as `DependentScopeMemberExpr` because that's what the standard dictates, however in many trivial cases it is easy to resolve the reference to its actual Member.
Take this code:
```
template<typename T>
class A{
int value;
A& operator=(const A& Other){
value = Other.value;
this->value = Other.value;
return *this;
}
};
```
When ran with `clang-tidy file.cpp -checks=readability-identifier-naming --config="{CheckOptions: [{key: readability-identifier-naming.MemberPrefix, value: m_}]}" -fix`
Current behaviour:
```
template<typename T>
class A{
int m_value;
A& operator=(const A& Other){
m_value = Other.value;
this->value = Other.value;
return *this;
}
};
```
As `this->value` and `Other.value` are Dependent they are ignored when creating the fix-its, however this can easily be resolved.
Proposed behaviour:
```
template<typename T>
class A{
int m_value;
A& operator=(const A& Other){
m_value = Other.m_value;
this->m_value = Other.m_value;
return *this;
}
};
```
Reviewers: aaron.ballman, JonasToth, alexfh, hokein, gribozavr2
Reviewed By: aaron.ballman
Subscribers: merge_guards_bot, xazax.hun, cfe-commits
Tags: #clang, #clang-tools-extra
Differential Revision: https://reviews.llvm.org/D73052
2020-05-09 02:30:18 +08:00
|
|
|
member references that need changing. This can lead to errors with template
|
2020-12-07 20:13:56 +08:00
|
|
|
specializations so the default value is `false`.
|
[clang-tidy] RenamerClangTidy now renames dependent member expr when the member can be resolved
Summary:
Sometimes in templated code Member references are reported as `DependentScopeMemberExpr` because that's what the standard dictates, however in many trivial cases it is easy to resolve the reference to its actual Member.
Take this code:
```
template<typename T>
class A{
int value;
A& operator=(const A& Other){
value = Other.value;
this->value = Other.value;
return *this;
}
};
```
When ran with `clang-tidy file.cpp -checks=readability-identifier-naming --config="{CheckOptions: [{key: readability-identifier-naming.MemberPrefix, value: m_}]}" -fix`
Current behaviour:
```
template<typename T>
class A{
int m_value;
A& operator=(const A& Other){
m_value = Other.value;
this->value = Other.value;
return *this;
}
};
```
As `this->value` and `Other.value` are Dependent they are ignored when creating the fix-its, however this can easily be resolved.
Proposed behaviour:
```
template<typename T>
class A{
int m_value;
A& operator=(const A& Other){
m_value = Other.m_value;
this->m_value = Other.m_value;
return *this;
}
};
```
Reviewers: aaron.ballman, JonasToth, alexfh, hokein, gribozavr2
Reviewed By: aaron.ballman
Subscribers: merge_guards_bot, xazax.hun, cfe-commits
Tags: #clang, #clang-tools-extra
Differential Revision: https://reviews.llvm.org/D73052
2020-05-09 02:30:18 +08:00
|
|
|
|
|
|
|
For example using values of:
|
|
|
|
|
|
|
|
- ClassMemberCase of ``lower_case``
|
|
|
|
|
|
|
|
Before:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
template <typename T>
|
|
|
|
struct Base {
|
|
|
|
T BadNamedMember;
|
|
|
|
};
|
|
|
|
|
|
|
|
template <typename T>
|
|
|
|
struct Derived : Base<T> {
|
|
|
|
void reset() {
|
|
|
|
this->BadNamedMember = 0;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2020-12-07 20:13:56 +08:00
|
|
|
After if AggressiveDependentMemberLookup is `false`:
|
[clang-tidy] RenamerClangTidy now renames dependent member expr when the member can be resolved
Summary:
Sometimes in templated code Member references are reported as `DependentScopeMemberExpr` because that's what the standard dictates, however in many trivial cases it is easy to resolve the reference to its actual Member.
Take this code:
```
template<typename T>
class A{
int value;
A& operator=(const A& Other){
value = Other.value;
this->value = Other.value;
return *this;
}
};
```
When ran with `clang-tidy file.cpp -checks=readability-identifier-naming --config="{CheckOptions: [{key: readability-identifier-naming.MemberPrefix, value: m_}]}" -fix`
Current behaviour:
```
template<typename T>
class A{
int m_value;
A& operator=(const A& Other){
m_value = Other.value;
this->value = Other.value;
return *this;
}
};
```
As `this->value` and `Other.value` are Dependent they are ignored when creating the fix-its, however this can easily be resolved.
Proposed behaviour:
```
template<typename T>
class A{
int m_value;
A& operator=(const A& Other){
m_value = Other.m_value;
this->m_value = Other.m_value;
return *this;
}
};
```
Reviewers: aaron.ballman, JonasToth, alexfh, hokein, gribozavr2
Reviewed By: aaron.ballman
Subscribers: merge_guards_bot, xazax.hun, cfe-commits
Tags: #clang, #clang-tools-extra
Differential Revision: https://reviews.llvm.org/D73052
2020-05-09 02:30:18 +08:00
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
template <typename T>
|
|
|
|
struct Base {
|
|
|
|
T bad_named_member;
|
|
|
|
};
|
|
|
|
|
|
|
|
template <typename T>
|
|
|
|
struct Derived : Base<T> {
|
|
|
|
void reset() {
|
|
|
|
this->BadNamedMember = 0;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2020-12-07 20:13:56 +08:00
|
|
|
After if AggressiveDependentMemberLookup is `true`:
|
[clang-tidy] RenamerClangTidy now renames dependent member expr when the member can be resolved
Summary:
Sometimes in templated code Member references are reported as `DependentScopeMemberExpr` because that's what the standard dictates, however in many trivial cases it is easy to resolve the reference to its actual Member.
Take this code:
```
template<typename T>
class A{
int value;
A& operator=(const A& Other){
value = Other.value;
this->value = Other.value;
return *this;
}
};
```
When ran with `clang-tidy file.cpp -checks=readability-identifier-naming --config="{CheckOptions: [{key: readability-identifier-naming.MemberPrefix, value: m_}]}" -fix`
Current behaviour:
```
template<typename T>
class A{
int m_value;
A& operator=(const A& Other){
m_value = Other.value;
this->value = Other.value;
return *this;
}
};
```
As `this->value` and `Other.value` are Dependent they are ignored when creating the fix-its, however this can easily be resolved.
Proposed behaviour:
```
template<typename T>
class A{
int m_value;
A& operator=(const A& Other){
m_value = Other.m_value;
this->m_value = Other.m_value;
return *this;
}
};
```
Reviewers: aaron.ballman, JonasToth, alexfh, hokein, gribozavr2
Reviewed By: aaron.ballman
Subscribers: merge_guards_bot, xazax.hun, cfe-commits
Tags: #clang, #clang-tools-extra
Differential Revision: https://reviews.llvm.org/D73052
2020-05-09 02:30:18 +08:00
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
template <typename T>
|
|
|
|
struct Base {
|
|
|
|
T bad_named_member;
|
|
|
|
};
|
|
|
|
|
|
|
|
template <typename T>
|
|
|
|
struct Derived : Base<T> {
|
|
|
|
void reset() {
|
|
|
|
this->bad_named_member = 0;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
.. option:: ClassCase
|
|
|
|
|
|
|
|
When defined, the check will ensure class names conform to the
|
|
|
|
selected casing.
|
|
|
|
|
|
|
|
.. option:: ClassPrefix
|
|
|
|
|
|
|
|
When defined, the check will ensure class names will add the
|
|
|
|
prefixed with the given value (regardless of casing).
|
|
|
|
|
2020-11-25 09:18:38 +08:00
|
|
|
.. option:: ClassIgnoredRegexp
|
|
|
|
|
|
|
|
Identifier naming checks won't be enforced for class names matching
|
|
|
|
this regular expression.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
.. option:: ClassSuffix
|
|
|
|
|
|
|
|
When defined, the check will ensure class names will add the
|
|
|
|
suffix with the given value (regardless of casing).
|
|
|
|
|
2021-08-02 06:20:12 +08:00
|
|
|
.. option:: ClassHungarianPrefix
|
|
|
|
|
|
|
|
When enabled, the check ensures that the declared identifier will
|
|
|
|
have a Hungarian notation prefix based on the declared type.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
For example using values of:
|
|
|
|
|
|
|
|
- ClassCase of ``lower_case``
|
|
|
|
- ClassPrefix of ``pre_``
|
|
|
|
- ClassSuffix of ``_post``
|
2021-08-02 06:20:12 +08:00
|
|
|
- ClassHungarianPrefix of ``On``
|
2019-01-16 06:06:49 +08:00
|
|
|
|
|
|
|
Identifies and/or transforms class names as follows:
|
|
|
|
|
|
|
|
Before:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
class FOO {
|
|
|
|
public:
|
|
|
|
FOO();
|
|
|
|
~FOO();
|
|
|
|
};
|
|
|
|
|
|
|
|
After:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
class pre_foo_post {
|
|
|
|
public:
|
|
|
|
pre_foo_post();
|
|
|
|
~pre_foo_post();
|
|
|
|
};
|
|
|
|
|
|
|
|
.. option:: ClassConstantCase
|
|
|
|
|
|
|
|
When defined, the check will ensure class constant names conform to the
|
|
|
|
selected casing.
|
|
|
|
|
|
|
|
.. option:: ClassConstantPrefix
|
|
|
|
|
|
|
|
When defined, the check will ensure class constant names will add the
|
|
|
|
prefixed with the given value (regardless of casing).
|
|
|
|
|
2020-11-25 09:18:38 +08:00
|
|
|
.. option:: ClassConstantIgnoredRegexp
|
|
|
|
|
|
|
|
Identifier naming checks won't be enforced for class constant names
|
|
|
|
matching this regular expression.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
.. option:: ClassConstantSuffix
|
|
|
|
|
|
|
|
When defined, the check will ensure class constant names will add the
|
|
|
|
suffix with the given value (regardless of casing).
|
|
|
|
|
2021-08-02 06:20:12 +08:00
|
|
|
.. option:: ClassConstantHungarianPrefix
|
|
|
|
|
|
|
|
When enabled, the check ensures that the declared identifier will
|
|
|
|
have a Hungarian notation prefix based on the declared type.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
For example using values of:
|
|
|
|
|
|
|
|
- ClassConstantCase of ``lower_case``
|
|
|
|
- ClassConstantPrefix of ``pre_``
|
|
|
|
- ClassConstantSuffix of ``_post``
|
2021-08-02 06:20:12 +08:00
|
|
|
- ClassConstantHungarianPrefix of ``On``
|
2019-01-16 06:06:49 +08:00
|
|
|
|
|
|
|
Identifies and/or transforms class constant names as follows:
|
|
|
|
|
|
|
|
Before:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
class FOO {
|
|
|
|
public:
|
|
|
|
static const int CLASS_CONSTANT;
|
|
|
|
};
|
|
|
|
|
|
|
|
After:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
class FOO {
|
|
|
|
public:
|
|
|
|
static const int pre_class_constant_post;
|
|
|
|
};
|
|
|
|
|
|
|
|
.. option:: ClassMemberCase
|
|
|
|
|
|
|
|
When defined, the check will ensure class member names conform to the
|
|
|
|
selected casing.
|
|
|
|
|
|
|
|
.. option:: ClassMemberPrefix
|
|
|
|
|
|
|
|
When defined, the check will ensure class member names will add the
|
|
|
|
prefixed with the given value (regardless of casing).
|
|
|
|
|
2020-11-25 09:18:38 +08:00
|
|
|
.. option:: ClassMemberIgnoredRegexp
|
|
|
|
|
|
|
|
Identifier naming checks won't be enforced for class member names
|
|
|
|
matching this regular expression.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
.. option:: ClassMemberSuffix
|
|
|
|
|
|
|
|
When defined, the check will ensure class member names will add the
|
|
|
|
suffix with the given value (regardless of casing).
|
|
|
|
|
2021-08-02 06:20:12 +08:00
|
|
|
.. option:: ClassMemberHungarianPrefix
|
|
|
|
|
|
|
|
When enabled, the check ensures that the declared identifier will
|
|
|
|
have a Hungarian notation prefix based on the declared type.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
For example using values of:
|
|
|
|
|
|
|
|
- ClassMemberCase of ``lower_case``
|
|
|
|
- ClassMemberPrefix of ``pre_``
|
|
|
|
- ClassMemberSuffix of ``_post``
|
2021-08-02 06:20:12 +08:00
|
|
|
- ClassMemberHungarianPrefix of ``On``
|
2019-01-16 06:06:49 +08:00
|
|
|
|
|
|
|
Identifies and/or transforms class member names as follows:
|
|
|
|
|
|
|
|
Before:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
class FOO {
|
|
|
|
public:
|
|
|
|
static int CLASS_CONSTANT;
|
|
|
|
};
|
|
|
|
|
|
|
|
After:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
class FOO {
|
|
|
|
public:
|
|
|
|
static int pre_class_constant_post;
|
|
|
|
};
|
|
|
|
|
|
|
|
.. option:: ClassMethodCase
|
|
|
|
|
|
|
|
When defined, the check will ensure class method names conform to the
|
|
|
|
selected casing.
|
|
|
|
|
|
|
|
.. option:: ClassMethodPrefix
|
|
|
|
|
|
|
|
When defined, the check will ensure class method names will add the
|
|
|
|
prefixed with the given value (regardless of casing).
|
|
|
|
|
2020-11-25 09:18:38 +08:00
|
|
|
.. option:: ClassMethodIgnoredRegexp
|
|
|
|
|
|
|
|
Identifier naming checks won't be enforced for class method names
|
|
|
|
matching this regular expression.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
.. option:: ClassMethodSuffix
|
|
|
|
|
|
|
|
When defined, the check will ensure class method names will add the
|
|
|
|
suffix with the given value (regardless of casing).
|
|
|
|
|
|
|
|
For example using values of:
|
|
|
|
|
|
|
|
- ClassMethodCase of ``lower_case``
|
|
|
|
- ClassMethodPrefix of ``pre_``
|
|
|
|
- ClassMethodSuffix of ``_post``
|
|
|
|
|
|
|
|
Identifies and/or transforms class method names as follows:
|
|
|
|
|
|
|
|
Before:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
class FOO {
|
|
|
|
public:
|
|
|
|
int CLASS_MEMBER();
|
|
|
|
};
|
|
|
|
|
|
|
|
After:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
class FOO {
|
|
|
|
public:
|
|
|
|
int pre_class_member_post();
|
|
|
|
};
|
|
|
|
|
|
|
|
.. option:: ConstantCase
|
|
|
|
|
|
|
|
When defined, the check will ensure constant names conform to the
|
|
|
|
selected casing.
|
|
|
|
|
|
|
|
.. option:: ConstantPrefix
|
|
|
|
|
|
|
|
When defined, the check will ensure constant names will add the
|
|
|
|
prefixed with the given value (regardless of casing).
|
|
|
|
|
2020-11-25 09:18:38 +08:00
|
|
|
.. option:: ConstantIgnoredRegexp
|
|
|
|
|
|
|
|
Identifier naming checks won't be enforced for constant names
|
|
|
|
matching this regular expression.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
.. option:: ConstantSuffix
|
|
|
|
|
|
|
|
When defined, the check will ensure constant names will add the
|
|
|
|
suffix with the given value (regardless of casing).
|
|
|
|
|
2021-08-02 06:20:12 +08:00
|
|
|
.. option:: ConstantHungarianPrefix
|
|
|
|
|
|
|
|
When enabled, the check ensures that the declared identifier will
|
|
|
|
have a Hungarian notation prefix based on the declared type.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
For example using values of:
|
|
|
|
|
|
|
|
- ConstantCase of ``lower_case``
|
|
|
|
- ConstantPrefix of ``pre_``
|
|
|
|
- ConstantSuffix of ``_post``
|
2021-08-02 06:20:12 +08:00
|
|
|
- ConstantHungarianPrefix of ``On``
|
2019-01-16 06:06:49 +08:00
|
|
|
|
|
|
|
Identifies and/or transforms constant names as follows:
|
|
|
|
|
|
|
|
Before:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
void function() { unsigned const MyConst_array[] = {1, 2, 3}; }
|
|
|
|
|
|
|
|
After:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
void function() { unsigned const pre_myconst_array_post[] = {1, 2, 3}; }
|
|
|
|
|
|
|
|
.. option:: ConstantMemberCase
|
|
|
|
|
|
|
|
When defined, the check will ensure constant member names conform to the
|
|
|
|
selected casing.
|
|
|
|
|
|
|
|
.. option:: ConstantMemberPrefix
|
|
|
|
|
|
|
|
When defined, the check will ensure constant member names will add the
|
|
|
|
prefixed with the given value (regardless of casing).
|
|
|
|
|
2020-11-25 09:18:38 +08:00
|
|
|
.. option:: ConstantMemberIgnoredRegexp
|
|
|
|
|
|
|
|
Identifier naming checks won't be enforced for constant member names
|
|
|
|
matching this regular expression.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
.. option:: ConstantMemberSuffix
|
|
|
|
|
|
|
|
When defined, the check will ensure constant member names will add the
|
|
|
|
suffix with the given value (regardless of casing).
|
|
|
|
|
2021-08-02 06:20:12 +08:00
|
|
|
.. option:: ConstantMemberHungarianPrefix
|
|
|
|
|
|
|
|
When enabled, the check ensures that the declared identifier will
|
|
|
|
have a Hungarian notation prefix based on the declared type.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
For example using values of:
|
|
|
|
|
|
|
|
- ConstantMemberCase of ``lower_case``
|
|
|
|
- ConstantMemberPrefix of ``pre_``
|
|
|
|
- ConstantMemberSuffix of ``_post``
|
2021-08-02 06:20:12 +08:00
|
|
|
- ConstantMemberHungarianPrefix of ``On``
|
2019-01-16 06:06:49 +08:00
|
|
|
|
|
|
|
Identifies and/or transforms constant member names as follows:
|
|
|
|
|
|
|
|
Before:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
class Foo {
|
|
|
|
char const MY_ConstMember_string[4] = "123";
|
|
|
|
}
|
|
|
|
|
|
|
|
After:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
class Foo {
|
|
|
|
char const pre_my_constmember_string_post[4] = "123";
|
|
|
|
}
|
|
|
|
|
|
|
|
.. option:: ConstantParameterCase
|
|
|
|
|
|
|
|
When defined, the check will ensure constant parameter names conform to the
|
|
|
|
selected casing.
|
|
|
|
|
|
|
|
.. option:: ConstantParameterPrefix
|
|
|
|
|
|
|
|
When defined, the check will ensure constant parameter names will add the
|
|
|
|
prefixed with the given value (regardless of casing).
|
|
|
|
|
2020-11-25 09:18:38 +08:00
|
|
|
.. option:: ConstantParameterIgnoredRegexp
|
|
|
|
|
|
|
|
Identifier naming checks won't be enforced for constant parameter names
|
|
|
|
matching this regular expression.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
.. option:: ConstantParameterSuffix
|
|
|
|
|
|
|
|
When defined, the check will ensure constant parameter names will add the
|
|
|
|
suffix with the given value (regardless of casing).
|
|
|
|
|
2021-08-02 06:20:12 +08:00
|
|
|
.. option:: ConstantParameterHungarianPrefix
|
|
|
|
|
|
|
|
When enabled, the check ensures that the declared identifier will
|
|
|
|
have a Hungarian notation prefix based on the declared type.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
For example using values of:
|
|
|
|
|
|
|
|
- ConstantParameterCase of ``lower_case``
|
|
|
|
- ConstantParameterPrefix of ``pre_``
|
|
|
|
- ConstantParameterSuffix of ``_post``
|
2021-08-02 06:20:12 +08:00
|
|
|
- ConstantParameterHungarianPrefix of ``On``
|
2019-01-16 06:06:49 +08:00
|
|
|
|
|
|
|
Identifies and/or transforms constant parameter names as follows:
|
|
|
|
|
|
|
|
Before:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
void GLOBAL_FUNCTION(int PARAMETER_1, int const CONST_parameter);
|
|
|
|
|
|
|
|
After:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
void GLOBAL_FUNCTION(int PARAMETER_1, int const pre_const_parameter_post);
|
|
|
|
|
|
|
|
.. option:: ConstantPointerParameterCase
|
|
|
|
|
|
|
|
When defined, the check will ensure constant pointer parameter names conform to the
|
|
|
|
selected casing.
|
|
|
|
|
|
|
|
.. option:: ConstantPointerParameterPrefix
|
|
|
|
|
|
|
|
When defined, the check will ensure constant pointer parameter names will add the
|
|
|
|
prefixed with the given value (regardless of casing).
|
|
|
|
|
2020-11-25 09:18:38 +08:00
|
|
|
.. option:: ConstantPointerParameterIgnoredRegexp
|
|
|
|
|
|
|
|
Identifier naming checks won't be enforced for constant pointer parameter
|
|
|
|
names matching this regular expression.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
.. option:: ConstantPointerParameterSuffix
|
|
|
|
|
|
|
|
When defined, the check will ensure constant pointer parameter names will add the
|
|
|
|
suffix with the given value (regardless of casing).
|
|
|
|
|
2021-08-02 06:20:12 +08:00
|
|
|
.. option:: ConstantPointerParameterHungarianPrefix
|
|
|
|
|
|
|
|
When enabled, the check ensures that the declared identifier will
|
|
|
|
have a Hungarian notation prefix based on the declared type.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
For example using values of:
|
|
|
|
|
|
|
|
- ConstantPointerParameterCase of ``lower_case``
|
|
|
|
- ConstantPointerParameterPrefix of ``pre_``
|
|
|
|
- ConstantPointerParameterSuffix of ``_post``
|
2021-08-02 06:20:12 +08:00
|
|
|
- ConstantPointerParameterHungarianPrefix of ``On``
|
2019-01-16 06:06:49 +08:00
|
|
|
|
|
|
|
Identifies and/or transforms constant pointer parameter names as follows:
|
|
|
|
|
|
|
|
Before:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
void GLOBAL_FUNCTION(int const *CONST_parameter);
|
|
|
|
|
|
|
|
After:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
void GLOBAL_FUNCTION(int const *pre_const_parameter_post);
|
|
|
|
|
|
|
|
.. option:: ConstexprFunctionCase
|
|
|
|
|
|
|
|
When defined, the check will ensure constexpr function names conform to the
|
|
|
|
selected casing.
|
|
|
|
|
|
|
|
.. option:: ConstexprFunctionPrefix
|
|
|
|
|
|
|
|
When defined, the check will ensure constexpr function names will add the
|
|
|
|
prefixed with the given value (regardless of casing).
|
|
|
|
|
2020-11-25 09:18:38 +08:00
|
|
|
.. option:: ConstexprFunctionIgnoredRegexp
|
|
|
|
|
|
|
|
Identifier naming checks won't be enforced for constexpr function names
|
|
|
|
matching this regular expression.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
.. option:: ConstexprFunctionSuffix
|
|
|
|
|
|
|
|
When defined, the check will ensure constexpr function names will add the
|
|
|
|
suffix with the given value (regardless of casing).
|
|
|
|
|
|
|
|
For example using values of:
|
|
|
|
|
|
|
|
- ConstexprFunctionCase of ``lower_case``
|
|
|
|
- ConstexprFunctionPrefix of ``pre_``
|
|
|
|
- ConstexprFunctionSuffix of ``_post``
|
|
|
|
|
|
|
|
Identifies and/or transforms constexpr function names as follows:
|
|
|
|
|
|
|
|
Before:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
constexpr int CE_function() { return 3; }
|
|
|
|
|
|
|
|
After:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
constexpr int pre_ce_function_post() { return 3; }
|
|
|
|
|
|
|
|
.. option:: ConstexprMethodCase
|
|
|
|
|
|
|
|
When defined, the check will ensure constexpr method names conform to the
|
|
|
|
selected casing.
|
|
|
|
|
|
|
|
.. option:: ConstexprMethodPrefix
|
|
|
|
|
|
|
|
When defined, the check will ensure constexpr method names will add the
|
|
|
|
prefixed with the given value (regardless of casing).
|
|
|
|
|
2020-11-25 09:18:38 +08:00
|
|
|
.. option:: ConstexprMethodIgnoredRegexp
|
|
|
|
|
|
|
|
Identifier naming checks won't be enforced for constexpr method names
|
|
|
|
matching this regular expression.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
.. option:: ConstexprMethodSuffix
|
|
|
|
|
|
|
|
When defined, the check will ensure constexpr method names will add the
|
|
|
|
suffix with the given value (regardless of casing).
|
|
|
|
|
|
|
|
For example using values of:
|
|
|
|
|
|
|
|
- ConstexprMethodCase of ``lower_case``
|
|
|
|
- ConstexprMethodPrefix of ``pre_``
|
|
|
|
- ConstexprMethodSuffix of ``_post``
|
|
|
|
|
|
|
|
Identifies and/or transforms constexpr method names as follows:
|
|
|
|
|
|
|
|
Before:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
class Foo {
|
|
|
|
public:
|
|
|
|
constexpr int CST_expr_Method() { return 2; }
|
|
|
|
}
|
|
|
|
|
|
|
|
After:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
class Foo {
|
|
|
|
public:
|
|
|
|
constexpr int pre_cst_expr_method_post() { return 2; }
|
|
|
|
}
|
|
|
|
|
|
|
|
.. option:: ConstexprVariableCase
|
|
|
|
|
|
|
|
When defined, the check will ensure constexpr variable names conform to the
|
|
|
|
selected casing.
|
|
|
|
|
|
|
|
.. option:: ConstexprVariablePrefix
|
|
|
|
|
|
|
|
When defined, the check will ensure constexpr variable names will add the
|
|
|
|
prefixed with the given value (regardless of casing).
|
|
|
|
|
2020-11-25 09:18:38 +08:00
|
|
|
.. option:: ConstexprVariableIgnoredRegexp
|
|
|
|
|
|
|
|
Identifier naming checks won't be enforced for constexpr variable names
|
|
|
|
matching this regular expression.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
.. option:: ConstexprVariableSuffix
|
|
|
|
|
|
|
|
When defined, the check will ensure constexpr variable names will add the
|
|
|
|
suffix with the given value (regardless of casing).
|
|
|
|
|
2021-08-02 06:20:12 +08:00
|
|
|
.. option:: ConstexprVariableHungarianPrefix
|
|
|
|
|
|
|
|
When enabled, the check ensures that the declared identifier will
|
|
|
|
have a Hungarian notation prefix based on the declared type.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
For example using values of:
|
|
|
|
|
|
|
|
- ConstexprVariableCase of ``lower_case``
|
|
|
|
- ConstexprVariablePrefix of ``pre_``
|
|
|
|
- ConstexprVariableSuffix of ``_post``
|
2021-08-02 06:20:12 +08:00
|
|
|
- ConstexprVariableHungarianPrefix of ``On``
|
2019-01-16 06:06:49 +08:00
|
|
|
|
|
|
|
Identifies and/or transforms constexpr variable names as follows:
|
|
|
|
|
|
|
|
Before:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
constexpr int ConstExpr_variable = MyConstant;
|
|
|
|
|
|
|
|
After:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
constexpr int pre_constexpr_variable_post = MyConstant;
|
|
|
|
|
|
|
|
.. option:: EnumCase
|
|
|
|
|
|
|
|
When defined, the check will ensure enumeration names conform to the
|
|
|
|
selected casing.
|
|
|
|
|
|
|
|
.. option:: EnumPrefix
|
|
|
|
|
|
|
|
When defined, the check will ensure enumeration names will add the
|
|
|
|
prefixed with the given value (regardless of casing).
|
|
|
|
|
2020-11-25 20:33:38 +08:00
|
|
|
.. option:: EnumIgnoredRegexp
|
2020-11-25 09:18:38 +08:00
|
|
|
|
|
|
|
Identifier naming checks won't be enforced for enumeration names
|
|
|
|
matching this regular expression.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
.. option:: EnumSuffix
|
|
|
|
|
|
|
|
When defined, the check will ensure enumeration names will add the
|
|
|
|
suffix with the given value (regardless of casing).
|
|
|
|
|
|
|
|
For example using values of:
|
|
|
|
|
|
|
|
- EnumCase of ``lower_case``
|
|
|
|
- EnumPrefix of ``pre_``
|
|
|
|
- EnumSuffix of ``_post``
|
|
|
|
|
|
|
|
Identifies and/or transforms enumeration names as follows:
|
|
|
|
|
|
|
|
Before:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
enum FOO { One, Two, Three };
|
|
|
|
|
|
|
|
After:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
enum pre_foo_post { One, Two, Three };
|
|
|
|
|
|
|
|
.. option:: EnumConstantCase
|
|
|
|
|
|
|
|
When defined, the check will ensure enumeration constant names conform to the
|
|
|
|
selected casing.
|
|
|
|
|
|
|
|
.. option:: EnumConstantPrefix
|
|
|
|
|
|
|
|
When defined, the check will ensure enumeration constant names will add the
|
|
|
|
prefixed with the given value (regardless of casing).
|
|
|
|
|
2020-11-25 09:18:38 +08:00
|
|
|
.. option:: EnumConstantIgnoredRegexp
|
|
|
|
|
|
|
|
Identifier naming checks won't be enforced for enumeration constant names
|
|
|
|
matching this regular expression.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
.. option:: EnumConstantSuffix
|
|
|
|
|
|
|
|
When defined, the check will ensure enumeration constant names will add the
|
|
|
|
suffix with the given value (regardless of casing).
|
|
|
|
|
2021-08-02 06:20:12 +08:00
|
|
|
.. option:: EnumConstantHungarianPrefix
|
|
|
|
|
|
|
|
When enabled, the check ensures that the declared identifier will
|
|
|
|
have a Hungarian notation prefix based on the declared type.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
For example using values of:
|
|
|
|
|
|
|
|
- EnumConstantCase of ``lower_case``
|
|
|
|
- EnumConstantPrefix of ``pre_``
|
|
|
|
- EnumConstantSuffix of ``_post``
|
2021-08-02 06:20:12 +08:00
|
|
|
- EnumConstantHungarianPrefix of ``On``
|
2019-01-16 06:06:49 +08:00
|
|
|
|
|
|
|
Identifies and/or transforms enumeration constant names as follows:
|
|
|
|
|
|
|
|
Before:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
enum FOO { One, Two, Three };
|
|
|
|
|
|
|
|
After:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
enum FOO { pre_One_post, pre_Two_post, pre_Three_post };
|
|
|
|
|
|
|
|
.. option:: FunctionCase
|
|
|
|
|
|
|
|
When defined, the check will ensure function names conform to the
|
|
|
|
selected casing.
|
|
|
|
|
|
|
|
.. option:: FunctionPrefix
|
|
|
|
|
|
|
|
When defined, the check will ensure function names will add the
|
|
|
|
prefixed with the given value (regardless of casing).
|
|
|
|
|
2020-11-25 09:18:38 +08:00
|
|
|
.. option:: FunctionIgnoredRegexp
|
|
|
|
|
|
|
|
Identifier naming checks won't be enforced for function names
|
|
|
|
matching this regular expression.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
.. option:: FunctionSuffix
|
|
|
|
|
|
|
|
When defined, the check will ensure function names will add the
|
|
|
|
suffix with the given value (regardless of casing).
|
|
|
|
|
|
|
|
For example using values of:
|
|
|
|
|
|
|
|
- FunctionCase of ``lower_case``
|
|
|
|
- FunctionPrefix of ``pre_``
|
|
|
|
- FunctionSuffix of ``_post``
|
|
|
|
|
|
|
|
Identifies and/or transforms function names as follows:
|
|
|
|
|
|
|
|
Before:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
char MY_Function_string();
|
|
|
|
|
|
|
|
After:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
char pre_my_function_string_post();
|
|
|
|
|
2020-08-01 17:35:13 +08:00
|
|
|
.. option:: GetConfigPerFile
|
|
|
|
|
|
|
|
When `true` the check will look for the configuration for where an
|
|
|
|
identifier is declared. Useful for when included header files use a
|
|
|
|
different style.
|
|
|
|
Default value is `true`.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
.. option:: GlobalConstantCase
|
|
|
|
|
|
|
|
When defined, the check will ensure global constant names conform to the
|
|
|
|
selected casing.
|
|
|
|
|
|
|
|
.. option:: GlobalConstantPrefix
|
|
|
|
|
|
|
|
When defined, the check will ensure global constant names will add the
|
|
|
|
prefixed with the given value (regardless of casing).
|
|
|
|
|
2020-11-25 09:18:38 +08:00
|
|
|
.. option:: GlobalConstantIgnoredRegexp
|
|
|
|
|
|
|
|
Identifier naming checks won't be enforced for global constant names
|
|
|
|
matching this regular expression.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
.. option:: GlobalConstantSuffix
|
|
|
|
|
|
|
|
When defined, the check will ensure global constant names will add the
|
|
|
|
suffix with the given value (regardless of casing).
|
|
|
|
|
2021-08-02 06:20:12 +08:00
|
|
|
.. option:: GlobalConstantHungarianPrefix
|
|
|
|
|
|
|
|
When enabled, the check ensures that the declared identifier will
|
|
|
|
have a Hungarian notation prefix based on the declared type.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
For example using values of:
|
|
|
|
|
|
|
|
- GlobalConstantCase of ``lower_case``
|
|
|
|
- GlobalConstantPrefix of ``pre_``
|
|
|
|
- GlobalConstantSuffix of ``_post``
|
2021-08-02 06:20:12 +08:00
|
|
|
- GlobalConstantHungarianPrefix of ``On``
|
2019-01-16 06:06:49 +08:00
|
|
|
|
|
|
|
Identifies and/or transforms global constant names as follows:
|
|
|
|
|
|
|
|
Before:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
unsigned const MyConstGlobal_array[] = {1, 2, 3};
|
|
|
|
|
|
|
|
After:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
unsigned const pre_myconstglobal_array_post[] = {1, 2, 3};
|
|
|
|
|
|
|
|
.. option:: GlobalConstantPointerCase
|
|
|
|
|
|
|
|
When defined, the check will ensure global constant pointer names conform to the
|
|
|
|
selected casing.
|
|
|
|
|
|
|
|
.. option:: GlobalConstantPointerPrefix
|
|
|
|
|
|
|
|
When defined, the check will ensure global constant pointer names will add the
|
|
|
|
prefixed with the given value (regardless of casing).
|
|
|
|
|
2020-11-25 09:18:38 +08:00
|
|
|
.. option:: GlobalConstantPointerIgnoredRegexp
|
|
|
|
|
|
|
|
Identifier naming checks won't be enforced for global constant pointer
|
|
|
|
names matching this regular expression.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
.. option:: GlobalConstantPointerSuffix
|
|
|
|
|
|
|
|
When defined, the check will ensure global constant pointer names will add the
|
|
|
|
suffix with the given value (regardless of casing).
|
|
|
|
|
2021-08-02 06:20:12 +08:00
|
|
|
.. option:: GlobalConstantPointerHungarianPrefix
|
|
|
|
|
|
|
|
When enabled, the check ensures that the declared identifier will
|
|
|
|
have a Hungarian notation prefix based on the declared type.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
For example using values of:
|
|
|
|
|
|
|
|
- GlobalConstantPointerCase of ``lower_case``
|
|
|
|
- GlobalConstantPointerPrefix of ``pre_``
|
|
|
|
- GlobalConstantPointerSuffix of ``_post``
|
2021-08-02 06:20:12 +08:00
|
|
|
- GlobalConstantPointerHungarianPrefix of ``On``
|
2019-01-16 06:06:49 +08:00
|
|
|
|
|
|
|
Identifies and/or transforms global constant pointer names as follows:
|
|
|
|
|
|
|
|
Before:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
int *const MyConstantGlobalPointer = nullptr;
|
|
|
|
|
|
|
|
After:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
int *const pre_myconstantglobalpointer_post = nullptr;
|
|
|
|
|
|
|
|
.. option:: GlobalFunctionCase
|
|
|
|
|
|
|
|
When defined, the check will ensure global function names conform to the
|
|
|
|
selected casing.
|
|
|
|
|
|
|
|
.. option:: GlobalFunctionPrefix
|
|
|
|
|
|
|
|
When defined, the check will ensure global function names will add the
|
|
|
|
prefixed with the given value (regardless of casing).
|
|
|
|
|
2020-11-25 09:18:38 +08:00
|
|
|
.. option:: GlobalFunctionIgnoredRegexp
|
|
|
|
|
|
|
|
Identifier naming checks won't be enforced for global function names
|
|
|
|
matching this regular expression.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
.. option:: GlobalFunctionSuffix
|
|
|
|
|
|
|
|
When defined, the check will ensure global function names will add the
|
|
|
|
suffix with the given value (regardless of casing).
|
|
|
|
|
|
|
|
For example using values of:
|
|
|
|
|
|
|
|
- GlobalFunctionCase of ``lower_case``
|
|
|
|
- GlobalFunctionPrefix of ``pre_``
|
|
|
|
- GlobalFunctionSuffix of ``_post``
|
|
|
|
|
|
|
|
Identifies and/or transforms global function names as follows:
|
|
|
|
|
|
|
|
Before:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
void GLOBAL_FUNCTION(int PARAMETER_1, int const CONST_parameter);
|
|
|
|
|
|
|
|
After:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
void pre_global_function_post(int PARAMETER_1, int const CONST_parameter);
|
|
|
|
|
|
|
|
.. option:: GlobalPointerCase
|
|
|
|
|
|
|
|
When defined, the check will ensure global pointer names conform to the
|
|
|
|
selected casing.
|
|
|
|
|
|
|
|
.. option:: GlobalPointerPrefix
|
|
|
|
|
|
|
|
When defined, the check will ensure global pointer names will add the
|
|
|
|
prefixed with the given value (regardless of casing).
|
|
|
|
|
2020-11-25 09:18:38 +08:00
|
|
|
.. option:: GlobalPointerIgnoredRegexp
|
|
|
|
|
|
|
|
Identifier naming checks won't be enforced for global pointer names
|
|
|
|
matching this regular expression.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
.. option:: GlobalPointerSuffix
|
|
|
|
|
|
|
|
When defined, the check will ensure global pointer names will add the
|
|
|
|
suffix with the given value (regardless of casing).
|
|
|
|
|
2021-08-02 06:20:12 +08:00
|
|
|
.. option:: GlobalPointerHungarianPrefix
|
|
|
|
|
|
|
|
When enabled, the check ensures that the declared identifier will
|
|
|
|
have a Hungarian notation prefix based on the declared type.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
For example using values of:
|
|
|
|
|
|
|
|
- GlobalPointerCase of ``lower_case``
|
|
|
|
- GlobalPointerPrefix of ``pre_``
|
|
|
|
- GlobalPointerSuffix of ``_post``
|
2021-08-02 06:20:12 +08:00
|
|
|
- GlobalPointerHungarianPrefix of ``On``
|
2019-01-16 06:06:49 +08:00
|
|
|
|
|
|
|
Identifies and/or transforms global pointer names as follows:
|
|
|
|
|
|
|
|
Before:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
int *GLOBAL3;
|
|
|
|
|
|
|
|
After:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
int *pre_global3_post;
|
|
|
|
|
|
|
|
.. option:: GlobalVariableCase
|
|
|
|
|
|
|
|
When defined, the check will ensure global variable names conform to the
|
|
|
|
selected casing.
|
|
|
|
|
|
|
|
.. option:: GlobalVariablePrefix
|
|
|
|
|
|
|
|
When defined, the check will ensure global variable names will add the
|
|
|
|
prefixed with the given value (regardless of casing).
|
|
|
|
|
2020-11-25 09:18:38 +08:00
|
|
|
.. option:: GlobalVariableIgnoredRegexp
|
|
|
|
|
|
|
|
Identifier naming checks won't be enforced for global variable names
|
|
|
|
matching this regular expression.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
.. option:: GlobalVariableSuffix
|
|
|
|
|
|
|
|
When defined, the check will ensure global variable names will add the
|
|
|
|
suffix with the given value (regardless of casing).
|
|
|
|
|
2021-08-02 06:20:12 +08:00
|
|
|
.. option:: GlobalVariableHungarianPrefix
|
|
|
|
|
|
|
|
When enabled, the check ensures that the declared identifier will
|
|
|
|
have a Hungarian notation prefix based on the declared type.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
For example using values of:
|
|
|
|
|
|
|
|
- GlobalVariableCase of ``lower_case``
|
|
|
|
- GlobalVariablePrefix of ``pre_``
|
|
|
|
- GlobalVariableSuffix of ``_post``
|
2021-08-02 06:20:12 +08:00
|
|
|
- GlobalVariableHungarianPrefix of ``On``
|
2019-01-16 06:06:49 +08:00
|
|
|
|
|
|
|
Identifies and/or transforms global variable names as follows:
|
|
|
|
|
|
|
|
Before:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
int GLOBAL3;
|
|
|
|
|
|
|
|
After:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
int pre_global3_post;
|
|
|
|
|
[clang-tidy] readability-identifier-naming disregards parameters restrictions on main like functions
Summary:
Typically most main functions have the signature:
```
int main(int argc, char *argv[])
```
To stick with convention when renaming parameters we should ignore the `argc` and `argv` names even if the parameter style says they should be renamed. This patch addresses this by checking all ParmVarDecls if they form part of a function with a signature that matches main `int name(int argc, char * argv[], (optional char *env[]))`
Reviewers: aaron.ballman, JonasToth, alexfh, hokein
Reviewed By: aaron.ballman
Subscribers: Mordante, merge_guards_bot, xazax.hun, kristof.beyls, cfe-commits
Tags: #clang, #clang-tools-extra
Differential Revision: https://reviews.llvm.org/D73098
2020-01-28 07:46:53 +08:00
|
|
|
.. option:: IgnoreMainLikeFunctions
|
|
|
|
|
2020-12-07 20:13:56 +08:00
|
|
|
When set to `true` functions that have a similar signature to ``main`` or
|
[clang-tidy] readability-identifier-naming disregards parameters restrictions on main like functions
Summary:
Typically most main functions have the signature:
```
int main(int argc, char *argv[])
```
To stick with convention when renaming parameters we should ignore the `argc` and `argv` names even if the parameter style says they should be renamed. This patch addresses this by checking all ParmVarDecls if they form part of a function with a signature that matches main `int name(int argc, char * argv[], (optional char *env[]))`
Reviewers: aaron.ballman, JonasToth, alexfh, hokein
Reviewed By: aaron.ballman
Subscribers: Mordante, merge_guards_bot, xazax.hun, kristof.beyls, cfe-commits
Tags: #clang, #clang-tools-extra
Differential Revision: https://reviews.llvm.org/D73098
2020-01-28 07:46:53 +08:00
|
|
|
``wmain`` won't enforce checks on the names of their parameters.
|
2020-12-07 20:13:56 +08:00
|
|
|
Default value is `false`.
|
[clang-tidy] readability-identifier-naming disregards parameters restrictions on main like functions
Summary:
Typically most main functions have the signature:
```
int main(int argc, char *argv[])
```
To stick with convention when renaming parameters we should ignore the `argc` and `argv` names even if the parameter style says they should be renamed. This patch addresses this by checking all ParmVarDecls if they form part of a function with a signature that matches main `int name(int argc, char * argv[], (optional char *env[]))`
Reviewers: aaron.ballman, JonasToth, alexfh, hokein
Reviewed By: aaron.ballman
Subscribers: Mordante, merge_guards_bot, xazax.hun, kristof.beyls, cfe-commits
Tags: #clang, #clang-tools-extra
Differential Revision: https://reviews.llvm.org/D73098
2020-01-28 07:46:53 +08:00
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
.. option:: InlineNamespaceCase
|
|
|
|
|
|
|
|
When defined, the check will ensure inline namespaces names conform to the
|
|
|
|
selected casing.
|
|
|
|
|
|
|
|
.. option:: InlineNamespacePrefix
|
|
|
|
|
|
|
|
When defined, the check will ensure inline namespaces names will add the
|
|
|
|
prefixed with the given value (regardless of casing).
|
|
|
|
|
2020-11-25 09:18:38 +08:00
|
|
|
.. option:: InlineNamespaceIgnoredRegexp
|
|
|
|
|
|
|
|
Identifier naming checks won't be enforced for inline namespaces names
|
|
|
|
matching this regular expression.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
.. option:: InlineNamespaceSuffix
|
|
|
|
|
|
|
|
When defined, the check will ensure inline namespaces names will add the
|
|
|
|
suffix with the given value (regardless of casing).
|
|
|
|
|
|
|
|
For example using values of:
|
|
|
|
|
|
|
|
- InlineNamespaceCase of ``lower_case``
|
|
|
|
- InlineNamespacePrefix of ``pre_``
|
|
|
|
- InlineNamespaceSuffix of ``_post``
|
|
|
|
|
|
|
|
Identifies and/or transforms inline namespaces names as follows:
|
|
|
|
|
|
|
|
Before:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
namespace FOO_NS {
|
|
|
|
inline namespace InlineNamespace {
|
|
|
|
...
|
|
|
|
}
|
|
|
|
} // namespace FOO_NS
|
|
|
|
|
|
|
|
After:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
namespace FOO_NS {
|
|
|
|
inline namespace pre_inlinenamespace_post {
|
|
|
|
...
|
|
|
|
}
|
|
|
|
} // namespace FOO_NS
|
|
|
|
|
|
|
|
.. option:: LocalConstantCase
|
|
|
|
|
|
|
|
When defined, the check will ensure local constant names conform to the
|
|
|
|
selected casing.
|
|
|
|
|
|
|
|
.. option:: LocalConstantPrefix
|
|
|
|
|
|
|
|
When defined, the check will ensure local constant names will add the
|
|
|
|
prefixed with the given value (regardless of casing).
|
|
|
|
|
2020-11-25 09:18:38 +08:00
|
|
|
.. option:: LocalConstantIgnoredRegexp
|
|
|
|
|
|
|
|
Identifier naming checks won't be enforced for local constant names
|
|
|
|
matching this regular expression.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
.. option:: LocalConstantSuffix
|
|
|
|
|
|
|
|
When defined, the check will ensure local constant names will add the
|
|
|
|
suffix with the given value (regardless of casing).
|
|
|
|
|
2021-08-02 06:20:12 +08:00
|
|
|
.. option:: LocalConstantHungarianPrefix
|
|
|
|
|
|
|
|
When enabled, the check ensures that the declared identifier will
|
|
|
|
have a Hungarian notation prefix based on the declared type.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
For example using values of:
|
|
|
|
|
|
|
|
- LocalConstantCase of ``lower_case``
|
|
|
|
- LocalConstantPrefix of ``pre_``
|
|
|
|
- LocalConstantSuffix of ``_post``
|
2021-08-02 06:20:12 +08:00
|
|
|
- LocalConstantHungarianPrefix of ``On``
|
2019-01-16 06:06:49 +08:00
|
|
|
|
|
|
|
Identifies and/or transforms local constant names as follows:
|
|
|
|
|
|
|
|
Before:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
void foo() { int const local_Constant = 3; }
|
|
|
|
|
|
|
|
After:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
void foo() { int const pre_local_constant_post = 3; }
|
|
|
|
|
|
|
|
.. option:: LocalConstantPointerCase
|
|
|
|
|
|
|
|
When defined, the check will ensure local constant pointer names conform to the
|
|
|
|
selected casing.
|
|
|
|
|
|
|
|
.. option:: LocalConstantPointerPrefix
|
|
|
|
|
|
|
|
When defined, the check will ensure local constant pointer names will add the
|
|
|
|
prefixed with the given value (regardless of casing).
|
|
|
|
|
2020-11-25 09:18:38 +08:00
|
|
|
.. option:: LocalConstantPointerIgnoredRegexp
|
|
|
|
|
|
|
|
Identifier naming checks won't be enforced for local constant pointer names
|
|
|
|
matching this regular expression.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
.. option:: LocalConstantPointerSuffix
|
|
|
|
|
|
|
|
When defined, the check will ensure local constant pointer names will add the
|
|
|
|
suffix with the given value (regardless of casing).
|
|
|
|
|
2021-08-02 06:20:12 +08:00
|
|
|
.. option:: LocalConstantPointerHungarianPrefix
|
|
|
|
|
|
|
|
When enabled, the check ensures that the declared identifier will
|
|
|
|
have a Hungarian notation prefix based on the declared type.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
For example using values of:
|
|
|
|
|
|
|
|
- LocalConstantPointerCase of ``lower_case``
|
|
|
|
- LocalConstantPointerPrefix of ``pre_``
|
|
|
|
- LocalConstantPointerSuffix of ``_post``
|
2021-08-02 06:20:12 +08:00
|
|
|
- LocalConstantPointerHungarianPrefix of ``On``
|
2019-01-16 06:06:49 +08:00
|
|
|
|
|
|
|
Identifies and/or transforms local constant pointer names as follows:
|
|
|
|
|
|
|
|
Before:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
void foo() { int const *local_Constant = 3; }
|
|
|
|
|
|
|
|
After:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
void foo() { int const *pre_local_constant_post = 3; }
|
|
|
|
|
|
|
|
.. option:: LocalPointerCase
|
|
|
|
|
|
|
|
When defined, the check will ensure local pointer names conform to the
|
|
|
|
selected casing.
|
|
|
|
|
|
|
|
.. option:: LocalPointerPrefix
|
|
|
|
|
|
|
|
When defined, the check will ensure local pointer names will add the
|
|
|
|
prefixed with the given value (regardless of casing).
|
|
|
|
|
2020-11-25 09:18:38 +08:00
|
|
|
.. option:: LocalPointerIgnoredRegexp
|
|
|
|
|
|
|
|
Identifier naming checks won't be enforced for local pointer names
|
|
|
|
matching this regular expression.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
.. option:: LocalPointerSuffix
|
|
|
|
|
|
|
|
When defined, the check will ensure local pointer names will add the
|
|
|
|
suffix with the given value (regardless of casing).
|
|
|
|
|
2021-08-02 06:20:12 +08:00
|
|
|
.. option:: LocalPointerHungarianPrefix
|
|
|
|
|
|
|
|
When enabled, the check ensures that the declared identifier will
|
|
|
|
have a Hungarian notation prefix based on the declared type.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
For example using values of:
|
|
|
|
|
|
|
|
- LocalPointerCase of ``lower_case``
|
|
|
|
- LocalPointerPrefix of ``pre_``
|
|
|
|
- LocalPointerSuffix of ``_post``
|
2021-08-02 06:20:12 +08:00
|
|
|
- LocalPointerHungarianPrefix of ``On``
|
2019-01-16 06:06:49 +08:00
|
|
|
|
|
|
|
Identifies and/or transforms local pointer names as follows:
|
|
|
|
|
|
|
|
Before:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
void foo() { int *local_Constant; }
|
|
|
|
|
|
|
|
After:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
void foo() { int *pre_local_constant_post; }
|
|
|
|
|
|
|
|
.. option:: LocalVariableCase
|
|
|
|
|
|
|
|
When defined, the check will ensure local variable names conform to the
|
|
|
|
selected casing.
|
|
|
|
|
|
|
|
.. option:: LocalVariablePrefix
|
|
|
|
|
|
|
|
When defined, the check will ensure local variable names will add the
|
|
|
|
prefixed with the given value (regardless of casing).
|
|
|
|
|
2020-11-25 09:18:38 +08:00
|
|
|
.. option:: LocalVariableIgnoredRegexp
|
|
|
|
|
|
|
|
Identifier naming checks won't be enforced for local variable names
|
|
|
|
matching this regular expression.
|
|
|
|
|
|
|
|
For example using values of:
|
|
|
|
|
|
|
|
- LocalVariableCase of ``CamelCase``
|
|
|
|
- LocalVariableIgnoredRegexp of ``\w{1,2}``
|
|
|
|
|
|
|
|
Will exclude variables with a length less than or equal to 2 from the
|
|
|
|
camel case check applied to other variables.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
.. option:: LocalVariableSuffix
|
|
|
|
|
|
|
|
When defined, the check will ensure local variable names will add the
|
|
|
|
suffix with the given value (regardless of casing).
|
|
|
|
|
2021-08-02 06:20:12 +08:00
|
|
|
.. option:: LocalVariableHungarianPrefix
|
|
|
|
|
|
|
|
When enabled, the check ensures that the declared identifier will
|
|
|
|
have a Hungarian notation prefix based on the declared type.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
For example using values of:
|
|
|
|
|
|
|
|
- LocalVariableCase of ``lower_case``
|
|
|
|
- LocalVariablePrefix of ``pre_``
|
|
|
|
- LocalVariableSuffix of ``_post``
|
2021-08-02 06:20:12 +08:00
|
|
|
- LocalVariableHungarianPrefix of ``On``
|
2019-01-16 06:06:49 +08:00
|
|
|
|
|
|
|
Identifies and/or transforms local variable names as follows:
|
|
|
|
|
|
|
|
Before:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
void foo() { int local_Constant; }
|
|
|
|
|
|
|
|
After:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
void foo() { int pre_local_constant_post; }
|
|
|
|
|
2020-06-03 16:23:32 +08:00
|
|
|
.. option:: MacroDefinitionCase
|
|
|
|
|
|
|
|
When defined, the check will ensure macro definitions conform to the
|
|
|
|
selected casing.
|
|
|
|
|
|
|
|
.. option:: MacroDefinitionPrefix
|
|
|
|
|
|
|
|
When defined, the check will ensure macro definitions will add the
|
|
|
|
prefixed with the given value (regardless of casing).
|
|
|
|
|
2020-11-25 09:18:38 +08:00
|
|
|
.. option:: MacroDefinitionIgnoredRegexp
|
|
|
|
|
|
|
|
Identifier naming checks won't be enforced for macro definitions
|
|
|
|
matching this regular expression.
|
|
|
|
|
2020-06-03 16:23:32 +08:00
|
|
|
.. option:: MacroDefinitionSuffix
|
|
|
|
|
|
|
|
When defined, the check will ensure macro definitions will add the
|
|
|
|
suffix with the given value (regardless of casing).
|
|
|
|
|
|
|
|
For example using values of:
|
|
|
|
|
|
|
|
- MacroDefinitionCase of ``lower_case``
|
|
|
|
- MacroDefinitionPrefix of ``pre_``
|
|
|
|
- MacroDefinitionSuffix of ``_post``
|
|
|
|
|
|
|
|
Identifies and/or transforms macro definitions as follows:
|
|
|
|
|
|
|
|
Before:
|
|
|
|
|
|
|
|
.. code-block:: c
|
|
|
|
|
|
|
|
#define MY_MacroDefinition
|
|
|
|
|
|
|
|
After:
|
|
|
|
|
|
|
|
.. code-block:: c
|
|
|
|
|
|
|
|
#define pre_my_macro_definition_post
|
|
|
|
|
|
|
|
Note: This will not warn on builtin macros or macros defined on the command line
|
|
|
|
using the ``-D`` flag.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
.. option:: MemberCase
|
|
|
|
|
|
|
|
When defined, the check will ensure member names conform to the
|
|
|
|
selected casing.
|
|
|
|
|
|
|
|
.. option:: MemberPrefix
|
|
|
|
|
|
|
|
When defined, the check will ensure member names will add the
|
|
|
|
prefixed with the given value (regardless of casing).
|
|
|
|
|
2020-11-25 09:18:38 +08:00
|
|
|
.. option:: MemberIgnoredRegexp
|
|
|
|
|
|
|
|
Identifier naming checks won't be enforced for member names
|
|
|
|
matching this regular expression.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
.. option:: MemberSuffix
|
|
|
|
|
|
|
|
When defined, the check will ensure member names will add the
|
|
|
|
suffix with the given value (regardless of casing).
|
|
|
|
|
2021-08-02 06:20:12 +08:00
|
|
|
.. option:: MemberHungarianPrefix
|
|
|
|
|
|
|
|
When enabled, the check ensures that the declared identifier will
|
|
|
|
have a Hungarian notation prefix based on the declared type.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
For example using values of:
|
|
|
|
|
|
|
|
- MemberCase of ``lower_case``
|
|
|
|
- MemberPrefix of ``pre_``
|
|
|
|
- MemberSuffix of ``_post``
|
2021-08-02 06:20:12 +08:00
|
|
|
- MemberHungarianPrefix of ``On``
|
2019-01-16 06:06:49 +08:00
|
|
|
|
|
|
|
Identifies and/or transforms member names as follows:
|
|
|
|
|
|
|
|
Before:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
class Foo {
|
|
|
|
char MY_ConstMember_string[4];
|
|
|
|
}
|
|
|
|
|
|
|
|
After:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
class Foo {
|
|
|
|
char pre_my_constmember_string_post[4];
|
|
|
|
}
|
|
|
|
|
|
|
|
.. option:: MethodCase
|
|
|
|
|
|
|
|
When defined, the check will ensure method names conform to the
|
|
|
|
selected casing.
|
|
|
|
|
|
|
|
.. option:: MethodPrefix
|
|
|
|
|
|
|
|
When defined, the check will ensure method names will add the
|
|
|
|
prefixed with the given value (regardless of casing).
|
|
|
|
|
2020-11-25 09:18:38 +08:00
|
|
|
.. option:: MethodIgnoredRegexp
|
|
|
|
|
|
|
|
Identifier naming checks won't be enforced for method names
|
|
|
|
matching this regular expression.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
.. option:: MethodSuffix
|
|
|
|
|
|
|
|
When defined, the check will ensure method names will add the
|
|
|
|
suffix with the given value (regardless of casing).
|
|
|
|
|
|
|
|
For example using values of:
|
|
|
|
|
|
|
|
- MethodCase of ``lower_case``
|
|
|
|
- MethodPrefix of ``pre_``
|
|
|
|
- MethodSuffix of ``_post``
|
|
|
|
|
|
|
|
Identifies and/or transforms method names as follows:
|
|
|
|
|
|
|
|
Before:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
class Foo {
|
|
|
|
char MY_Method_string();
|
|
|
|
}
|
|
|
|
|
|
|
|
After:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
class Foo {
|
|
|
|
char pre_my_method_string_post();
|
|
|
|
}
|
|
|
|
|
|
|
|
.. option:: NamespaceCase
|
|
|
|
|
|
|
|
When defined, the check will ensure namespace names conform to the
|
|
|
|
selected casing.
|
|
|
|
|
|
|
|
.. option:: NamespacePrefix
|
|
|
|
|
|
|
|
When defined, the check will ensure namespace names will add the
|
|
|
|
prefixed with the given value (regardless of casing).
|
|
|
|
|
2020-11-25 09:18:38 +08:00
|
|
|
.. option:: NamespaceIgnoredRegexp
|
|
|
|
|
|
|
|
Identifier naming checks won't be enforced for namespace names
|
|
|
|
matching this regular expression.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
.. option:: NamespaceSuffix
|
|
|
|
|
|
|
|
When defined, the check will ensure namespace names will add the
|
|
|
|
suffix with the given value (regardless of casing).
|
|
|
|
|
|
|
|
For example using values of:
|
|
|
|
|
|
|
|
- NamespaceCase of ``lower_case``
|
|
|
|
- NamespacePrefix of ``pre_``
|
|
|
|
- NamespaceSuffix of ``_post``
|
|
|
|
|
|
|
|
Identifies and/or transforms namespace names as follows:
|
|
|
|
|
|
|
|
Before:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
namespace FOO_NS {
|
|
|
|
...
|
|
|
|
}
|
|
|
|
|
|
|
|
After:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
namespace pre_foo_ns_post {
|
|
|
|
...
|
|
|
|
}
|
|
|
|
|
|
|
|
.. option:: ParameterCase
|
|
|
|
|
|
|
|
When defined, the check will ensure parameter names conform to the
|
|
|
|
selected casing.
|
|
|
|
|
|
|
|
.. option:: ParameterPrefix
|
|
|
|
|
|
|
|
When defined, the check will ensure parameter names will add the
|
|
|
|
prefixed with the given value (regardless of casing).
|
|
|
|
|
2020-11-25 09:18:38 +08:00
|
|
|
.. option:: ParameterIgnoredRegexp
|
|
|
|
|
|
|
|
Identifier naming checks won't be enforced for parameter names
|
|
|
|
matching this regular expression.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
.. option:: ParameterSuffix
|
|
|
|
|
|
|
|
When defined, the check will ensure parameter names will add the
|
|
|
|
suffix with the given value (regardless of casing).
|
|
|
|
|
2021-08-02 06:20:12 +08:00
|
|
|
.. option:: ParameterHungarianPrefix
|
|
|
|
|
|
|
|
When enabled, the check ensures that the declared identifier will
|
|
|
|
have a Hungarian notation prefix based on the declared type.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
For example using values of:
|
|
|
|
|
|
|
|
- ParameterCase of ``lower_case``
|
|
|
|
- ParameterPrefix of ``pre_``
|
|
|
|
- ParameterSuffix of ``_post``
|
2021-08-02 06:20:12 +08:00
|
|
|
- ParameterHungarianPrefix of ``On``
|
2019-01-16 06:06:49 +08:00
|
|
|
|
|
|
|
Identifies and/or transforms parameter names as follows:
|
|
|
|
|
|
|
|
Before:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
void GLOBAL_FUNCTION(int PARAMETER_1, int const CONST_parameter);
|
|
|
|
|
|
|
|
After:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
void GLOBAL_FUNCTION(int pre_parameter_post, int const CONST_parameter);
|
|
|
|
|
|
|
|
.. option:: ParameterPackCase
|
|
|
|
|
|
|
|
When defined, the check will ensure parameter pack names conform to the
|
|
|
|
selected casing.
|
|
|
|
|
|
|
|
.. option:: ParameterPackPrefix
|
|
|
|
|
|
|
|
When defined, the check will ensure parameter pack names will add the
|
|
|
|
prefixed with the given value (regardless of casing).
|
|
|
|
|
2020-11-25 09:18:38 +08:00
|
|
|
.. option:: ParameterPackIgnoredRegexp
|
|
|
|
|
|
|
|
Identifier naming checks won't be enforced for parameter pack names
|
|
|
|
matching this regular expression.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
.. option:: ParameterPackSuffix
|
|
|
|
|
|
|
|
When defined, the check will ensure parameter pack names will add the
|
|
|
|
suffix with the given value (regardless of casing).
|
|
|
|
|
|
|
|
For example using values of:
|
|
|
|
|
|
|
|
- ParameterPackCase of ``lower_case``
|
|
|
|
- ParameterPackPrefix of ``pre_``
|
|
|
|
- ParameterPackSuffix of ``_post``
|
|
|
|
|
|
|
|
Identifies and/or transforms parameter pack names as follows:
|
|
|
|
|
|
|
|
Before:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
template <typename... TYPE_parameters> {
|
|
|
|
void FUNCTION(int... TYPE_parameters);
|
|
|
|
}
|
|
|
|
|
|
|
|
After:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
template <typename... TYPE_parameters> {
|
|
|
|
void FUNCTION(int... pre_type_parameters_post);
|
|
|
|
}
|
|
|
|
|
|
|
|
.. option:: PointerParameterCase
|
|
|
|
|
|
|
|
When defined, the check will ensure pointer parameter names conform to the
|
|
|
|
selected casing.
|
|
|
|
|
|
|
|
.. option:: PointerParameterPrefix
|
|
|
|
|
|
|
|
When defined, the check will ensure pointer parameter names will add the
|
|
|
|
prefixed with the given value (regardless of casing).
|
|
|
|
|
2020-11-25 09:18:38 +08:00
|
|
|
.. option:: PointerParameterIgnoredRegexp
|
|
|
|
|
|
|
|
Identifier naming checks won't be enforced for pointer parameter names
|
|
|
|
matching this regular expression.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
.. option:: PointerParameterSuffix
|
|
|
|
|
|
|
|
When defined, the check will ensure pointer parameter names will add the
|
|
|
|
suffix with the given value (regardless of casing).
|
|
|
|
|
2021-08-02 06:20:12 +08:00
|
|
|
.. option:: PointerParameterHungarianPrefix
|
|
|
|
|
|
|
|
When enabled, the check ensures that the declared identifier will
|
|
|
|
have a Hungarian notation prefix based on the declared type.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
For example using values of:
|
|
|
|
|
|
|
|
- PointerParameterCase of ``lower_case``
|
|
|
|
- PointerParameterPrefix of ``pre_``
|
|
|
|
- PointerParameterSuffix of ``_post``
|
2021-08-02 06:20:12 +08:00
|
|
|
- PointerParameterHungarianPrefix of ``On``
|
2019-01-16 06:06:49 +08:00
|
|
|
|
|
|
|
Identifies and/or transforms pointer parameter names as follows:
|
|
|
|
|
|
|
|
Before:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
void FUNCTION(int *PARAMETER);
|
|
|
|
|
|
|
|
After:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
void FUNCTION(int *pre_parameter_post);
|
|
|
|
|
|
|
|
.. option:: PrivateMemberCase
|
|
|
|
|
|
|
|
When defined, the check will ensure private member names conform to the
|
|
|
|
selected casing.
|
|
|
|
|
|
|
|
.. option:: PrivateMemberPrefix
|
|
|
|
|
|
|
|
When defined, the check will ensure private member names will add the
|
|
|
|
prefixed with the given value (regardless of casing).
|
|
|
|
|
2020-11-25 09:18:38 +08:00
|
|
|
.. option:: PrivateMemberIgnoredRegexp
|
|
|
|
|
|
|
|
Identifier naming checks won't be enforced for private member names
|
|
|
|
matching this regular expression.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
.. option:: PrivateMemberSuffix
|
|
|
|
|
|
|
|
When defined, the check will ensure private member names will add the
|
|
|
|
suffix with the given value (regardless of casing).
|
|
|
|
|
2021-08-02 06:20:12 +08:00
|
|
|
.. option:: PrivateMemberHungarianPrefix
|
|
|
|
|
|
|
|
When enabled, the check ensures that the declared identifier will
|
|
|
|
have a Hungarian notation prefix based on the declared type.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
For example using values of:
|
|
|
|
|
|
|
|
- PrivateMemberCase of ``lower_case``
|
|
|
|
- PrivateMemberPrefix of ``pre_``
|
|
|
|
- PrivateMemberSuffix of ``_post``
|
2021-08-02 06:20:12 +08:00
|
|
|
- PrivateMemberHungarianPrefix of ``On``
|
2019-01-16 06:06:49 +08:00
|
|
|
|
|
|
|
Identifies and/or transforms private member names as follows:
|
|
|
|
|
|
|
|
Before:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
class Foo {
|
|
|
|
private:
|
|
|
|
int Member_Variable;
|
|
|
|
}
|
|
|
|
|
|
|
|
After:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
class Foo {
|
|
|
|
private:
|
|
|
|
int pre_member_variable_post;
|
|
|
|
}
|
|
|
|
|
|
|
|
.. option:: PrivateMethodCase
|
|
|
|
|
|
|
|
When defined, the check will ensure private method names conform to the
|
|
|
|
selected casing.
|
|
|
|
|
|
|
|
.. option:: PrivateMethodPrefix
|
|
|
|
|
|
|
|
When defined, the check will ensure private method names will add the
|
|
|
|
prefixed with the given value (regardless of casing).
|
|
|
|
|
2020-11-25 09:18:38 +08:00
|
|
|
.. option:: PrivateMethodIgnoredRegexp
|
|
|
|
|
|
|
|
Identifier naming checks won't be enforced for private method names
|
|
|
|
matching this regular expression.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
.. option:: PrivateMethodSuffix
|
|
|
|
|
|
|
|
When defined, the check will ensure private method names will add the
|
|
|
|
suffix with the given value (regardless of casing).
|
|
|
|
|
|
|
|
For example using values of:
|
|
|
|
|
|
|
|
- PrivateMethodCase of ``lower_case``
|
|
|
|
- PrivateMethodPrefix of ``pre_``
|
|
|
|
- PrivateMethodSuffix of ``_post``
|
|
|
|
|
|
|
|
Identifies and/or transforms private method names as follows:
|
|
|
|
|
|
|
|
Before:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
class Foo {
|
|
|
|
private:
|
|
|
|
int Member_Method();
|
|
|
|
}
|
|
|
|
|
|
|
|
After:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
class Foo {
|
|
|
|
private:
|
|
|
|
int pre_member_method_post();
|
|
|
|
}
|
|
|
|
|
|
|
|
.. option:: ProtectedMemberCase
|
|
|
|
|
|
|
|
When defined, the check will ensure protected member names conform to the
|
|
|
|
selected casing.
|
|
|
|
|
|
|
|
.. option:: ProtectedMemberPrefix
|
|
|
|
|
|
|
|
When defined, the check will ensure protected member names will add the
|
|
|
|
prefixed with the given value (regardless of casing).
|
|
|
|
|
2020-11-25 09:18:38 +08:00
|
|
|
.. option:: ProtectedMemberIgnoredRegexp
|
|
|
|
|
|
|
|
Identifier naming checks won't be enforced for protected member names
|
|
|
|
matching this regular expression.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
.. option:: ProtectedMemberSuffix
|
|
|
|
|
|
|
|
When defined, the check will ensure protected member names will add the
|
|
|
|
suffix with the given value (regardless of casing).
|
|
|
|
|
2021-08-02 06:20:12 +08:00
|
|
|
.. option:: ProtectedMemberHungarianPrefix
|
|
|
|
|
|
|
|
When enabled, the check ensures that the declared identifier will
|
|
|
|
have a Hungarian notation prefix based on the declared type.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
For example using values of:
|
|
|
|
|
|
|
|
- ProtectedMemberCase of ``lower_case``
|
|
|
|
- ProtectedMemberPrefix of ``pre_``
|
|
|
|
- ProtectedMemberSuffix of ``_post``
|
2021-08-02 06:20:12 +08:00
|
|
|
- ProtectedMemberHungarianPrefix of ``On``
|
2019-01-16 06:06:49 +08:00
|
|
|
|
|
|
|
Identifies and/or transforms protected member names as follows:
|
|
|
|
|
|
|
|
Before:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
class Foo {
|
|
|
|
protected:
|
|
|
|
int Member_Variable;
|
|
|
|
}
|
|
|
|
|
|
|
|
After:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
class Foo {
|
|
|
|
protected:
|
|
|
|
int pre_member_variable_post;
|
|
|
|
}
|
|
|
|
|
|
|
|
.. option:: ProtectedMethodCase
|
|
|
|
|
2020-11-25 09:18:38 +08:00
|
|
|
When defined, the check will ensure protected method names conform to the
|
2019-01-16 06:06:49 +08:00
|
|
|
selected casing.
|
|
|
|
|
|
|
|
.. option:: ProtectedMethodPrefix
|
|
|
|
|
2020-11-25 09:18:38 +08:00
|
|
|
When defined, the check will ensure protected method names will add the
|
2019-01-16 06:06:49 +08:00
|
|
|
prefixed with the given value (regardless of casing).
|
|
|
|
|
2020-11-25 09:18:38 +08:00
|
|
|
.. option:: ProtectedMethodIgnoredRegexp
|
|
|
|
|
|
|
|
Identifier naming checks won't be enforced for protected method names
|
|
|
|
matching this regular expression.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
.. option:: ProtectedMethodSuffix
|
|
|
|
|
2020-11-25 09:18:38 +08:00
|
|
|
When defined, the check will ensure protected method names will add the
|
2019-01-16 06:06:49 +08:00
|
|
|
suffix with the given value (regardless of casing).
|
|
|
|
|
|
|
|
For example using values of:
|
|
|
|
|
|
|
|
- ProtectedMethodCase of ``lower_case``
|
|
|
|
- ProtectedMethodPrefix of ``pre_``
|
|
|
|
- ProtectedMethodSuffix of ``_post``
|
|
|
|
|
|
|
|
Identifies and/or transforms protect method names as follows:
|
|
|
|
|
|
|
|
Before:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
class Foo {
|
|
|
|
protected:
|
|
|
|
int Member_Method();
|
|
|
|
}
|
|
|
|
|
|
|
|
After:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
class Foo {
|
|
|
|
protected:
|
|
|
|
int pre_member_method_post();
|
|
|
|
}
|
|
|
|
|
|
|
|
.. option:: PublicMemberCase
|
|
|
|
|
|
|
|
When defined, the check will ensure public member names conform to the
|
|
|
|
selected casing.
|
|
|
|
|
|
|
|
.. option:: PublicMemberPrefix
|
|
|
|
|
|
|
|
When defined, the check will ensure public member names will add the
|
|
|
|
prefixed with the given value (regardless of casing).
|
|
|
|
|
2020-11-25 09:18:38 +08:00
|
|
|
.. option:: PublicMemberIgnoredRegexp
|
|
|
|
|
|
|
|
Identifier naming checks won't be enforced for public member names
|
|
|
|
matching this regular expression.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
.. option:: PublicMemberSuffix
|
|
|
|
|
|
|
|
When defined, the check will ensure public member names will add the
|
|
|
|
suffix with the given value (regardless of casing).
|
|
|
|
|
2021-08-02 06:20:12 +08:00
|
|
|
.. option:: PublicMemberHungarianPrefix
|
|
|
|
|
|
|
|
When enabled, the check ensures that the declared identifier will
|
|
|
|
have a Hungarian notation prefix based on the declared type.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
For example using values of:
|
|
|
|
|
|
|
|
- PublicMemberCase of ``lower_case``
|
|
|
|
- PublicMemberPrefix of ``pre_``
|
|
|
|
- PublicMemberSuffix of ``_post``
|
2021-08-02 06:20:12 +08:00
|
|
|
- PublicMemberHungarianPrefix of ``On``
|
2019-01-16 06:06:49 +08:00
|
|
|
|
|
|
|
Identifies and/or transforms public member names as follows:
|
|
|
|
|
|
|
|
Before:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
class Foo {
|
|
|
|
public:
|
|
|
|
int Member_Variable;
|
|
|
|
}
|
|
|
|
|
|
|
|
After:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
class Foo {
|
|
|
|
public:
|
|
|
|
int pre_member_variable_post;
|
|
|
|
}
|
|
|
|
|
|
|
|
.. option:: PublicMethodCase
|
|
|
|
|
|
|
|
When defined, the check will ensure public method names conform to the
|
|
|
|
selected casing.
|
|
|
|
|
|
|
|
.. option:: PublicMethodPrefix
|
|
|
|
|
|
|
|
When defined, the check will ensure public method names will add the
|
|
|
|
prefixed with the given value (regardless of casing).
|
|
|
|
|
2020-11-25 09:18:38 +08:00
|
|
|
.. option:: PublicMethodIgnoredRegexp
|
|
|
|
|
|
|
|
Identifier naming checks won't be enforced for public method names
|
|
|
|
matching this regular expression.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
.. option:: PublicMethodSuffix
|
|
|
|
|
|
|
|
When defined, the check will ensure public method names will add the
|
|
|
|
suffix with the given value (regardless of casing).
|
|
|
|
|
|
|
|
For example using values of:
|
|
|
|
|
|
|
|
- PublicMethodCase of ``lower_case``
|
|
|
|
- PublicMethodPrefix of ``pre_``
|
|
|
|
- PublicMethodSuffix of ``_post``
|
|
|
|
|
|
|
|
Identifies and/or transforms public method names as follows:
|
|
|
|
|
|
|
|
Before:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
class Foo {
|
|
|
|
public:
|
|
|
|
int Member_Method();
|
|
|
|
}
|
|
|
|
|
|
|
|
After:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
class Foo {
|
|
|
|
public:
|
|
|
|
int pre_member_method_post();
|
|
|
|
}
|
|
|
|
|
2020-10-19 22:57:46 +08:00
|
|
|
.. option:: ScopedEnumConstantCase
|
|
|
|
|
|
|
|
When defined, the check will ensure scoped enum constant names conform to
|
|
|
|
the selected casing.
|
|
|
|
|
|
|
|
.. option:: ScopedEnumConstantPrefix
|
|
|
|
|
|
|
|
When defined, the check will ensure scoped enum constant names will add the
|
|
|
|
prefixed with the given value (regardless of casing).
|
|
|
|
|
2020-11-25 09:18:38 +08:00
|
|
|
.. option:: ScopedEnumConstantIgnoredRegexp
|
|
|
|
|
|
|
|
Identifier naming checks won't be enforced for scoped enum constant names
|
|
|
|
matching this regular expression.
|
|
|
|
|
2020-10-19 22:57:46 +08:00
|
|
|
.. option:: ScopedEnumConstantSuffix
|
|
|
|
|
|
|
|
When defined, the check will ensure scoped enum constant names will add the
|
|
|
|
suffix with the given value (regardless of casing).
|
|
|
|
|
2021-08-02 06:20:12 +08:00
|
|
|
.. option:: ScopedEnumConstantHungarianPrefix
|
|
|
|
|
|
|
|
When enabled, the check ensures that the declared identifier will
|
|
|
|
have a Hungarian notation prefix based on the declared type.
|
|
|
|
|
2020-10-19 22:57:46 +08:00
|
|
|
For example using values of:
|
|
|
|
|
|
|
|
- ScopedEnumConstantCase of ``lower_case``
|
|
|
|
- ScopedEnumConstantPrefix of ``pre_``
|
|
|
|
- ScopedEnumConstantSuffix of ``_post``
|
2021-08-02 06:20:12 +08:00
|
|
|
- ScopedEnumConstantHungarianPrefix of ``On``
|
2020-10-19 22:57:46 +08:00
|
|
|
|
|
|
|
Identifies and/or transforms enumeration constant names as follows:
|
|
|
|
|
|
|
|
Before:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
enum class FOO { One, Two, Three };
|
|
|
|
|
|
|
|
After:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
enum class FOO { pre_One_post, pre_Two_post, pre_Three_post };
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
.. option:: StaticConstantCase
|
|
|
|
|
|
|
|
When defined, the check will ensure static constant names conform to the
|
|
|
|
selected casing.
|
|
|
|
|
|
|
|
.. option:: StaticConstantPrefix
|
|
|
|
|
|
|
|
When defined, the check will ensure static constant names will add the
|
|
|
|
prefixed with the given value (regardless of casing).
|
|
|
|
|
2020-11-25 09:18:38 +08:00
|
|
|
.. option:: StaticConstantIgnoredRegexp
|
|
|
|
|
|
|
|
Identifier naming checks won't be enforced for static constant names
|
|
|
|
matching this regular expression.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
.. option:: StaticConstantSuffix
|
|
|
|
|
|
|
|
When defined, the check will ensure static constant names will add the
|
|
|
|
suffix with the given value (regardless of casing).
|
|
|
|
|
2021-08-02 06:20:12 +08:00
|
|
|
.. option:: StaticConstantHungarianPrefix
|
|
|
|
|
|
|
|
When enabled, the check ensures that the declared identifier will
|
|
|
|
have a Hungarian notation prefix based on the declared type.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
For example using values of:
|
|
|
|
|
|
|
|
- StaticConstantCase of ``lower_case``
|
|
|
|
- StaticConstantPrefix of ``pre_``
|
|
|
|
- StaticConstantSuffix of ``_post``
|
2021-08-02 06:20:12 +08:00
|
|
|
- StaticConstantHungarianPrefix of ``On``
|
2019-01-16 06:06:49 +08:00
|
|
|
|
|
|
|
Identifies and/or transforms static constant names as follows:
|
|
|
|
|
|
|
|
Before:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
static unsigned const MyConstStatic_array[] = {1, 2, 3};
|
|
|
|
|
|
|
|
After:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
static unsigned const pre_myconststatic_array_post[] = {1, 2, 3};
|
|
|
|
|
|
|
|
.. option:: StaticVariableCase
|
|
|
|
|
|
|
|
When defined, the check will ensure static variable names conform to the
|
|
|
|
selected casing.
|
|
|
|
|
|
|
|
.. option:: StaticVariablePrefix
|
|
|
|
|
|
|
|
When defined, the check will ensure static variable names will add the
|
|
|
|
prefixed with the given value (regardless of casing).
|
|
|
|
|
2020-11-25 09:18:38 +08:00
|
|
|
.. option:: StaticVariableIgnoredRegexp
|
|
|
|
|
|
|
|
Identifier naming checks won't be enforced for static variable names
|
|
|
|
matching this regular expression.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
.. option:: StaticVariableSuffix
|
|
|
|
|
|
|
|
When defined, the check will ensure static variable names will add the
|
|
|
|
suffix with the given value (regardless of casing).
|
|
|
|
|
2021-08-02 06:20:12 +08:00
|
|
|
.. option:: StaticVariableHungarianPrefix
|
|
|
|
|
|
|
|
When enabled, the check ensures that the declared identifier will
|
|
|
|
have a Hungarian notation prefix based on the declared type.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
For example using values of:
|
|
|
|
|
|
|
|
- StaticVariableCase of ``lower_case``
|
|
|
|
- StaticVariablePrefix of ``pre_``
|
|
|
|
- StaticVariableSuffix of ``_post``
|
2021-08-02 06:20:12 +08:00
|
|
|
- StaticVariableHungarianPrefix of ``On``
|
2019-01-16 06:06:49 +08:00
|
|
|
|
|
|
|
Identifies and/or transforms static variable names as follows:
|
|
|
|
|
|
|
|
Before:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
static unsigned MyStatic_array[] = {1, 2, 3};
|
|
|
|
|
|
|
|
After:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
static unsigned pre_mystatic_array_post[] = {1, 2, 3};
|
|
|
|
|
|
|
|
.. option:: StructCase
|
|
|
|
|
|
|
|
When defined, the check will ensure struct names conform to the
|
|
|
|
selected casing.
|
|
|
|
|
|
|
|
.. option:: StructPrefix
|
|
|
|
|
|
|
|
When defined, the check will ensure struct names will add the
|
|
|
|
prefixed with the given value (regardless of casing).
|
|
|
|
|
2020-11-25 09:18:38 +08:00
|
|
|
.. option:: StructIgnoredRegexp
|
|
|
|
|
|
|
|
Identifier naming checks won't be enforced for struct names
|
|
|
|
matching this regular expression.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
.. option:: StructSuffix
|
|
|
|
|
|
|
|
When defined, the check will ensure struct names will add the
|
|
|
|
suffix with the given value (regardless of casing).
|
|
|
|
|
|
|
|
For example using values of:
|
|
|
|
|
|
|
|
- StructCase of ``lower_case``
|
|
|
|
- StructPrefix of ``pre_``
|
|
|
|
- StructSuffix of ``_post``
|
|
|
|
|
|
|
|
Identifies and/or transforms struct names as follows:
|
|
|
|
|
|
|
|
Before:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
struct FOO {
|
|
|
|
FOO();
|
|
|
|
~FOO();
|
|
|
|
};
|
|
|
|
|
|
|
|
After:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
struct pre_foo_post {
|
|
|
|
pre_foo_post();
|
|
|
|
~pre_foo_post();
|
|
|
|
};
|
|
|
|
|
|
|
|
.. option:: TemplateParameterCase
|
|
|
|
|
|
|
|
When defined, the check will ensure template parameter names conform to the
|
|
|
|
selected casing.
|
|
|
|
|
|
|
|
.. option:: TemplateParameterPrefix
|
|
|
|
|
|
|
|
When defined, the check will ensure template parameter names will add the
|
|
|
|
prefixed with the given value (regardless of casing).
|
|
|
|
|
2020-11-25 09:18:38 +08:00
|
|
|
.. option:: TemplateParameterIgnoredRegexp
|
|
|
|
|
|
|
|
Identifier naming checks won't be enforced for template parameter names
|
|
|
|
matching this regular expression.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
.. option:: TemplateParameterSuffix
|
|
|
|
|
|
|
|
When defined, the check will ensure template parameter names will add the
|
|
|
|
suffix with the given value (regardless of casing).
|
|
|
|
|
|
|
|
For example using values of:
|
|
|
|
|
|
|
|
- TemplateParameterCase of ``lower_case``
|
|
|
|
- TemplateParameterPrefix of ``pre_``
|
|
|
|
- TemplateParameterSuffix of ``_post``
|
|
|
|
|
|
|
|
Identifies and/or transforms template parameter names as follows:
|
|
|
|
|
|
|
|
Before:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
template <typename T> class Foo {};
|
|
|
|
|
|
|
|
After:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
template <typename pre_t_post> class Foo {};
|
|
|
|
|
|
|
|
.. option:: TemplateTemplateParameterCase
|
|
|
|
|
|
|
|
When defined, the check will ensure template template parameter names conform to the
|
|
|
|
selected casing.
|
|
|
|
|
|
|
|
.. option:: TemplateTemplateParameterPrefix
|
|
|
|
|
|
|
|
When defined, the check will ensure template template parameter names will add the
|
|
|
|
prefixed with the given value (regardless of casing).
|
|
|
|
|
2020-11-25 09:18:38 +08:00
|
|
|
.. option:: TemplateTemplateParameterIgnoredRegexp
|
|
|
|
|
|
|
|
Identifier naming checks won't be enforced for template template parameter
|
|
|
|
names matching this regular expression.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
.. option:: TemplateTemplateParameterSuffix
|
|
|
|
|
|
|
|
When defined, the check will ensure template template parameter names will add the
|
|
|
|
suffix with the given value (regardless of casing).
|
|
|
|
|
|
|
|
For example using values of:
|
|
|
|
|
|
|
|
- TemplateTemplateParameterCase of ``lower_case``
|
|
|
|
- TemplateTemplateParameterPrefix of ``pre_``
|
|
|
|
- TemplateTemplateParameterSuffix of ``_post``
|
|
|
|
|
|
|
|
Identifies and/or transforms template template parameter names as follows:
|
|
|
|
|
|
|
|
Before:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
template <template <typename> class TPL_parameter, int COUNT_params,
|
|
|
|
typename... TYPE_parameters>
|
|
|
|
|
|
|
|
After:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
template <template <typename> class pre_tpl_parameter_post, int COUNT_params,
|
|
|
|
typename... TYPE_parameters>
|
|
|
|
|
|
|
|
.. option:: TypeAliasCase
|
|
|
|
|
|
|
|
When defined, the check will ensure type alias names conform to the
|
|
|
|
selected casing.
|
|
|
|
|
|
|
|
.. option:: TypeAliasPrefix
|
|
|
|
|
|
|
|
When defined, the check will ensure type alias names will add the
|
|
|
|
prefixed with the given value (regardless of casing).
|
|
|
|
|
2020-11-25 09:18:38 +08:00
|
|
|
.. option:: TypeAliasIgnoredRegexp
|
|
|
|
|
|
|
|
Identifier naming checks won't be enforced for type alias names
|
|
|
|
matching this regular expression.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
.. option:: TypeAliasSuffix
|
|
|
|
|
|
|
|
When defined, the check will ensure type alias names will add the
|
|
|
|
suffix with the given value (regardless of casing).
|
|
|
|
|
|
|
|
For example using values of:
|
|
|
|
|
|
|
|
- TypeAliasCase of ``lower_case``
|
|
|
|
- TypeAliasPrefix of ``pre_``
|
|
|
|
- TypeAliasSuffix of ``_post``
|
|
|
|
|
|
|
|
Identifies and/or transforms type alias names as follows:
|
|
|
|
|
|
|
|
Before:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
using MY_STRUCT_TYPE = my_structure;
|
|
|
|
|
|
|
|
After:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
using pre_my_struct_type_post = my_structure;
|
|
|
|
|
|
|
|
.. option:: TypedefCase
|
|
|
|
|
|
|
|
When defined, the check will ensure typedef names conform to the
|
|
|
|
selected casing.
|
|
|
|
|
|
|
|
.. option:: TypedefPrefix
|
|
|
|
|
|
|
|
When defined, the check will ensure typedef names will add the
|
|
|
|
prefixed with the given value (regardless of casing).
|
|
|
|
|
2020-11-25 09:18:38 +08:00
|
|
|
.. option:: TypedefIgnoredRegexp
|
|
|
|
|
|
|
|
Identifier naming checks won't be enforced for typedef names
|
|
|
|
matching this regular expression.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
.. option:: TypedefSuffix
|
|
|
|
|
|
|
|
When defined, the check will ensure typedef names will add the
|
|
|
|
suffix with the given value (regardless of casing).
|
|
|
|
|
|
|
|
For example using values of:
|
|
|
|
|
|
|
|
- TypedefCase of ``lower_case``
|
|
|
|
- TypedefPrefix of ``pre_``
|
|
|
|
- TypedefSuffix of ``_post``
|
|
|
|
|
|
|
|
Identifies and/or transforms typedef names as follows:
|
|
|
|
|
|
|
|
Before:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
typedef int MYINT;
|
|
|
|
|
|
|
|
After:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
typedef int pre_myint_post;
|
|
|
|
|
|
|
|
.. option:: TypeTemplateParameterCase
|
|
|
|
|
|
|
|
When defined, the check will ensure type template parameter names conform to the
|
|
|
|
selected casing.
|
|
|
|
|
|
|
|
.. option:: TypeTemplateParameterPrefix
|
|
|
|
|
|
|
|
When defined, the check will ensure type template parameter names will add the
|
|
|
|
prefixed with the given value (regardless of casing).
|
|
|
|
|
2020-11-25 09:18:38 +08:00
|
|
|
.. option:: TypeTemplateParameterIgnoredRegexp
|
|
|
|
|
|
|
|
Identifier naming checks won't be enforced for type template names
|
|
|
|
matching this regular expression.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
.. option:: TypeTemplateParameterSuffix
|
|
|
|
|
|
|
|
When defined, the check will ensure type template parameter names will add the
|
|
|
|
suffix with the given value (regardless of casing).
|
|
|
|
|
|
|
|
For example using values of:
|
|
|
|
|
|
|
|
- TypeTemplateParameterCase of ``lower_case``
|
|
|
|
- TypeTemplateParameterPrefix of ``pre_``
|
|
|
|
- TypeTemplateParameterSuffix of ``_post``
|
|
|
|
|
|
|
|
Identifies and/or transforms type template parameter names as follows:
|
|
|
|
|
|
|
|
Before:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
template <template <typename> class TPL_parameter, int COUNT_params,
|
|
|
|
typename... TYPE_parameters>
|
|
|
|
|
|
|
|
After:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
template <template <typename> class TPL_parameter, int COUNT_params,
|
|
|
|
typename... pre_type_parameters_post>
|
|
|
|
|
|
|
|
.. option:: UnionCase
|
|
|
|
|
|
|
|
When defined, the check will ensure union names conform to the
|
|
|
|
selected casing.
|
|
|
|
|
|
|
|
.. option:: UnionPrefix
|
|
|
|
|
|
|
|
When defined, the check will ensure union names will add the
|
|
|
|
prefixed with the given value (regardless of casing).
|
|
|
|
|
2020-11-25 09:18:38 +08:00
|
|
|
.. option:: UnionIgnoredRegexp
|
|
|
|
|
|
|
|
Identifier naming checks won't be enforced for union names
|
|
|
|
matching this regular expression.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
.. option:: UnionSuffix
|
|
|
|
|
|
|
|
When defined, the check will ensure union names will add the
|
|
|
|
suffix with the given value (regardless of casing).
|
|
|
|
|
|
|
|
For example using values of:
|
|
|
|
|
|
|
|
- UnionCase of ``lower_case``
|
|
|
|
- UnionPrefix of ``pre_``
|
|
|
|
- UnionSuffix of ``_post``
|
|
|
|
|
|
|
|
Identifies and/or transforms union names as follows:
|
|
|
|
|
|
|
|
Before:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
union FOO {
|
|
|
|
int a;
|
|
|
|
char b;
|
|
|
|
};
|
|
|
|
|
|
|
|
After:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
union pre_foo_post {
|
|
|
|
int a;
|
|
|
|
char b;
|
|
|
|
};
|
|
|
|
|
|
|
|
.. option:: ValueTemplateParameterCase
|
|
|
|
|
|
|
|
When defined, the check will ensure value template parameter names conform to the
|
|
|
|
selected casing.
|
|
|
|
|
|
|
|
.. option:: ValueTemplateParameterPrefix
|
|
|
|
|
|
|
|
When defined, the check will ensure value template parameter names will add the
|
|
|
|
prefixed with the given value (regardless of casing).
|
|
|
|
|
2020-11-25 09:18:38 +08:00
|
|
|
.. option:: ValueTemplateParameterIgnoredRegexp
|
|
|
|
|
|
|
|
Identifier naming checks won't be enforced for value template parameter
|
|
|
|
names matching this regular expression.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
.. option:: ValueTemplateParameterSuffix
|
|
|
|
|
|
|
|
When defined, the check will ensure value template parameter names will add the
|
|
|
|
suffix with the given value (regardless of casing).
|
|
|
|
|
|
|
|
For example using values of:
|
|
|
|
|
|
|
|
- ValueTemplateParameterCase of ``lower_case``
|
|
|
|
- ValueTemplateParameterPrefix of ``pre_``
|
|
|
|
- ValueTemplateParameterSuffix of ``_post``
|
|
|
|
|
|
|
|
Identifies and/or transforms value template parameter names as follows:
|
|
|
|
|
|
|
|
Before:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
template <template <typename> class TPL_parameter, int COUNT_params,
|
|
|
|
typename... TYPE_parameters>
|
|
|
|
|
|
|
|
After:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
template <template <typename> class TPL_parameter, int pre_count_params_post,
|
|
|
|
typename... TYPE_parameters>
|
|
|
|
|
|
|
|
.. option:: VariableCase
|
|
|
|
|
|
|
|
When defined, the check will ensure variable names conform to the
|
|
|
|
selected casing.
|
|
|
|
|
|
|
|
.. option:: VariablePrefix
|
|
|
|
|
|
|
|
When defined, the check will ensure variable names will add the
|
|
|
|
prefixed with the given value (regardless of casing).
|
|
|
|
|
2020-11-25 09:18:38 +08:00
|
|
|
.. option:: VariableIgnoredRegexp
|
|
|
|
|
|
|
|
Identifier naming checks won't be enforced for variable names
|
|
|
|
matching this regular expression.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
.. option:: VariableSuffix
|
|
|
|
|
|
|
|
When defined, the check will ensure variable names will add the
|
|
|
|
suffix with the given value (regardless of casing).
|
|
|
|
|
2021-08-02 06:20:12 +08:00
|
|
|
.. option:: VariableHungarianPrefix
|
|
|
|
|
|
|
|
When enabled, the check ensures that the declared identifier will
|
|
|
|
have a Hungarian notation prefix based on the declared type.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
For example using values of:
|
|
|
|
|
|
|
|
- VariableCase of ``lower_case``
|
|
|
|
- VariablePrefix of ``pre_``
|
|
|
|
- VariableSuffix of ``_post``
|
2021-08-02 06:20:12 +08:00
|
|
|
- VariableHungarianPrefix of ``On``
|
2019-01-16 06:06:49 +08:00
|
|
|
|
|
|
|
Identifies and/or transforms variable names as follows:
|
|
|
|
|
|
|
|
Before:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
unsigned MyVariable;
|
|
|
|
|
|
|
|
After:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
unsigned pre_myvariable_post;
|
|
|
|
|
|
|
|
.. option:: VirtualMethodCase
|
|
|
|
|
|
|
|
When defined, the check will ensure virtual method names conform to the
|
|
|
|
selected casing.
|
|
|
|
|
|
|
|
.. option:: VirtualMethodPrefix
|
|
|
|
|
|
|
|
When defined, the check will ensure virtual method names will add the
|
|
|
|
prefixed with the given value (regardless of casing).
|
|
|
|
|
2020-11-25 09:18:38 +08:00
|
|
|
.. option:: VirtualMethodIgnoredRegexp
|
|
|
|
|
|
|
|
Identifier naming checks won't be enforced for virtual method names
|
|
|
|
matching this regular expression.
|
|
|
|
|
2019-01-16 06:06:49 +08:00
|
|
|
.. option:: VirtualMethodSuffix
|
|
|
|
|
|
|
|
When defined, the check will ensure virtual method names will add the
|
|
|
|
suffix with the given value (regardless of casing).
|
|
|
|
|
|
|
|
For example using values of:
|
|
|
|
|
|
|
|
- VirtualMethodCase of ``lower_case``
|
|
|
|
- VirtualMethodPrefix of ``pre_``
|
|
|
|
- VirtualMethodSuffix of ``_post``
|
|
|
|
|
|
|
|
Identifies and/or transforms virtual method names as follows:
|
|
|
|
|
|
|
|
Before:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
class Foo {
|
|
|
|
public:
|
|
|
|
virtual int MemberFunction();
|
|
|
|
}
|
|
|
|
|
|
|
|
After:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
class Foo {
|
|
|
|
public:
|
|
|
|
virtual int pre_member_function_post();
|
|
|
|
}
|
2021-08-02 06:20:12 +08:00
|
|
|
|
|
|
|
|
|
|
|
The default mapping table of Hungarian Notation
|
|
|
|
-----------------------------------------------
|
|
|
|
|
|
|
|
In Hungarian notation, a variable name starts with a group of lower-case
|
|
|
|
letters which are mnemonics for the type or purpose of that variable, followed
|
|
|
|
by whatever name the programmer has chosen; this last part is sometimes
|
|
|
|
distinguished as the given name. The first character of the given name can be
|
|
|
|
capitalized to separate it from the type indicators (see also CamelCase).
|
|
|
|
Otherwise the case of this character denotes scope.
|
|
|
|
|
|
|
|
The following table is the default mapping table of Hungarian Notation which
|
|
|
|
maps Decl to its prefix string. You can also have your own style in config file.
|
|
|
|
|
|
|
|
================= ============== ====================== ============== =========== ==============
|
|
|
|
Primitive Types Microsoft data types
|
|
|
|
---------------------------------------------------------------------- --------------------------
|
|
|
|
Type Prefix Type Prefix Type Prefix
|
|
|
|
================= ============== ====================== ============== =========== ==============
|
|
|
|
int8_t i8 signed int si BOOL b
|
|
|
|
int16_t i16 signed short ss BOOLEAN b
|
|
|
|
int32_t i32 signed short int ssi BYTE by
|
|
|
|
int64_t i64 signed long long int slli CHAR c
|
|
|
|
uint8_t u8 signed long long sll UCHAR uc
|
|
|
|
uint16_t u16 signed long int sli SHORT s
|
|
|
|
uint32_t u32 signed long sl USHORT us
|
|
|
|
uint64_t u64 signed s WORD w
|
|
|
|
char8_t c8 unsigned long long int ulli DWORD dw
|
|
|
|
char16_t c16 unsigned long long ull DWORD32 dw32
|
|
|
|
char32_t c32 unsigned long int uli DWORD64 dw64
|
|
|
|
float f unsigned long ul LONG l
|
|
|
|
double d unsigned short int usi ULONG ul
|
|
|
|
char c unsigned short us ULONG32 ul32
|
|
|
|
bool b unsigned int ui ULONG64 ul64
|
|
|
|
_Bool b unsigned u ULONGLONG ull
|
|
|
|
int i long long int lli HANDLE h
|
|
|
|
size_t n long double ld INT i
|
|
|
|
short s long long ll INT8 i8
|
|
|
|
signed i long int li INT16 i16
|
|
|
|
unsigned u long l INT32 i32
|
|
|
|
long l ptrdiff_t p INT64 i64
|
|
|
|
long long ll UINT ui
|
|
|
|
unsigned long ul UINT8 u8
|
|
|
|
long double ld UINT16 u16
|
|
|
|
ptrdiff_t p UINT32 u32
|
|
|
|
wchar_t wc UINT64 u64
|
|
|
|
short int si PVOID p
|
|
|
|
short s
|
|
|
|
================= ============== ====================== ============== =========== ==============
|
|
|
|
|
|
|
|
**There are more trivial options for Hungarian Notation:**
|
|
|
|
|
|
|
|
**HungarianNotation.General.***
|
|
|
|
Options are not belonging to any specific Decl.
|
|
|
|
|
|
|
|
**HungarianNotation.CString.***
|
|
|
|
Options for NULL-terminated string.
|
|
|
|
|
|
|
|
**HungarianNotation.DerivedType.***
|
|
|
|
Options for derived types.
|
|
|
|
|
|
|
|
**HungarianNotation.PrimitiveType.***
|
|
|
|
Options for primitive types.
|
|
|
|
|
|
|
|
**HungarianNotation.UserDefinedType.***
|
|
|
|
Options for user-defined types.
|
|
|
|
|
|
|
|
|
|
|
|
Options for Hungarian Notation
|
|
|
|
------------------------------
|
|
|
|
|
|
|
|
- :option:`HungarianNotation.General.TreatStructAsClass`
|
|
|
|
|
|
|
|
- :option:`HungarianNotation.DerivedType.Array`
|
|
|
|
- :option:`HungarianNotation.DerivedType.Pointer`
|
|
|
|
- :option:`HungarianNotation.DerivedType.FunctionPointer`
|
|
|
|
|
|
|
|
- :option:`HungarianNotation.CString.CharPrinter`
|
|
|
|
- :option:`HungarianNotation.CString.CharArray`
|
|
|
|
- :option:`HungarianNotation.CString.WideCharPrinter`
|
|
|
|
- :option:`HungarianNotation.CString.WideCharArray`
|
|
|
|
|
|
|
|
- :option:`HungarianNotation.PrimitiveType.*`
|
|
|
|
- :option:`HungarianNotation.UserDefinedType.*`
|
|
|
|
|
|
|
|
.. option:: HungarianNotation.General.TreatStructAsClass
|
|
|
|
|
|
|
|
When defined, the check will treat naming of struct as a class.
|
|
|
|
The default value is `false`.
|
|
|
|
|
|
|
|
.. option:: HungarianNotation.DerivedType.Array
|
|
|
|
|
|
|
|
When defined, the check will ensure variable name will add the prefix with
|
|
|
|
the given string. The default prefix is `a`.
|
|
|
|
|
|
|
|
.. option:: HungarianNotation.DerivedType.Pointer
|
|
|
|
|
|
|
|
When defined, the check will ensure variable name will add the prefix with
|
|
|
|
the given string. The default prefix is `p`.
|
|
|
|
|
|
|
|
.. option:: HungarianNotation.DerivedType.FunctionPointer
|
|
|
|
|
|
|
|
When defined, the check will ensure variable name will add the prefix with
|
|
|
|
the given string. The default prefix is `fn`.
|
|
|
|
|
|
|
|
|
|
|
|
Before:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
// Array
|
|
|
|
int DataArray[2] = {0};
|
|
|
|
|
|
|
|
// Pointer
|
|
|
|
void *DataBuffer = NULL;
|
|
|
|
|
|
|
|
// FunctionPointer
|
|
|
|
typedef void (*FUNC_PTR)();
|
|
|
|
FUNC_PTR FuncPtr = NULL;
|
|
|
|
|
|
|
|
After:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
// Array
|
|
|
|
int aDataArray[2] = {0};
|
|
|
|
|
|
|
|
// Pointer
|
|
|
|
void *pDataBuffer = NULL;
|
|
|
|
|
|
|
|
// FunctionPointer
|
|
|
|
typedef void (*FUNC_PTR)();
|
|
|
|
FUNC_PTR fnFuncPtr = NULL;
|
|
|
|
|
|
|
|
|
|
|
|
.. option:: HungarianNotation.CString.CharPrinter
|
|
|
|
|
|
|
|
When defined, the check will ensure variable name will add the prefix with
|
|
|
|
the given string. The default prefix is `sz`.
|
|
|
|
|
|
|
|
.. option:: HungarianNotation.CString.CharArray
|
|
|
|
|
|
|
|
When defined, the check will ensure variable name will add the prefix with
|
|
|
|
the given string. The default prefix is `sz`.
|
|
|
|
|
|
|
|
.. option:: HungarianNotation.CString.WideCharPrinter
|
|
|
|
|
|
|
|
When defined, the check will ensure variable name will add the prefix with
|
|
|
|
the given string. The default prefix is `wsz`.
|
|
|
|
|
|
|
|
.. option:: HungarianNotation.CString.WideCharArray
|
|
|
|
|
|
|
|
When defined, the check will ensure variable name will add the prefix with
|
|
|
|
the given string. The default prefix is `wsz`.
|
|
|
|
|
|
|
|
|
|
|
|
Before:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
// CharPrinter
|
|
|
|
const char *NamePtr = "Name";
|
|
|
|
|
|
|
|
// CharArray
|
|
|
|
const char NameArray[] = "Name";
|
|
|
|
|
|
|
|
// WideCharPrinter
|
|
|
|
const wchar_t *WideNamePtr = L"Name";
|
|
|
|
|
|
|
|
// WideCharArray
|
|
|
|
const wchar_t WideNameArray[] = L"Name";
|
|
|
|
|
|
|
|
After:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
// CharPrinter
|
|
|
|
const char *szNamePtr = "Name";
|
|
|
|
|
|
|
|
// CharArray
|
|
|
|
const char szNameArray[] = "Name";
|
|
|
|
|
|
|
|
// WideCharPrinter
|
|
|
|
const wchar_t *wszWideNamePtr = L"Name";
|
|
|
|
|
|
|
|
// WideCharArray
|
|
|
|
const wchar_t wszWideNameArray[] = L"Name";
|
|
|
|
|
|
|
|
|
|
|
|
.. option:: HungarianNotation.PrimitiveType.*
|
|
|
|
|
|
|
|
When defined, the check will ensure variable name of involved primitive
|
|
|
|
types will add the prefix with the given string. The default prefixes are
|
|
|
|
defined in the default mapping table.
|
|
|
|
|
|
|
|
.. option:: HungarianNotation.UserDefinedType.*
|
|
|
|
|
|
|
|
When defined, the check will ensure variable name of involved primitive
|
|
|
|
types will add the prefix with the given string. The default prefixes are
|
|
|
|
defined in the default mapping table.
|
|
|
|
|
|
|
|
|
|
|
|
Before:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
int8_t ValueI8 = 0;
|
|
|
|
int16_t ValueI16 = 0;
|
|
|
|
int32_t ValueI32 = 0;
|
|
|
|
int64_t ValueI64 = 0;
|
|
|
|
uint8_t ValueU8 = 0;
|
|
|
|
uint16_t ValueU16 = 0;
|
|
|
|
uint32_t ValueU32 = 0;
|
|
|
|
uint64_t ValueU64 = 0;
|
|
|
|
float ValueFloat = 0.0;
|
|
|
|
double ValueDouble = 0.0;
|
|
|
|
ULONG ValueUlong = 0;
|
|
|
|
DWORD ValueDword = 0;
|
|
|
|
|
|
|
|
After:
|
|
|
|
|
|
|
|
.. code-block:: c++
|
|
|
|
|
|
|
|
int8_t i8ValueI8 = 0;
|
|
|
|
int16_t i16ValueI16 = 0;
|
|
|
|
int32_t i32ValueI32 = 0;
|
|
|
|
int64_t i64ValueI64 = 0;
|
|
|
|
uint8_t u8ValueU8 = 0;
|
|
|
|
uint16_t u16ValueU16 = 0;
|
|
|
|
uint32_t u32ValueU32 = 0;
|
|
|
|
uint64_t u64ValueU64 = 0;
|
|
|
|
float fValueFloat = 0.0;
|
|
|
|
double dValueDouble = 0.0;
|
|
|
|
ULONG ulValueUlong = 0;
|
|
|
|
DWORD dwValueDword = 0;
|