| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254 |
- # 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``
- .. versionadded:: 4.2
- 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>``.
- Deprecated Variables
- ^^^^^^^^^^^^^^^^^^^^
- The following variables are provided for backward compatibility:
- ``Subversion_VERSION_SVN``
- .. deprecated:: 4.2
- Use the ``Subversion_VERSION``.
- Version of the ``svn`` command-line client found.
- 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()
- if(DEFINED Subversion_VERSION_SVN)
- set(Subversion_VERSION "${Subversion_VERSION_SVN}")
- else()
- unset(Subversion_VERSION)
- 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)
- # for compatibility
- set(Subversion_SVN_FOUND ${Subversion_FOUND})
|