MosheBerman added a comment.

In D123352#3458530 <https://reviews.llvm.org/D123352#3458530>, @steakhal wrote:

> In D123352#3439649 <https://reviews.llvm.org/D123352#3439649>, @MosheBerman 
> wrote:
>
>> In D123352#3439390 <https://reviews.llvm.org/D123352#3439390>, @steakhal 
>> wrote:
>>
>>> tldr; static-analyzer fixits are not completely implemented.
>>
>> Where can I learn more about this?
>
> Grep through the code and look for references to the variable. It's not used 
> widely.
> In fact, there are no checkers facilitating fixits.

There's a DeadStore checker that does have some fixit code, which is where I 
found the `FixItHint` class. I did notice it isn't used in too many other 
places.

>> Would it be possible and idiomatically/architecturally sounds to write a 
>> clang-tidy that processes output from this checker?
>
> I don't believe that `clang-tidy` should be involved in this. It would be 
> better to keep it in-house (in the analyzer).
>
>>> When I passed the `apply-fixits`, it modified the input source file - as I 
>>> expected.
>>
>> Did you test this diff, or an existing checker? Would you please share the 
>> command you used to test?
>
> Sort of. I tried to apply some parts of it by hand, and check the output 
> difference in my command.
>
> I cannot immediately recall, but I cannot remember any major obstacles, which 
> suggests that I had to set the `apply-fixits=true` analyzer config option and 
> that's it.
> Since there were no checkers emitting fixit hints, I modified an existing one 
> to emit a dummy fixithint. Nothing fancy there.
>
>>> Then I tried the `-analyzer-output=text` and suddenly it inserted the fixit 
>>> 2 times xD, which is less than ideal and we should fix this.
>>> And I'm expecting many more bugs with this feature.
>>
>> This is why it's gated. xD.
>
> What do you mean by 'gated'? It seems to be a bug, which we should fix prior 
> to this.

The `-analyzer-output=text` comes from a frontend. (I misplaced the source 
right now, but I did see it recently on the LLVM github.) The reasons I'm not 
too concerned are:

1. It looks like a pre-existing behavior. (The text frontend consumer appeared 
to be printing fixits independently of whatever other diagnostic flags)
2. When I say gated, I mean that the default behavior of the checker hasn't 
changed. These fixits are opt-in. If you're opting in, you can also choose to 
not use the text output.

> PS: I'm also inviting @whisperity since he is more experienced with fixits 
> and that sort of stuff.

Thanks! More reviewers means I learn more and can be more accurate.


Repository:
  rG LLVM Github Monorepo

CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D123352/new/

https://reviews.llvm.org/D123352

_______________________________________________
cfe-commits mailing list
cfe-commits@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits

Reply via email to