]> git.ipfire.org Git - thirdparty/libarchive.git/commitdiff
Include coverage script if ENABLE_COVERAGE is set 44/head
authorKonrad Kleine <konrad.wilhelm.kleine@gmail.com>
Fri, 13 Dec 2013 08:28:55 +0000 (09:28 +0100)
committerKonrad Kleine <konrad.wilhelm.kleine@gmail.com>
Fri, 13 Dec 2013 08:42:31 +0000 (09:42 +0100)
Rather than including the LibarchiveCodeCoverage.cmake file and checking
there if ENABLE_COVERAGE is set, we only include the file if this option
is set in the first place.

CMakeLists.txt
build/cmake/LibarchiveCodeCoverage.cmake

index fd257676319361240b4599295434cf9b1d99e44f..cc98160c223a8ecbd3f4c3d301336dc67c4f4784 100644 (file)
@@ -156,7 +156,9 @@ SET(POSIX_REGEX_LIB "AUTO" CACHE STRING "Choose what library should provide POSI
 SET(ENABLE_SAFESEH "AUTO" CACHE STRING "Enable use of /SAFESEH linker flag (MSVC only)")
 SET(WINDOWS_VERSION "" CACHE STRING "Set Windows version to use (Windows only)")
 
-include(LibarchiveCodeCoverage)
+IF(ENABLE_COVERAGE)
+       include(LibarchiveCodeCoverage)
+ENDIF(ENABLE_COVERAGE)
 
 IF(ENABLE_TEST)
        ENABLE_TESTING()
index ea7bb215aae5799cda53132a971fcfacb244441a..297b886ccf055bfb0bd38948fda1f0f27a834482 100644 (file)
 #    make coverage
 #    xdg-open coverage/index.html
 #################################################################
-IF(ENABLE_COVERAGE)
-  # Find programs we need 
-  FIND_PROGRAM(LCOV_EXECUTABLE lcov DOC "Full path to lcov executable")
-  FIND_PROGRAM(GENHTML_EXECUTABLE genhtml DOC "Full path to genhtml executable")
-  MARK_AS_ADVANCED(LCOV_EXECUTABLE GENHTML_EXECUTABLE)
-  
-  # Check, compiler, build types and programs are available
-  IF(NOT CMAKE_COMPILER_IS_GNUCC)
-    MESSAGE(FATAL_ERROR "Coverage can only be built on GCC")
-  ELSEIF(NOT CMAKE_BUILD_TYPE STREQUAL "Debug")
-    MESSAGE(FATAL_ERROR "Coverage can only be built in Debug mode")
-  ELSEIF(NOT LCOV_EXECUTABLE)
-    MESSAGE(FATAL_ERROR "lcov executable not found")
-  ELSEIF(NOT GENHTML_EXECUTABLE)
-    MESSAGE(FATAL_ERROR "genhtml executable not found")
-  ENDIF(NOT CMAKE_COMPILER_IS_GNUCC)
 
-  # Enable testing if not already done
-  SET(ENABLE_TEST ON)
+# Find programs we need 
+FIND_PROGRAM(LCOV_EXECUTABLE lcov DOC "Full path to lcov executable")
+FIND_PROGRAM(GENHTML_EXECUTABLE genhtml DOC "Full path to genhtml executable")
+MARK_AS_ADVANCED(LCOV_EXECUTABLE GENHTML_EXECUTABLE)
 
-  #################################################################
-  # Set special compiler and linker flags for test coverage
-  #################################################################
-  # 0. Enable debug: -g
-  SET(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -g")
-  # 1. Disable optimizations: -O0
-  SET(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -O0")
-  # 2. Enable all kind of warnings:
-  SET(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wall -W")
-  # 3. Enable special coverage flag (HINT: --coverage is a synonym for -fprofile-arcs -ftest-coverage)
-  SET(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} --coverage")
-  SET(CMAKE_SHARED_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS} --coverage")
-  SET(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} --coverage")
-  #################################################################
+# Check, compiler, build types and programs are available
+IF(NOT CMAKE_COMPILER_IS_GNUCC)
+MESSAGE(FATAL_ERROR "Coverage can only be built on GCC")
+ELSEIF(NOT CMAKE_BUILD_TYPE STREQUAL "Debug")
+MESSAGE(FATAL_ERROR "Coverage can only be built in Debug mode")
+ELSEIF(NOT LCOV_EXECUTABLE)
+MESSAGE(FATAL_ERROR "lcov executable not found")
+ELSEIF(NOT GENHTML_EXECUTABLE)
+MESSAGE(FATAL_ERROR "genhtml executable not found")
+ENDIF(NOT CMAKE_COMPILER_IS_GNUCC)
+
+# Enable testing if not already done
+SET(ENABLE_TEST ON)
+
+#################################################################
+# Set special compiler and linker flags for test coverage
+#################################################################
+# 0. Enable debug: -g
+SET(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -g")
+# 1. Disable optimizations: -O0
+SET(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -O0")
+# 2. Enable all kind of warnings:
+SET(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wall -W")
+# 3. Enable special coverage flag (HINT: --coverage is a synonym for -fprofile-arcs -ftest-coverage)
+SET(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} --coverage")
+SET(CMAKE_SHARED_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS} --coverage")
+SET(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} --coverage")
+#################################################################
+
+ADD_CUSTOM_TARGET(coverage
+COMMAND ${CMAKE_COMMAND} -E echo "Beginning test coverage. Output is written to coverage.log."
+COMMAND ${CMAKE_COMMAND} -E echo "COVERAGE-STEP-1/5: Reset all execution counts to zero"
+COMMAND ${LCOV_EXECUTABLE} --directory . --zerocounters > coverage.log 2>&1
+COMMAND ${CMAKE_COMMAND} -E echo "COVERAGE-STEP-2/5: Run testrunner"
+COMMAND ${CMAKE_CTEST_COMMAND} >> coverage.log 2>&1
+COMMAND ${CMAKE_COMMAND} -E echo "COVERAGE-STEP-3/5: Collect coverage data"
+COMMAND ${LCOV_EXECUTABLE} --capture --directory . --output-file "./coverage.info" >> coverage.log 2>&1
+COMMAND ${CMAKE_COMMAND} -E echo "COVERAGE-STEP-4/5: Generate HTML from coverage data"
+COMMAND ${GENHTML_EXECUTABLE} "coverage.info" --title="libarchive-${LIBARCHIVE_VERSION_STRING}" --show-details --legend --output-directory "./coverage"  >> coverage.log 2>&1
+COMMAND ${CMAKE_COMMAND} -E echo "COVERAGE-STEP-5/5: Open test coverage HTML output in browser: xdg-open ./coverage/index.html"
+COMMENT "Runs testrunner and generates coverage output (formats: .info and .html)")
 
-  ADD_CUSTOM_TARGET(coverage
-    COMMAND ${CMAKE_COMMAND} -E echo "Beginning test coverage. Output is written to coverage.log."
-    COMMAND ${CMAKE_COMMAND} -E echo "COVERAGE-STEP-1/5: Reset all execution counts to zero"
-    COMMAND ${LCOV_EXECUTABLE} --directory . --zerocounters > coverage.log 2>&1
-    COMMAND ${CMAKE_COMMAND} -E echo "COVERAGE-STEP-2/5: Run testrunner"
-    COMMAND ${CMAKE_CTEST_COMMAND} >> coverage.log 2>&1
-    COMMAND ${CMAKE_COMMAND} -E echo "COVERAGE-STEP-3/5: Collect coverage data"
-    COMMAND ${LCOV_EXECUTABLE} --capture --directory . --output-file "./coverage.info" >> coverage.log 2>&1
-    COMMAND ${CMAKE_COMMAND} -E echo "COVERAGE-STEP-4/5: Generate HTML from coverage data"
-    COMMAND ${GENHTML_EXECUTABLE} "coverage.info" --title="libarchive-${LIBARCHIVE_VERSION_STRING}" --show-details --legend --output-directory "./coverage"  >> coverage.log 2>&1
-    COMMAND ${CMAKE_COMMAND} -E echo "COVERAGE-STEP-5/5: Open test coverage HTML output in browser: xdg-open ./coverage/index.html"
-    COMMENT "Runs testrunner and generates coverage output (formats: .info and .html)")
-ENDIF(ENABLE_COVERAGE)