1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798 |
- # Distributed under the OSI-approved BSD 3-Clause License. See accompanying
- # file Copyright.txt or https://cmake.org/licensing for details.
- #[=======================================================================[.rst:
- FindGit
- -------
- The module defines the following ``IMPORTED`` targets (when
- :prop_gbl:`CMAKE_ROLE` is ``PROJECT``):
- ``Git::Git``
- Executable of the Git command-line client.
- The module defines the following variables:
- ``GIT_EXECUTABLE``
- Path to Git command-line client.
- ``Git_FOUND``, ``GIT_FOUND``
- True if the Git command-line client was found.
- ``GIT_VERSION_STRING``
- The version of Git found.
- Example usage:
- .. code-block:: cmake
- find_package(Git)
- if(Git_FOUND)
- message("Git found: ${GIT_EXECUTABLE}")
- endif()
- #]=======================================================================]
- # Look for 'git' or 'eg' (easy git)
- #
- set(git_names git eg)
- # Prefer .cmd variants on Windows unless running in a Makefile
- # in the MSYS shell.
- #
- if(CMAKE_HOST_WIN32)
- if(NOT CMAKE_GENERATOR MATCHES "MSYS")
- set(git_names git.cmd git eg.cmd eg)
- # GitHub search path for Windows
- file(GLOB github_path
- "$ENV{LOCALAPPDATA}/Github/PortableGit*/cmd"
- "$ENV{LOCALAPPDATA}/Github/PortableGit*/bin"
- )
- # SourceTree search path for Windows
- set(_git_sourcetree_path "$ENV{LOCALAPPDATA}/Atlassian/SourceTree/git_local/bin")
- endif()
- endif()
- # First search the PATH and specific locations.
- find_program(GIT_EXECUTABLE
- NAMES ${git_names}
- PATHS ${github_path} ${_git_sourcetree_path}
- DOC "Git command line client"
- )
- if(CMAKE_HOST_WIN32)
- # Now look for installations in Git/ directories under typical installation
- # prefixes on Windows. Exclude PATH from this search because VS 2017's
- # command prompt happens to have a PATH entry with a Git/ subdirectory
- # containing a minimal git not meant for general use.
- find_program(GIT_EXECUTABLE
- NAMES ${git_names}
- PATH_SUFFIXES Git/cmd Git/bin
- NO_SYSTEM_ENVIRONMENT_PATH
- DOC "Git command line client"
- )
- endif()
- mark_as_advanced(GIT_EXECUTABLE)
- unset(git_names)
- unset(_git_sourcetree_path)
- if(GIT_EXECUTABLE)
- execute_process(COMMAND ${GIT_EXECUTABLE} --version
- OUTPUT_VARIABLE git_version
- ERROR_QUIET
- OUTPUT_STRIP_TRAILING_WHITESPACE)
- if (git_version MATCHES "^git version [0-9]")
- string(REPLACE "git version " "" GIT_VERSION_STRING "${git_version}")
- endif()
- unset(git_version)
- get_property(_findgit_role GLOBAL PROPERTY CMAKE_ROLE)
- if(_findgit_role STREQUAL "PROJECT" AND NOT TARGET Git::Git)
- add_executable(Git::Git IMPORTED)
- set_property(TARGET Git::Git PROPERTY IMPORTED_LOCATION "${GIT_EXECUTABLE}")
- endif()
- endif()
- include(${CMAKE_CURRENT_LIST_DIR}/FindPackageHandleStandardArgs.cmake)
- find_package_handle_standard_args(Git
- REQUIRED_VARS GIT_EXECUTABLE
- VERSION_VAR GIT_VERSION_STRING)
|