[CMake] Generate sources

Mark Stijnman mark.stijnman at gmail.com
Wed Dec 16 11:53:49 EST 2015


On Wed, Dec 16, 2015 at 2:29 PM, Layus <layus.on at gmail.com> wrote:

> Hi,
>
> I am looking for a way to share an archive of a partially compiled project
> to speedup compilation time and configuration hassle for the users.
>
> I have a project that works in two steps.
> First a source generator is built (based on clang) and generates some
> extra source files based on the existing source files.
> Then the normal compilation process takes places, building the application
> from both original and generated sources.
>
> <snip>


> Now, is it possible to distribute a source archive with the generated
> sources, in such a way that any user unpacking the archive and running
> cmake would not have to generate the extra sources ?
>
> This would be useful because
> i) the project is tricky to configure and
> ii) the generated sources are not dependent on the user config, so
> building the generator is just useless computation time on the user.
>
> The ideal scheme would be something like
>
>     [developper]
>     $ cmake -DCLANG=config
>     $ make generate
>     $ make package_source
>
>     [user]
>     $ unpack
>     $ cmake -DUSER=config
>     $ make # builds only the application, reusing the shipped generated
> sources.
>     $ make install
>
> ... but when the user runs cmake, he overwrites the generated Makefiles
> and the extra sources are generated again.
>
> Any idea ?
>
> layus.
>
> --
>

I'd probably just make it such that the CMake script automatically detects
the presence of the generated files, and if they don't exist, generate
them. For example:
1. Set a variable GENERATED_FOLDER to ${CMAKE_CURRENT_SOURCE_DIR}/generated
2. If ${GENERATED_FOLDER} doesn't exist, set it to
${CMAKE_CURRENT_BINARY_DIR}/generated instead, and set up the targets that
will generate the files in that folder.
3. Simply use the ${GENERATED_FOLDER} variable to add the generated files
to your application.
4. Set up the package_source target so that it packages the files from
${GENERATED_FOLDER} to a folder called "generated" (such that if a user
unpacks from there, they will end up in
${CMAKE_CURRENT_SOURCE_DIR}/generated), and you're done.
5. Recommended: add a check for the existence of target "generate", and if
so, set it as a dependency for your application and package_source.

This way, you don't need to remember what switches to use, or when to use
"make generate". If you need to make it possible for a user to force
generation, you can alter step 2 to also run when a command line option is
supplied.

Hope that helps,

Best regards Mark
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://public.kitware.com/pipermail/cmake/attachments/20151216/05dd41aa/attachment-0001.html>


More information about the CMake mailing list