mirror of
https://github.com/Kitware/CMake.git
synced 2026-01-01 11:22:21 -06:00
- Added intro code block with find_package() showing how to find the package using this module. - Used "commands" instead of "macros". - Synced one missed SUBVERSION_FOUND variable in code to Subversion_FOUND (available as of CMake 3.3.). - Synced few descriptions with other similar find modules.
236 lines
7.5 KiB
CMake
236 lines
7.5 KiB
CMake
# Distributed under the OSI-approved BSD 3-Clause License. See accompanying
|
|
# file LICENSE.rst or https://cmake.org/licensing for details.
|
|
|
|
#[=======================================================================[.rst:
|
|
FindSubversion
|
|
--------------
|
|
|
|
Finds a Subversion command-line client executable (``svn``) and provides
|
|
commands for extracting information from a Subversion working copy:
|
|
|
|
.. code-block:: cmake
|
|
|
|
find_package(Subversion [<version>] [...])
|
|
|
|
Result Variables
|
|
^^^^^^^^^^^^^^^^
|
|
|
|
This module defines the following variables:
|
|
|
|
``Subversion_FOUND``
|
|
Boolean indicating whether (the requested version of) Subversion command-line
|
|
client is found. For backward compatibility, the ``SUBVERSION_FOUND``
|
|
variable is also set to the same value.
|
|
|
|
``Subversion_VERSION_SVN``
|
|
Version of the ``svn`` command-line client found.
|
|
|
|
Cache Variables
|
|
^^^^^^^^^^^^^^^
|
|
|
|
The following cache variables may also be set:
|
|
|
|
``Subversion_SVN_EXECUTABLE``
|
|
Path to the ``svn`` command-line client.
|
|
|
|
Commands
|
|
^^^^^^^^
|
|
|
|
This module provides the following commands if the Subversion command-line
|
|
client is found:
|
|
|
|
.. command:: Subversion_WC_INFO
|
|
|
|
Extracts information from a Subversion working copy located at a specified
|
|
directory:
|
|
|
|
.. code-block:: cmake
|
|
|
|
Subversion_WC_INFO(<dir> <var-prefix> [IGNORE_SVN_FAILURE])
|
|
|
|
This command defines the following variables if running Subversion's ``info``
|
|
subcommand on ``<dir>`` succeeds; otherwise a ``SEND_ERROR`` message is
|
|
generated:
|
|
|
|
``<var-prefix>_WC_URL``
|
|
URL of the repository (at ``<dir>``).
|
|
``<var-prefix>_WC_ROOT``
|
|
Root URL of the repository.
|
|
``<var-prefix>_WC_REVISION``
|
|
Current revision.
|
|
``<var-prefix>_WC_LAST_CHANGED_AUTHOR``
|
|
Author of last commit.
|
|
``<var-prefix>_WC_LAST_CHANGED_DATE``
|
|
Date of last commit.
|
|
``<var-prefix>_WC_LAST_CHANGED_REV``
|
|
Revision of last commit.
|
|
``<var-prefix>_WC_INFO``
|
|
Output of the command ``svn info <dir>``
|
|
|
|
The options are:
|
|
|
|
``IGNORE_SVN_FAILURE``
|
|
.. versionadded:: 3.13
|
|
|
|
When specified, errors from Subversion operation will not trigger a
|
|
``SEND_ERROR`` message. In case of an error, the ``<var-prefix>_*``
|
|
variables remain undefined.
|
|
|
|
.. command:: Subversion_WC_LOG
|
|
|
|
Retrieves the log message of the base revision of a Subversion working copy at
|
|
a given location:
|
|
|
|
.. code-block:: cmake
|
|
|
|
Subversion_WC_LOG(<dir> <var-prefix>)
|
|
|
|
This command defines the following variable if running Subversion's ``log``
|
|
subcommand on ``<dir>`` succeeds; otherwise a ``SEND_ERROR`` message is
|
|
generated:
|
|
|
|
``<var-prefix>_LAST_CHANGED_LOG``
|
|
Last log of the base revision of a Subversion working copy located at
|
|
``<dir>``.
|
|
|
|
Examples
|
|
^^^^^^^^
|
|
|
|
Examples: Finding Subversion
|
|
""""""""""""""""""""""""""""
|
|
|
|
Finding Subversion:
|
|
|
|
.. code-block:: cmake
|
|
|
|
find_package(Subversion)
|
|
|
|
Or, finding Subversion and specifying a minimum required version:
|
|
|
|
.. code-block:: cmake
|
|
|
|
find_package(Subversion 1.4)
|
|
|
|
Or, finding Subversion and making it required (if not found, processing stops
|
|
with an error message):
|
|
|
|
.. code-block:: cmake
|
|
|
|
find_package(Subversion REQUIRED)
|
|
|
|
Example: Using Subversion
|
|
"""""""""""""""""""""""""
|
|
|
|
Finding Subversion and retrieving information about the current project's
|
|
working copy:
|
|
|
|
.. code-block:: cmake
|
|
|
|
find_package(Subversion)
|
|
if(Subversion_FOUND)
|
|
Subversion_WC_INFO(${PROJECT_SOURCE_DIR} Project)
|
|
message("Current revision is ${Project_WC_REVISION}")
|
|
Subversion_WC_LOG(${PROJECT_SOURCE_DIR} Project)
|
|
message("Last changed log is ${Project_LAST_CHANGED_LOG}")
|
|
endif()
|
|
#]=======================================================================]
|
|
|
|
find_program(Subversion_SVN_EXECUTABLE svn
|
|
PATHS
|
|
[HKEY_LOCAL_MACHINE\\Software\\TortoiseSVN;Directory]/bin
|
|
DOC "subversion command line client")
|
|
mark_as_advanced(Subversion_SVN_EXECUTABLE)
|
|
|
|
if(Subversion_SVN_EXECUTABLE)
|
|
# the subversion commands should be executed with the C locale, otherwise
|
|
# the message (which are parsed) may be translated, Alex
|
|
set(_Subversion_SAVED_LC_ALL "$ENV{LC_ALL}")
|
|
set(ENV{LC_ALL} C)
|
|
|
|
execute_process(COMMAND ${Subversion_SVN_EXECUTABLE} --version
|
|
OUTPUT_VARIABLE Subversion_VERSION_SVN
|
|
ERROR_VARIABLE _Subversion_VERSION_STDERR
|
|
RESULT_VARIABLE _Subversion_VERSION_RESULT
|
|
OUTPUT_STRIP_TRAILING_WHITESPACE)
|
|
|
|
# restore the previous LC_ALL
|
|
set(ENV{LC_ALL} ${_Subversion_SAVED_LC_ALL})
|
|
|
|
if(_Subversion_VERSION_RESULT EQUAL 0)
|
|
string(REGEX REPLACE "^(.*\n)?svn, version ([.0-9]+).*"
|
|
"\\2" Subversion_VERSION_SVN "${Subversion_VERSION_SVN}")
|
|
else()
|
|
unset(Subversion_VERSION_SVN)
|
|
if(_Subversion_VERSION_STDERR MATCHES "svn: error: The subversion command line tools are no longer provided by Xcode")
|
|
set(Subversion_SVN_EXECUTABLE Subversion_SVN_EXECUTABLE-NOTFOUND)
|
|
endif()
|
|
endif()
|
|
|
|
macro(Subversion_WC_INFO dir prefix)
|
|
|
|
cmake_parse_arguments(
|
|
"Subversion_WC_INFO"
|
|
"IGNORE_SVN_FAILURE"
|
|
"" ""
|
|
${ARGN}
|
|
)
|
|
|
|
# the subversion commands should be executed with the C locale, otherwise
|
|
# the message (which are parsed) may be translated, Alex
|
|
set(_Subversion_SAVED_LC_ALL "$ENV{LC_ALL}")
|
|
set(ENV{LC_ALL} C)
|
|
|
|
execute_process(COMMAND ${Subversion_SVN_EXECUTABLE} info ${dir}
|
|
OUTPUT_VARIABLE ${prefix}_WC_INFO
|
|
ERROR_VARIABLE Subversion_svn_info_error
|
|
RESULT_VARIABLE Subversion_svn_info_result
|
|
OUTPUT_STRIP_TRAILING_WHITESPACE)
|
|
|
|
if(${Subversion_svn_info_result} EQUAL 0)
|
|
string(REGEX REPLACE "^(.*\n)?URL: ([^\n]+).*"
|
|
"\\2" ${prefix}_WC_URL "${${prefix}_WC_INFO}")
|
|
string(REGEX REPLACE "^(.*\n)?Repository Root: ([^\n]+).*"
|
|
"\\2" ${prefix}_WC_ROOT "${${prefix}_WC_INFO}")
|
|
string(REGEX REPLACE "^(.*\n)?Revision: ([^\n]+).*"
|
|
"\\2" ${prefix}_WC_REVISION "${${prefix}_WC_INFO}")
|
|
string(REGEX REPLACE "^(.*\n)?Last Changed Author: ([^\n]+).*"
|
|
"\\2" ${prefix}_WC_LAST_CHANGED_AUTHOR "${${prefix}_WC_INFO}")
|
|
string(REGEX REPLACE "^(.*\n)?Last Changed Rev: ([^\n]+).*"
|
|
"\\2" ${prefix}_WC_LAST_CHANGED_REV "${${prefix}_WC_INFO}")
|
|
string(REGEX REPLACE "^(.*\n)?Last Changed Date: ([^\n]+).*"
|
|
"\\2" ${prefix}_WC_LAST_CHANGED_DATE "${${prefix}_WC_INFO}")
|
|
elseif(NOT Subversion_WC_INFO_IGNORE_SVN_FAILURE)
|
|
message(SEND_ERROR "Command \"${Subversion_SVN_EXECUTABLE} info ${dir}\" failed with output:\n${Subversion_svn_info_error}")
|
|
endif()
|
|
|
|
# restore the previous LC_ALL
|
|
set(ENV{LC_ALL} ${_Subversion_SAVED_LC_ALL})
|
|
|
|
endmacro()
|
|
|
|
macro(Subversion_WC_LOG dir prefix)
|
|
# This macro can block if the certificate is not signed:
|
|
# svn ask you to accept the certificate and wait for your answer
|
|
# This macro requires a svn server network access (Internet most of the time)
|
|
# and can also be slow since it access the svn server
|
|
execute_process(COMMAND
|
|
${Subversion_SVN_EXECUTABLE} --non-interactive log -r BASE ${dir}
|
|
OUTPUT_VARIABLE ${prefix}_LAST_CHANGED_LOG
|
|
ERROR_VARIABLE Subversion_svn_log_error
|
|
RESULT_VARIABLE Subversion_svn_log_result
|
|
OUTPUT_STRIP_TRAILING_WHITESPACE)
|
|
|
|
if(NOT ${Subversion_svn_log_result} EQUAL 0)
|
|
message(SEND_ERROR "Command \"${Subversion_SVN_EXECUTABLE} log -r BASE ${dir}\" failed with output:\n${Subversion_svn_log_error}")
|
|
endif()
|
|
endmacro()
|
|
|
|
endif()
|
|
|
|
include(FindPackageHandleStandardArgs)
|
|
find_package_handle_standard_args(Subversion REQUIRED_VARS Subversion_SVN_EXECUTABLE
|
|
VERSION_VAR Subversion_VERSION_SVN )
|
|
|
|
# for compatibility
|
|
set(Subversion_SVN_FOUND ${Subversion_FOUND})
|