[CMake] target_link_libraries: prefer static to dynamic
Michael Wild
themiwi at gmail.com
Mon Dec 28 04:35:33 EST 2009
On 27. Dec, 2009, at 23:30 , Pau Garcia i Quiles wrote:
> On Sun, Dec 27, 2009 at 10:16 PM, Michael Wild <themiwi at gmail.com> wrote:
>>
>> On 27. Dec, 2009, at 20:41 , Pau Garcia i Quiles wrote:
>>
>>> On Sun, Dec 27, 2009 at 10:59 AM, Michael Wild <themiwi at gmail.com> wrote:
>>>>
>>>> On 26. Dec, 2009, at 17:53 , Pau Garcia i Quiles wrote:
>>>>
>>>>> Hello,
>>>>>
>>>>> I think this has already been discussed and the answer is negative but
>>>>> still: when I do target_link_libraries to an external library (for
>>>>> instance, my application needs to link to sqlite), is it possible to
>>>>> tell CMake to link to the static version of sqlite instead of the
>>>>> dynamic version?
>>>>>
>>>>> For instance, in Debian the libsqlite3-dev package contains both the
>>>>> static and the dynamic versions of the library and they have the very
>>>>> same name:
>>>>>
>>>>> /usr/lib/libsqlite3.a
>>>>> /usr/lib/libsqlite3.so
>>>>>
>>>>> ( http://packages.debian.org/sid/i386/libsqlite3-dev/filelist )
>>>>>
>>>>> Is this feature going to be implemented any time soon? I have not
>>>>> looked at the sources for target_link_libraries but at first sight it
>>>>> doesn't look difficult to add something like
>>>>> "static;optimized;libsqlite3.a;dynamic;optimized;libsqlite3.so".
>>>>> There's the problem of find_library on Windows confusing the .lib as
>>>>> the import for a .dll with a static .lib library but IIRC it's
>>>>> possible to detect that.
>>>>
>>>> Perhaps a variable CMAKE_FIND_STATIC with the possible values "FIRST" "LAST", "ONLY" and "NEVER, similar to CMAKE_FIND_FRAMEWORK, would fit the bill?
>>>
>>> No, it won't. If my application links to two libraries, I may want to
>>> link statically to libA but dynamically to libB.
>>
>> But then, on Debian a static version of sqlite3 is available, but not on Mac OS X (that is, without compiling it yourself). What should be the behavior there? Perhaps this could be expanded to optional options FIND_STATIC of find_library and find_package? Besides, the variable IS enough:
>>
>> set(CMAKE_FIND_STATIC FIRST)
>> find_library(SQLITE_LIBRARY sqlite3)
>>
>> set(CMAKE_FIND_STATIC LAST)
>> find_library(OTHER_LIBRARY other)
>
> Instead of having CMAKE_FIND_STATIC, CMAKE_FIND_FRAMEWORK,
> CMAKE_FIND_APPBUNDLE, etc, those could be replaced with something like
> this in find_library:
>
> find_library(
> <VAR>
> name | NAMES name1 [name2 ...]
> [...]
> VARIANT variant1 [variant2 ...]
> )
>
> Where "variant1", "variant2", etc would be "shared static framework
> bundle" by default. That'd mean find_libraries searches for shared,
> static, framework and bundle in that order.
>
> With my proposal for find_library, and the one I made in the first
> e-mail of this thread, if I do:
>
> find_library( SQLITE3_LIBRARY_RELEASE sqlite3 VARIANT static shared )
>
> I'd have:
> SQLITE3_LIBRARY_RELEASE=static;release;/usr/lib/libsqlite3.a
>
> But if I do:
>
> find_library( SQLITE3_LIBRARY_RELEASE sqlite3 VARIANT shared static )
>
> I'd have:
> SQLITE3_LIBRARY_RELEASE=share;release;/usr/lib/libsqlite3.so
>
> I. e. I'm expressing preference: in the first case I'm saying "I'd
> like to find a static version of sqlite3 but if it's not available,
> give me the shared version". I could also look for the static version
> only:
>
> find_library( SQLITE3_LIBRARY_RELEASE sqlite3 VARIANT static )
>
> or the shared one:
>
> find_library( SQLITE3_LIBRARY_RELEASE sqlite3 VARIANT shared )
>
> Meaning: in the first case "I want to find a static version of sqlite3
> and fail if it's not available".
>
> Neither of those should not be the default, though.
>
> So for instance if I do:
>
> find_library( SQLITE3_LIBRARY_RELEASE sqlite3 )
>
> That'd would be equivalent to:
>
> find_library( SQLITE3_LIBRARY_RELEASE sqlite3 VARIANT shared static
> framework bundle )
>
That sounds doable to me. However, you'd need a mechanism to express the same preference when calling find_package and then have find_package communicate that to find_library. Not sure how fine-grained the control should be for FindXXX.cmake modules that find more than one library (or call another FindYYY.cmake internally).
Michael
More information about the CMake
mailing list