The -l
option tells the linker to search the libraries in the standard dirs.
And with -L
, we can specify our own library directories for searching.
Question: Does the sequence of order matters for the -L
option too, like it does for the -l
w.r.t the linker?
This link: http://gcc.gnu.org/onlinedocs/gcc/Link-Options.html doesn't say much about the sequence of -L
.
EDIT Also,
Directories specified on the command line are searched before the default directories
is from the man page (as pointed by Dmitry), does this mean that even if I specify the order like:
gcc -lm hello.c -Lx
still the directory specified with -L
will be given preference first?
Yes, the order of -L
options matters - just like -l
and -I
options.
From man ld
-Lsearchdir
--library-path=searchdirAdd path searchdir to the list of paths that ld will search for archive libraries and ld control scripts. You may use this option any number of times. The directories are searched in the order in which they are specified on the command line. Directories specified on the command line are searched before the default directories. All -L options apply to all -l options, regardless of the order in which the options appear.
GCC documentations and more specifically Linking Options will be useful for you
Edit
Sorry, indeed I missed to check the link you've given. "man ld" can just be written in the console.
Edit2
I made a simple test putting -l
before -L
options and it shows no difference comparing to -L
before -l
So answering your second question, this
gcc -lm hello.c -Lx
is equal to this
gcc -Lx -lm hello.c
libm is searched first in directory x/ in both tests.
Note though that putting -l<lib>
before source files is a bad practice, that may lead to undefined references when linking. This is the correct way
gcc hello.c -Lx -lm