llvm/clang-tools-extra/docs/clang-tidy/checks/readability/operators-representation.rst

.. 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.