On Wed, Mar 17, 2021 at 06:17:26PM +0100, Christophe Leroy wrote:
Le 17/03/2021 à 13:23, Peter Zijlstra a écrit :
On Wed, Mar 17, 2021 at 12:00:29PM +0100, Christophe Leroy wrote:
What do you mean ? 'extern' prototype is pointless for function prototypes
and deprecated, no new function prototypes should be added with the 'extern'
keyword.
checkpatch.pl tells you: "extern prototypes should be avoided in .h files"
I have a very strong preference for extern on function decls, to match
the extern on variable decl.
You mean you also do 'static inline' variable declarations ?
That's a func definition, not a declaration. And you _can_ do static
variable definitions in a header file just fine, although that's
typically not what you'd want. Although sometimes I've seen people do:
static const int my_var = 10;
inline is an attribute that obviously doesn't work on variables.
Using the extern keyword on function prototypes is superfluous visual
noise so suggest removing it.
I don't agree; and I think the C spec is actually wrong there (too).
The thing is that it distinguishes between a forward declaration of a
function in the same TU and an external declaration for a function in
another TU.
That is; if I see:
void ponies(int legs);
I expect that function to be defined later in the same TU. IOW it's a
forward declaration. OTOH if I see:
extern void ponies(int legs);
I know I won't find it in this TU and the linker will end up involved.
Now, the C people figured that distinction was useless and allowed
sloppiness. But I still think there's merrit to that. And as mentioned
earlier, it is consistent with variable declarations.