mirror of
https://github.com/reactos/CMake.git
synced 2025-01-17 00:48:40 +00:00
9db3116226
Ancient versions of CMake required else(), endif(), and similar block termination commands to have arguments matching the command starting the block. This is no longer the preferred style. Run the following shell code: for c in else endif endforeach endfunction endmacro endwhile; do echo 's/\b'"$c"'\(\s*\)(.\+)/'"$c"'\1()/' done >convert.sed && git ls-files -z -- bootstrap '*.cmake' '*.cmake.in' '*CMakeLists.txt' | egrep -z -v '^(Utilities/cm|Source/kwsys/)' | egrep -z -v 'Tests/CMakeTests/While-Endwhile-' | xargs -0 sed -i -f convert.sed && rm convert.sed
125 lines
4.1 KiB
CMake
125 lines
4.1 KiB
CMake
# - Configure a project for testing with CTest or old Dart Tcl Client
|
|
# This file is the backwards-compatibility version of the CTest module.
|
|
# It supports using the old Dart 1 Tcl client for driving dashboard
|
|
# submissions as well as testing with CTest. This module should be included
|
|
# in the CMakeLists.txt file at the top of a project. Typical usage:
|
|
# include(Dart)
|
|
# if(BUILD_TESTING)
|
|
# # ... testing related CMake code ...
|
|
# endif()
|
|
# The BUILD_TESTING option is created by the Dart module to determine
|
|
# whether testing support should be enabled. The default is ON.
|
|
|
|
# This file configures a project to use the Dart testing/dashboard process.
|
|
# It is broken into 3 sections.
|
|
#
|
|
# Section #1: Locate programs on the client and determine site and build name
|
|
# Section #2: Configure or copy Tcl scripts from the source tree to build tree
|
|
# Section #3: Custom targets for performing dashboard builds.
|
|
#
|
|
#
|
|
|
|
#=============================================================================
|
|
# Copyright 2001-2009 Kitware, Inc.
|
|
#
|
|
# Distributed under the OSI-approved BSD License (the "License");
|
|
# see accompanying file Copyright.txt 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 CMake, substitute the full
|
|
# License text for the above reference.)
|
|
|
|
option(BUILD_TESTING "Build the testing tree." ON)
|
|
|
|
if(BUILD_TESTING)
|
|
find_package(Dart QUIET)
|
|
|
|
#
|
|
# Section #1:
|
|
#
|
|
# CMake commands that will not vary from project to project. Locates programs
|
|
# on the client and configure site name and build name.
|
|
#
|
|
|
|
set(RUN_FROM_DART 1)
|
|
include(CTest)
|
|
set(RUN_FROM_DART)
|
|
|
|
find_program(COMPRESSIONCOMMAND NAMES gzip compress zip
|
|
DOC "Path to program used to compress files for transfer to the dart server")
|
|
find_program(GUNZIPCOMMAND gunzip DOC "Path to gunzip executable")
|
|
find_program(JAVACOMMAND java DOC "Path to java command, used by the Dart server to create html.")
|
|
option(DART_VERBOSE_BUILD "Show the actual output of the build, or if off show a . for each 1024 bytes."
|
|
OFF)
|
|
option(DART_BUILD_ERROR_REPORT_LIMIT "Limit of reported errors, -1 reports all." -1 )
|
|
option(DART_BUILD_WARNING_REPORT_LIMIT "Limit of reported warnings, -1 reports all." -1 )
|
|
|
|
set(VERBOSE_BUILD ${DART_VERBOSE_BUILD})
|
|
set(BUILD_ERROR_REPORT_LIMIT ${DART_BUILD_ERROR_REPORT_LIMIT})
|
|
set(BUILD_WARNING_REPORT_LIMIT ${DART_BUILD_WARNING_REPORT_LIMIT})
|
|
set (DELIVER_CONTINUOUS_EMAIL "Off" CACHE BOOL "Should Dart server send email when build errors are found in Continuous builds?")
|
|
|
|
mark_as_advanced(
|
|
COMPRESSIONCOMMAND
|
|
DART_BUILD_ERROR_REPORT_LIMIT
|
|
DART_BUILD_WARNING_REPORT_LIMIT
|
|
DART_TESTING_TIMEOUT
|
|
DART_VERBOSE_BUILD
|
|
DELIVER_CONTINUOUS_EMAIL
|
|
GUNZIPCOMMAND
|
|
JAVACOMMAND
|
|
)
|
|
|
|
set(HAVE_DART)
|
|
if(EXISTS "${DART_ROOT}/Source/Client/Dart.conf.in")
|
|
set(HAVE_DART 1)
|
|
endif()
|
|
|
|
#
|
|
# Section #2:
|
|
#
|
|
# Make necessary directories and configure testing scripts
|
|
#
|
|
# find a tcl shell command
|
|
if(HAVE_DART)
|
|
find_package(Tclsh)
|
|
endif()
|
|
|
|
|
|
if (HAVE_DART)
|
|
# make directories in the binary tree
|
|
file(MAKE_DIRECTORY "${PROJECT_BINARY_DIR}/Testing/HTML/TestingResults/Dashboard"
|
|
"${PROJECT_BINARY_DIR}/Testing/HTML/TestingResults/Sites/${SITE}/${BUILDNAME}")
|
|
|
|
# configure files
|
|
configure_file(
|
|
"${DART_ROOT}/Source/Client/Dart.conf.in"
|
|
"${PROJECT_BINARY_DIR}/DartConfiguration.tcl" )
|
|
|
|
#
|
|
# Section 3:
|
|
#
|
|
# Custom targets to perform dashboard builds and submissions.
|
|
# These should NOT need to be modified from project to project.
|
|
#
|
|
|
|
# add testing targets
|
|
set(DART_EXPERIMENTAL_NAME Experimental)
|
|
if(DART_EXPERIMENTAL_USE_PROJECT_NAME)
|
|
set(DART_EXPERIMENTAL_NAME "${DART_EXPERIMENTAL_NAME}${PROJECT_NAME}")
|
|
endif()
|
|
endif ()
|
|
|
|
set(RUN_FROM_CTEST_OR_DART 1)
|
|
include(CTestTargets)
|
|
set(RUN_FROM_CTEST_OR_DART)
|
|
endif()
|
|
|
|
#
|
|
# End of Dart.cmake
|
|
#
|
|
|