mirror of
https://github.com/reactos/CMake.git
synced 2025-01-21 02:45:05 +00:00
86578eccf2
Per-source copyright/license notice headers that spell out copyright holder names and years are hard to maintain and often out-of-date or plain wrong. Precise contributor information is already maintained automatically by the version control tool. Ultimately it is the receiver of a file who is responsible for determining its licensing status, and per-source notices are merely a convenience. Therefore it is simpler and more accurate for each source to have a generic notice of the license name and references to more detailed information on copyright holders and full license terms. Our `Copyright.txt` file now contains a list of Contributors whose names appeared source-level copyright notices. It also references version control history for more precise information. Therefore we no longer need to spell out the list of Contributors in each source file notice. Replace CMake per-source copyright/license notice headers with a short description of the license and links to `Copyright.txt` and online information available from "https://cmake.org/licensing". The online URL also handles cases of modules being copied out of our source into other projects, so we can drop our notices about replacing links with full license text. Run the `Utilities/Scripts/filter-notices.bash` script to perform the majority of the replacements mechanically. Manually fix up shebang lines and trailing newlines in a few files. Manually update the notices in a few files that the script does not handle.
125 lines
3.6 KiB
CMake
125 lines
3.6 KiB
CMake
# Distributed under the OSI-approved BSD 3-Clause License. See accompanying
|
|
# file Copyright.txt or https://cmake.org/licensing for details.
|
|
|
|
#.rst:
|
|
# Dart
|
|
# ----
|
|
#
|
|
# 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.
|
|
#
|
|
#
|
|
|
|
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)
|
|
string(APPEND 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
|
|
#
|
|
|