diff options
author | Alex Merry <alex.merry@kde.org> | 2015-02-01 11:20:43 +0000 |
---|---|---|
committer | Alex Merry <alex.merry@kde.org> | 2015-02-04 18:29:47 +0000 |
commit | 807ace309a489d21163b5c671d9e449c06e14e20 (patch) | |
tree | cfb1fd0e14ec49ad42d7ae2b4f32b1a4788b4e81 /modules/ECMUninstallTarget.cmake | |
parent | fea3b11ca01677e60d552ac29091b28946c99f08 (diff) | |
download | extra-cmake-modules-807ace309a489d21163b5c671d9e449c06e14e20.tar.gz extra-cmake-modules-807ace309a489d21163b5c671d9e449c06e14e20.tar.bz2 |
Add a module to provide an uninstall target.
This is basically just the code available on the CMake FAQ item about
`make uninstall`, but packaged up in a convenient module.
REVIEW: 122359
Diffstat (limited to 'modules/ECMUninstallTarget.cmake')
-rw-r--r-- | modules/ECMUninstallTarget.cmake | 56 |
1 files changed, 56 insertions, 0 deletions
diff --git a/modules/ECMUninstallTarget.cmake b/modules/ECMUninstallTarget.cmake new file mode 100644 index 00000000..d9363125 --- /dev/null +++ b/modules/ECMUninstallTarget.cmake @@ -0,0 +1,56 @@ +#.rst: +# ECMUninstallTarget +# ------------------ +# +# Add an ``uninstall`` target. +# +# By including this module, an ``uninstall`` target will be added to your CMake +# project. This will remove all files installed (or updated) by a previous +# invocation of the ``install`` target. It will not remove files created or +# modified by an ``install(SCRIPT)`` or ``install(CODE)`` command; you should +# create a custom uninstallation target for these and use ``add_dependency`` to +# make the ``uninstall`` target depend on it: +# +# .. code-block:: cmake +# +# include(ECMUninstallTarget) +# install(SCRIPT install-foo.cmake) +# add_custom_target(uninstall_foo COMMAND ${CMAKE_COMMAND} -P uninstall-foo.cmake) +# add_dependency(uninstall uninstall_foo) +# +# The target will fail if the ``install`` target has not yet been run (so it is +# not possible to run CMake on the project and then immediately run the +# ``uninstall`` target). +# +# .. warning:: +# +# CMake deliberately does not provide an ``uninstall`` target by default on +# the basis that such a target has the potential to remove important files +# from a user's computer. Use with caution. + +#============================================================================= +# Copyright 2015 Alex Merry <alex.merry@kde.org> +# +# Distributed under the OSI-approved BSD License (the "License"); +# see accompanying file COPYING-CMAKE-SCRIPTS for details. +# +# This software is distributed WITHOUT ANY WARRANTY; without even the +# implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. +# See the License for more information. +#============================================================================= +# (To distribute this file outside of extra-cmake-modules, substitute the full +# License text for the above reference.) + +if (NOT TARGET uninstall) + configure_file( + "${CMAKE_CURRENT_LIST_DIR}/ecm_uninstall.cmake.in" + "${CMAKE_BINARY_DIR}/ecm_uninstall.cmake" + IMMEDIATE + @ONLY + ) + + add_custom_target(uninstall + COMMAND "${CMAKE_COMMAND}" -P "${CMAKE_BINARY_DIR}/ecm_uninstall.cmake" + WORKING_DIRECTORY "${CMAKE_BINARY_DIR}" + ) +endif() |