[cmake-developers] Fwd: How to handle different cmake versions in extra-cmake-modules ?
Alexander Neundorf
neundorf at kde.org
Sun Dec 11 16:33:19 UTC 2011
On Tuesday 06 December 2011, Alexander Neundorf wrote:
> Hi,
>
> On Monday 07 November 2011, Brad King wrote:
> > On 11/6/2011 6:12 AM, Stephen Kelly wrote:
> > > ecm_copy_modules(${CMAKE_BINARY_DIR}/modules FindFoo.cmake
> > >
> > > FindBlub.cmake
> > > ECMDoSomething.cmake)
> > >
> > > set(CMAKE_MODULE_PATH ${CMAKE_MODULE_PATH}
> > > ${CMAKE_BINARY_DIR}/modules} )
> > >
> > > This macro would copy just these needed files into the given directory,
> > > which can then be added to CMAKE_MODULE_PATH.
> >
> > See below for an idea that may solve cases 2 and 3 together.
> >
> > > Case 3. I don't really have an idea yet. Add some code at the top of
> > > each file which include()s the file from cmake if the version is
> > > bigger than some specified version ?
> > >
> > > Something like:
> > > FindBlub.cmake:
> > >
> > > if(CMAKE_VERSION> 2.8.12)
> > >
> > > include(${CMAKE_ROOT}/Modules/FindBlub.cmake)
> > > return()
> > >
> > > endif()
> >
> > We've done the following before:
> > if(EXISTS ${CMAKE_ROOT}/Modules/FindBlub.cmake)
> >
> > include(${CMAKE_ROOT}/Modules/FindBlub.cmake)
> > return()
> >
> > endif()
> >
> > That way you don't need to know when the module is added. It is also
> > forward-compatible for any module not yet in CMake but may be later.
> > OTOH the version of the module added to CMake may provide a slightly
> > different interface than the original version. That leads to the
> > unfortunate situation that a newer CMake breaks an existing build,
> > which looks like CMake's fault but isn't.
> >
> > Another option is to provide a function that generates forwarding
> > modules. Instead of ecm_copy_modules, create a similar API that
> > generates short modules that include either the ECM version or the
> > CMake version depending on some conditions. Do the inclusion by
> > full path so that the actual ECM module dir does not need to be in
> > the CMAKE_MODULE_PATH.
>
> yesterday in the train I found the time to do start with something on this.
>
> So, here is the idea:
>
> * the files containing macros/functions and the find-modules are put into
> two different directories, e.g. modules/macros/ and modules/find/.
>
> (Since the macros will all have the "ecm_" prefix, a clash with anything
> from cmake is not possible. So we only have to care about the
> Find-modules.) So when doing
> find_package(extra-cmake-modules)
> two variables will be defined, ECM_MACROS_DIR and ECM_FIND_MODULES_DIR.
>
> If somebody wants everything, he does
>
> set(CMAKE_MODULES_PATH ${ECM_MACROS_DIR} ${ECM_FIND_MODULES_DIR} )
>
> If he wants to use only some macros, he does
> set(CMAKE_MODULES_PATH ${ECM_MACROS_DIR} )
>
> If he wants to use a subset of the find-modules, there is a function
> ecm_use_find_modules:
> ecm_use_find_modules(DIR <destdir>
> MODULES FindFoo.cmake FindBar.cmake ...
> [NO_OVERRIDE] )
>
> The listed find-modules will be copied from ${ECM_FIND_MODULES_DIR} to the
> directory given here as destination dir, and this directory has to be added
> to CMAKE_MODULE_PATH.
> If NO_OVERRIDE is used, the files will only be used if they do not exist in
> cmake.
> This way e.g. FindBlub.cmake will be used until it is part of cmake, then
> the cmake version will be used.
>
> Attached is a draft of the file, just to show the idea, I didn't actually
> try to run it yet.
>
>
> Examples:
>
> 1) use everything from e-c-m:
>
> find_package(extra-cmake-modules REQUIRED)
> set(CMAKE_MODULE_PATH ${ECM_MACROS_DIR} ${ECM_FIND_MODULES_DIR} )
>
> 2) make all macros available, but no find-modules:
>
> find_package(extra-cmake-modules REQUIRED)
> set(CMAKE_MODULE_PATH ${ECM_MACROS_DIR} )
>
> 3) make all macros available and some find-modules if they do not yet exist
> in cmake:
>
> find_package(extra-cmake-modules REQUIRED)
> ecm_use_find_modules(DIR ${CMAKE_CURRENT_BINARY_DIR}/ecm/
> MODULES FindFoo.cmake NO_OVERRIDE)
>
> set(CMAKE_MODULE_PATH ${ECM_MACROS_DIR} ${CMAKE_CURRENT_BINARY_DIR}/ecm/ )
>
>
> 4) make all macros available and some find-modules as override for the
> cmake ones:
>
> find_package(extra-cmake-modules REQUIRED)
> ecm_use_find_modules(DIR ${CMAKE_CURRENT_BINARY_DIR}/ecm/
> MODULES FindBoost.cmake)
>
> set(CMAKE_MODULE_PATH ${ECM_MACROS_DIR} ${CMAKE_CURRENT_BINARY_DIR}/ecm/ )
>
>
> Does that look like it should cover all use cases, for peopling wanting to
> selectively use some things from e-c-m, and fearing that something would
> break if they simply would make everything available ?
I added this now to extra-cmake-modules:
http://quickgit.kde.org/?p=extra-cmake-
modules.git&a=blob&hb=HEAD&f=modules/ECMUseFindModules.cmake
The find-modules now go into find-modules/, other modules go into modules/.
Alx
More information about the Kde-frameworks-devel
mailing list