What does Coverity/clang static analysis actually do?

Lutger lutger.blijdestijn at gmail.com
Thu Oct 1 14:44:12 PDT 2009


Walter Bright wrote:

> Nick Sabalausky wrote:
>> "Walter Bright" <newshound1 at digitalmars.com> wrote in message
>>> 2. possible dereference of NULL pointers (some reaching definitions of a
>>> pointer are NULL)
>>> 2. Optimizer collects the info, but ignores this, because people are
>>> annoyed by false positives.
>>>
>> 
>> If you mean something like this:
>> 
>> Foo f;
>> if(cond)
>>     f = new Foo();
>> f.bar();
>> 
>> Then I *want* the compiler to tell me. C# does this and I've never been
>> annoyed by it, in fact I've always appreciated it. I'm not aware of any
>> other C# user that has a problem with that either. If that's not what you
>> mean though, then could you elaborate?
> 
> The problem crops up when there are two connected variables:
> 
>    void foo(bool flag)
>    {
>      char* p = null;
>      if (flag)
> p = "hello";
>      ...
>      if (flag)
> bar(*p);
>    }
> 
> The code is logically correct, there is no null pointer dereference
> possible. However, the data flow analysis will see the *p and see two
> reaching definitions for p: null and "hello", even though only one
> actually reaches.
> 
> Hence the false positive. To eliminate the false error report, the user
> would have to insert a redundant null check.
> 
> Does this happen in practice? Yes.

How hard is this to implement? I ask this because I would suggest to try it 
out and see how much it catches vs. how annoying it is. In VB.NET I have 
quite some false positives, but in C# less. It's all about how it fits with 
the rest of the language. VB.NET doesn't have a ternary operator for 
example. In D you have less need for pointers and generally a much more 
expressive vocabulary at your disposal than other C family languages. 





More information about the Digitalmars-d mailing list