From bb059dc2e1dbcc47c6e2a932f762c390c8aaf45e Mon Sep 17 00:00:00 2001 From: Alanscut Date: Tue, 29 Oct 2019 15:48:11 +0800 Subject: [PATCH] add uninstall target in cmake --- CMakeLists.txt | 3 +++ library_config/uninstall.cmake | 27 +++++++++++++++++++++++++++ 2 files changed, 30 insertions(+) create mode 100644 library_config/uninstall.cmake diff --git a/CMakeLists.txt b/CMakeLists.txt index f977963..34ad39f 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -253,6 +253,9 @@ if(ENABLE_CJSON_TEST) DEPENDS ${TEST_CJSON}) endif() +#Create the uninstall target +add_custom_target(uninstall "${CMAKE_COMMAND}" -P "${PROJECT_SOURCE_DIR}/library_config/uninstall.cmake") + # Enable the use of locales option(ENABLE_LOCALES "Enable the use of locales" ON) if(ENABLE_LOCALES) diff --git a/library_config/uninstall.cmake b/library_config/uninstall.cmake new file mode 100644 index 0000000..e751ec4 --- /dev/null +++ b/library_config/uninstall.cmake @@ -0,0 +1,27 @@ +cmake_minimum_required(VERSION 2.8.5) + +set(MANIFEST "${CMAKE_CURRENT_BINARY_DIR}/install_manifest.txt") + +if(NOT EXISTS ${MANIFEST}) + message(FATAL_ERROR "Cannot find install mainfest: ${MANIFEST}") +endif() + +file(STRINGS ${MANIFEST} files) +foreach(file ${files}) + if(EXISTS ${file} OR IS_SYMLINK ${file}) + message(STATUS "Removing: ${file}") + + execute_process(COMMAND rm -f ${file} + RESULT_VARIABLE result + OUTPUT_QUIET + ERROR_VARIABLE stderr + ERROR_STRIP_TRAILING_WHITESPACE + ) + + if(NOT ${result} EQUAL 0) + message(FATAL_ERROR "${stderr}") + endif() + else() + message(STATUS "Does-not-exist: ${file}") + endif() +endforeach(file)