]> granicus.if.org Git - clang/commit
[Sema] -Wzero-as-null-pointer-constant: don't warn for system macros other than NULL.
authorRoman Lebedev <lebedev.ri@gmail.com>
Thu, 26 Oct 2017 13:18:14 +0000 (13:18 +0000)
committerRoman Lebedev <lebedev.ri@gmail.com>
Thu, 26 Oct 2017 13:18:14 +0000 (13:18 +0000)
commit5f17d5ca46b48156b96f81e7c32d381a0ca65b41
tree48e4daafadf6b5d89ba3ede2a1b2165234782d71
parent8084ad7fc6453b51a6422b6c73e41644910d7bd3
[Sema] -Wzero-as-null-pointer-constant: don't warn for system macros other than NULL.

Summary:
The warning was initially introduced in D32914 by @thakis,
and the concerns were raised there, and later in rL302247
and PR33771.

I do believe that it makes sense to relax the diagnostic
e.g. in this case, when the expression originates from the
system header, which can not be modified. This prevents
adoption for the diagnostic for codebases which use pthreads
(`PTHREAD_MUTEX_INITIALIZER`), gtest, etc.

As @malcolm.parsons suggests, it *may* make sense to also
not warn for the template types, but it is not obvious to
me how to do that in here.

Though, it still makes sense to complain about `NULL` macro.

While there, add more tests.

Reviewers: dblaikie, thakis, rsmith, rjmccall, aaron.ballman

Reviewed By: thakis

Subscribers: Rakete1111, hans, cfe-commits, thakis, malcolm.parsons

Tags: #clang

Differential Revision: https://reviews.llvm.org/D38954

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@316662 91177308-0d34-0410-b5e6-96231b3b80d8
docs/ReleaseNotes.rst
lib/Sema/Sema.cpp
test/SemaCXX/Inputs/warn-zero-nullptr.h [new file with mode: 0644]
test/SemaCXX/warn-zero-nullptr.cpp