===================================== Extra Clang Tools 6.0.0 Release Notes ===================================== .. contents:: :local: :depth: 3 Written by the `LLVM Team `_ Introduction ============ This document contains the release notes for the Extra Clang Tools, part of the Clang release 6.0.0. Here we describe the status of the Extra Clang Tools in some detail, including major improvements from the previous release and new feature work. All LLVM releases may be downloaded from the `LLVM releases web site `_. For more information about Clang or LLVM, including information about the latest release, please see the `Clang Web Site `_ or the `LLVM Web Site `_. What's New in Extra Clang Tools 6.0.0? ====================================== Some of the major new features and improvements to Extra Clang Tools are listed here. Generic improvements to Extra Clang Tools as a whole or to its underlying infrastructure are described first, followed by tool-specific sections. Improvements to clang-tidy -------------------------- - New module `fuchsia` for Fuchsia style checks. - New module `objc` for Objective-C style checks. - New `android-cloexec-accept `_ check Detects usage of ``accept()``. - New `android-cloexec-accept4 `_ check Checks if the required file flag ``SOCK_CLOEXEC`` is present in the argument of ``accept4()``. - New `android-cloexec-dup `_ check Detects usage of ``dup()``. - New `android-cloexec-epoll-create `_ check Detects usage of ``epoll_create()``. - New `android-cloexec-epoll-create1 `_ check Checks if the required file flag ``EPOLL_CLOEXEC`` is present in the argument of ``epoll_create1()``. - New `android-cloexec-inotify-init `_ check Detects usage of ``inotify_init()``. - New `android-cloexec-inotify-init1 `_ check Checks if the required file flag ``IN_CLOEXEC`` is present in the argument of ``inotify_init1()``. - New `android-cloexec-memfd_create `_ check Checks if the required file flag ``MFD_CLOEXEC`` is present in the argument of ``memfd_create()``. - New `bugprone-copy-constructor-init `_ check Finds copy constructors which don't call the copy constructor of the base class. - New `bugprone-integer-division `_ check Finds cases where integer division in a floating point context is likely to cause unintended loss of precision. - New `bugprone-misplaced-operator-in-strlen-in-alloc `_ check Finds cases where ``1`` is added to the string in the argument to ``strlen()``, ``strnlen()``, ``strnlen_s()``, ``wcslen()``, ``wcsnlen()``, and ``wcsnlen_s()`` instead of the result and the value is used as an argument to a memory allocation function (``malloc()``, ``calloc()``, ``realloc()``, ``alloca()``) or the ``new[]`` operator in `C++`. - New `cppcoreguidelines-owning-memory `_ check This check implements the type-based semantic of ``gsl::owner``, but without flow analysis. - New `fuchsia-default-arguments `_ check Warns if a function or method is declared or called with default arguments. - New `fuchsia-overloaded-operator `_ check Warns if an operator is overloaded, except for the assignment (copy and move) operators. - New `fuchsia-virtual-inheritance `_ check Warns if classes are defined with virtual inheritance. - New `google-objc-avoid-throwing-exception `_ check Finds uses of throwing exceptions usages in Objective-C files. - New `google-objc-global-variable-declaration `_ check Finds global variable declarations in Objective-C files that do not follow the pattern of variable names in Google's Objective-C Style Guide. - New `hicpp-exception-baseclass `_ check Ensures that all exception will be instances of ``std::exception`` and classes that are derived from it. - New `hicpp-signed-bitwise `_ check Finds uses of bitwise operations on signed integer types, which may lead to undefined or implementation defined behaviour. - New `objc-avoid-nserror-init `_ check Finds improper initialization of ``NSError`` objects. - New `objc-avoid-spinlock `_ check Finds usages of ``OSSpinlock``, which is deprecated due to potential livelock problems. - New `objc-forbidden-subclassing `_ check Finds Objective-C classes which are subclasses of classes which are not designed to be subclassed. - New `objc-property-declaration `_ check Finds property declarations in Objective-C files that do not follow the pattern of property names in Apple's programming guide. - New `readability-static-accessed-through-instance `_ check Finds member expressions that access static members through instances and replaces them with uses of the appropriate qualified-id. - The 'misc-argument-comment' check was renamed to `bugprone-argument-comment `_ - The 'misc-assert-side-effect' check was renamed to `bugprone-assert-side-effect `_ - The 'misc-bool-pointer-implicit-conversion' check was renamed to `bugprone-bool-pointer-implicit-conversion `_ - The 'misc-dangling-handle' check was renamed to `bugprone-dangling-handle `_ - The 'misc-fold-init-type' check was renamed to `bugprone-fold-init-type `_ - The 'misc-forward-declaration-namespace' check was renamed to `bugprone-forward-declaration-namespace `_ - The 'misc-inaccurate-erase' check was renamed to `bugprone-inaccurate-erase `_ - The 'misc-inefficient-algorithm' check was renamed to `performance-inefficient-algorithm `_ - The 'misc-move-const-arg' check was renamed to `performance-move-const-arg `_ - The 'misc-move-constructor-init' check was renamed to `performance-move-constructor-init `_ - The 'misc-move-forwarding-reference' check was renamed to `bugprone-move-forwarding-reference `_ - The 'misc-multiple-statement-macro' check was renamed to `bugprone-multiple-statement-macro `_ - The 'misc-noexcept-move-constructor' check was renamed to `performance-noexcept-move-constructor `_ - The 'misc-string-constructor' check was renamed to `bugprone-string-constructor `_ - The 'misc-use-after-move' check was renamed to `bugprone-use-after-move `_ - The 'performance-implicit-cast-in-loop' check was renamed to `performance-implicit-conversion-in-loop `_ - The 'readability-implicit-bool-cast' check was renamed to `readability-implicit-bool-conversion `_ The check's options were renamed as follows: - `AllowConditionalIntegerCasts` -> `AllowIntegerConditions`, - `AllowConditionalPointerCasts` -> `AllowPointerConditions`. - Added `modernize-use-emplace.IgnoreImplicitConstructors `_ option. - Added aliases for the `High Integrity C++ Coding Standard `_ to already implemented checks in other modules. - `hicpp-deprecated-headers `_ - `hicpp-move-const-arg `_ - `hicpp-no-array-decay `_ - `hicpp-no-malloc `_ - `hicpp-static-assert `_ - `hicpp-use-auto `_ - `hicpp-use-emplace `_ - `hicpp-use-noexcept `_ - `hicpp-use-nullptr `_ - `hicpp-vararg `_ - Added the ability to suppress specific checks (or all checks) in a ``NOLINT`` or ``NOLINTNEXTLINE`` comment. - Added new functionality to `misc-redundant-expression `_ check Finds redundant binary operator expressions where the operators are overloaded, and ones that contain the same macros twice. Also checks for assignment expressions that do not change the value of the assigned variable, and expressions that always evaluate to the same value because of possible operator confusion.