How can adding a header increase portability? (sys/time.h)

1.1k views Asked by At

I just noticed this line in the getrusage man page:

Including <sys/time.h> is not required these days, but increases portability. (Indeed, struct timeval is defined in <sys/time.h>)

What? Since struct rusage contains struct timeval as a member, surely sys/resource.h must include sys/time.h or the type would be incomplete and unusable?

How could this comment ever have made sense? How could it ever have not been necessary? How could portability have ever been helped?

2

There are 2 answers

0
Random832 On BEST ANSWER

In general, it was not uncommon in the early days of C for you to have to manually include header file A before header file B. Maybe an early version of the preprocessor couldn't do nested includes, or maybe it was just stylistic (manpages would often directly include the header files for relevant structures).

"These days", sys/resource.h must either include sys/time.h or repeat the definition of struct timeval, but not every system follows the standard completely.

1
trojanfoe On

It's because the BSD's require it:

FreeBSD and OpenBSD need sys/time.h, not just time.h, before sys/resource.h.

See this page on UNIX Portability for details.