> it uses -l if the full path is not know or if the full path is one of the 
> system
library dirs

Hm, that sound a little weird. Using `-l` appears to delegate the library
finding to the linker although CMake has already done that job. If one was
overly cautious, one could ask questions like: What if there are two
libraries by the same name in different system library dirs? What if
there's only one library in a system dir at configure time, but two at link
time?

Moreover, in the example I gave above it seems that both libraries are in
the system path, yet still they are represented differently on the link
line.

--Nico

On Mon, Aug 31, 2015 at 10:33 PM Alexander Neundorf <a.neundorf-w...@gmx.net>
wrote:

> On Friday, August 28, 2015 08:23:47 Nico Schlömer wrote:
> > Hi everyone,
> >
> > I'm curious about when CMake decides to link a library by its absolute
> path
> > and when it links using the `-l*` syntax. I came across this for the very
> > simple test problem
> > ```
> > cmake_minimum_required(VERSION 3.0)
> >
> > project(mytest)
> >
> > find_package(ZLIB REQUIRED)
> > find_package(netCDF REQUIRED)
> >
> > add_executable(mytest main.cpp)
> > target_link_libraries(
> >   mytest
> >   ${ZLIB_LIBRARIES}
> >   ${netCDF_LIBRARIES}
> >   )
> > ```
> > The resulting link line is
> > ```
> > /usr/bin/c++       CMakeFiles/mytest.dir/main.cpp.o  -o mytest -rdynamic
> > -lz /usr/lib/x86_64-linux-gnu/libnetcdf.so.7.3.0
> > ```
> > so ZLIB is linked with `-lz`, netCDF with the full absolute path.
> >
> > Seems inconsistent? (ZLIB by the way is found through CMake's
> > FindZLIB.cmake, netCDF by their own export files.)
> >
> > So far, I had been under the impression that `-l*` defeats the purpose of
> > CMake a little bit as it asks the linker to search in the system's paths
> > for a libz.so, something CMake has already done.
> >
> > A little clarification here would be great.
>
> it uses -l if the full path is not know or if the full path is one of the
> system library dirs (like e.g. /usr/lib/ or the, IIRC, $LIBRARY_PATH
> env.var)
>
> Alex
>
>
-- 

Powered by www.kitware.com

Please keep messages on-topic and check the CMake FAQ at: 
http://www.cmake.org/Wiki/CMake_FAQ

Kitware offers various services to support the CMake community. For more 
information on each offering, please visit:

CMake Support: http://cmake.org/cmake/help/support.html
CMake Consulting: http://cmake.org/cmake/help/consulting.html
CMake Training Courses: http://cmake.org/cmake/help/training.html

Visit other Kitware open-source projects at 
http://www.kitware.com/opensource/opensource.html

Follow this link to subscribe/unsubscribe:
http://public.kitware.com/mailman/listinfo/cmake

Reply via email to