Why can't gcc find the random() interface when -std=c99 is set?

14,528

Solution 1

man srandom says that the function is not part of C99 but part of POSIX.

Activate _BSD_SOURCE or _XOPEN_SOURCE >= 500 or any other suitable feature test macro that declares the srandom/random function (see man feature_test_macros and man srandom).

This one has good chances, but you need to figure out the macros that are defined/not defined implicitly thereby too by reading the manpages above.

/usr/bin/colorgcc -std=c99 -D_XOPEN_SOURCE=600 -fgnu89-inline -g -Wall 
    -I/usr/include -I./ -I../ -I../../ -I../../../ -I../../../../ -O3 -o f8  f8.c

Solution 2

Yes, there is a trick you are missing: you can use -std=gnu99 instead of -std=c99.

-std=c99 #defines __STRICT_ANSI__, which /usr/include/features.h interprets as "do not enable anything outside the C standard by default" (without it, you get at least both _SVID_SOURCE and _BSD_SOURCE). -std=gnu99, on the other hand, means "C99 plus GNU extensions" (the gcc default is currently -std=gnu89, its C89 equivalent, which is why you needed to specify something to get the new C99 features).

As an alternative, you can enable the feature test macros (as mentioned in @litb's answer). Looking at /usr/include/stdlib.h in my system, it expects one of __USE_SVID, __USE_XOPEN_EXTENDED, or __USE_BSD. /usr/include/features.h tells me that the feature test macros which would enable these are:

  • _SVID_SOURCE (enables __USE_SVID)
  • _BSD_SOURCE (enables __USE_BSD)
  • _XOPEN_SOURCE with a value of at least 500 (enables __USE_XOPEN_EXTENDED)
  • _XOPEN_SOURCE_EXTENDED (also enables __USE_XOPEN_EXTENDED)
  • _GNU_SOURCE (enables everything, including the four feature test macros above)

For new programs where you are not too concerned about potential name collisions with new functions from future standards, using both -std=gnu99 and -D_GNU_SOURCE is a good idea. It allows you to use all the new standard features and GNU extensions, which combined with some sort of fallback (for instance, autoconf-style feature tests) gives the most flexibility.

References:

Share:
14,528
Setjmp
Author by

Setjmp

I have been working in the digital marketing space since 2010 building prediction and optimization products. Before that, did quant finance for a bunch of years including such storied places as Amaranth Advisors and WorldQuant where I was one of the original employees. This was the mid 2000s and a very exciting period in the field. Along the way I have spent many years in academia and produced a number of publications including some early work in Recommender Systems. A theme in all my industrial work has been prediction and optimization as work product.

Updated on June 03, 2022

Comments

  • Setjmp
    Setjmp almost 2 years

    I do "#include <stdlib.h>" at the top of the source.

    Example compilation:

    /usr/bin/colorgcc -std=c99 -fgnu89-inline  -g -Wall -I/usr/include -I./ -I../ -I../../ -I../../../ -I../../../../    -O3 -o f8  f8.c
    In file included from f8.c:7:
    ctype-cmp.c: In function ‘randomized’:
    ctype-cmp.c:48: warning: implicit declaration of function ‘random’
    ctype-cmp.c: In function ‘main’:
    ctype-cmp.c:153: warning: implicit declaration of function ‘srandom’
    ais@xcalibur:t$ 
    

    When I turn off -std=c99, the function isfinite() can not be found. So I do want to use -std=c99 for this and other reasons. Is there some trick I'm missing?