87 lines
2.6 KiB
ReStructuredText
87 lines
2.6 KiB
ReStructuredText
|
.. title:: clang-tidy - readability-operators-representation
|
||
|
|
||
|
readability-operators-representation
|
||
|
====================================
|
||
|
|
||
|
Enforces consistent token representation for invoked binary, unary and
|
||
|
overloaded operators in C++ code. The check supports both traditional and
|
||
|
alternative representations of operators, such as ``&&`` and ``and``, ``||``
|
||
|
and ``or``, and so on.
|
||
|
|
||
|
In the realm of C++ programming, developers have the option to choose between
|
||
|
two distinct representations for operators: traditional token representation
|
||
|
and alternative token representation. Traditional tokens utilize symbols,
|
||
|
such as ``&&``, ``||``, and ``!``, while alternative tokens employ more
|
||
|
descriptive words like ``and``, ``or``, and ``not``.
|
||
|
|
||
|
In the following mapping table, a comprehensive list of traditional and
|
||
|
alternative tokens, along with their corresponding representations,
|
||
|
is presented:
|
||
|
|
||
|
.. table:: Token Representation Mapping Table
|
||
|
:widths: auto
|
||
|
|
||
|
=========== ===========
|
||
|
Traditional Alternative
|
||
|
=========== ===========
|
||
|
``&&`` ``and``
|
||
|
``&=`` ``and_eq``
|
||
|
``&`` ``bitand``
|
||
|
``|`` ``bitor``
|
||
|
``~`` ``compl``
|
||
|
``!`` ``not``
|
||
|
``!=`` ``not_eq``
|
||
|
``||`` ``or``
|
||
|
``|=`` ``or_eq``
|
||
|
``^`` ``xor``
|
||
|
``^=`` ``xor_eq``
|
||
|
=========== ===========
|
||
|
|
||
|
Example
|
||
|
-------
|
||
|
|
||
|
.. code-block:: c++
|
||
|
|
||
|
// Traditional Token Representation:
|
||
|
|
||
|
if (!a||!b)
|
||
|
{
|
||
|
// do something
|
||
|
}
|
||
|
|
||
|
// Alternative Token Representation:
|
||
|
|
||
|
if (not a or not b)
|
||
|
{
|
||
|
// do something
|
||
|
}
|
||
|
|
||
|
Options
|
||
|
-------
|
||
|
|
||
|
Due to the distinct benefits and drawbacks of each representation, the default
|
||
|
configuration doesn't enforce either. Explicit configuration is needed.
|
||
|
|
||
|
To configure check to enforce Traditional Token Representation for all
|
||
|
operators set options to `&&;&=;&;|;~;!;!=;||;|=;^;^=`.
|
||
|
|
||
|
To configure check to enforce Alternative Token Representation for all
|
||
|
operators set options to
|
||
|
`and;and_eq;bitand;bitor;compl;not;not_eq;or;or_eq;xor;xor_eq`.
|
||
|
|
||
|
Developers do not need to enforce all operators, and can mix the representations
|
||
|
as desired by specifying a semicolon-separated list of both traditional and
|
||
|
alternative tokens in the configuration, such as `and;||;not`.
|
||
|
|
||
|
.. option:: BinaryOperators
|
||
|
|
||
|
This option allows you to specify a semicolon-separated list of binary
|
||
|
operators for which you want to enforce specific token representation.
|
||
|
The default value is empty string.
|
||
|
|
||
|
.. option:: OverloadedOperators
|
||
|
|
||
|
This option allows you to specify a semicolon-separated list of overloaded
|
||
|
operators for which you want to enforce specific token representation.
|
||
|
The default value is empty string.
|