On Sun, Feb 28, 2021 at 8:57 AM Alexey Dobriyan <adobriyan@xxxxxxxxx> wrote: > > This is bulk deletion of preprocessor include guards and conversion > to #pragma once directive. So as mentioned earlier, I'm not 100% convinced about the advantage of #pragma once. But I decided to actually test it, and it turns out that it causes problems for at least sparse. Sparse *does* support pragma once, but it does it purely based on pathname equality. So a simple test-program like this: File 'pragma.h': #pragma once #include "header.h" works fine. But this doesn't work at all: #pragma once #include "./header.h" because it causes the filename to be different every time, and you eventually end up with trying to open "././....../pragma.h" and it causes ENAMETOOLONG. So at least sparse isn't ready for this. I guess sparse could always simplify the name, but that's non-trivial. And honestly, using st_dev/st_ino is problematic too, since (a) they can easily be re-used for generated files (b) you'd have to actually open/fstat the filename to use it, which obviates one of the optimizations Trying the same on gcc, you don't get that endless "add "./" behavior" that sparse did, but a quick test shows that it actually opens the file and reads it three times: once for "pramga.h", once for "./pragma.h" and a third time for "pragma.h". It only seems to _expand_ it once, though. I have no idea what gcc does. Maybe it does some "different name, so let's open and read it, and then does st_dev/st_ino again". But if so, why the _third_ time? Is it some guard against "st_ino might have been re-used, so I'll open the original name and re-verify"? End result: #pragma is fundamentally less reliable than the traditional #ifdef guard. The #ifdef guard works fine even if you re-read the file for whatever reason, while #pragma relies on some kind of magical behavior. I'm adding Luc in case he has any ideas of what the magical behavior might be. Honestly, I think #pragma once is complete garbage. It's really is fundamenetally more complicated than the #ifdef guard, and it has absolutely zero upsides. I'm not taking this pramga series unless somebody can explain why it's a good thing. Because all I see are downsides. Linus