|  | # Distributed under the OSI-approved BSD 3-Clause License.  See accompanying | 
|  | # file LICENSE.rst or https://cmake.org/licensing for details. | 
|  |  | 
|  | #[=======================================================================[.rst: | 
|  | FindIntl | 
|  | -------- | 
|  |  | 
|  | .. versionadded:: 3.2 | 
|  |  | 
|  | Finds internationalization support that includes message translation functions | 
|  | such as ``gettext()``.  These functions originate from the GNU ``libintl`` | 
|  | library, which is part of the GNU gettext utilities, but may also be provided by | 
|  | the standard C library. | 
|  |  | 
|  | Imported Targets | 
|  | ^^^^^^^^^^^^^^^^ | 
|  |  | 
|  | This module provides the following :ref:`Imported Targets`: | 
|  |  | 
|  | ``Intl::Intl`` | 
|  | .. versionadded:: 3.20 | 
|  |  | 
|  | Target encapsulating the Intl usage requirements, available if Intl is found. | 
|  |  | 
|  | Result Variables | 
|  | ^^^^^^^^^^^^^^^^ | 
|  |  | 
|  | This module defines the following variables: | 
|  |  | 
|  | ``Intl_FOUND`` | 
|  | Boolean indicating whether the Intl is found. | 
|  |  | 
|  | ``Intl_INCLUDE_DIRS`` | 
|  | Include directories containing headers needed to use Intl. | 
|  |  | 
|  | ``Intl_LIBRARIES`` | 
|  | The libraries needed to link against to use Intl. | 
|  |  | 
|  | ``Intl_VERSION`` | 
|  | .. versionadded:: 3.21 | 
|  |  | 
|  | The version of the found Intl implementation or library, in the format | 
|  | ``x.y.z``. | 
|  |  | 
|  | .. note:: | 
|  | Some Intl implementations don't embed the version in their header files. | 
|  | In this case the variables ``Intl_VERSION*`` will be empty. | 
|  |  | 
|  | ``Intl_VERSION_MAJOR`` | 
|  | .. versionadded:: 3.21 | 
|  |  | 
|  | The major version of Intl found. | 
|  |  | 
|  | ``Intl_VERSION_MINOR`` | 
|  | .. versionadded:: 3.21 | 
|  |  | 
|  | The minor version of Intl found. | 
|  |  | 
|  | ``Intl_VERSION_PATCH`` | 
|  | .. versionadded:: 3.21 | 
|  |  | 
|  | The patch version of Intl found. | 
|  |  | 
|  | Cache Variables | 
|  | ^^^^^^^^^^^^^^^ | 
|  |  | 
|  | The following cache variables may also be set: | 
|  |  | 
|  | ``Intl_INCLUDE_DIR`` | 
|  | The directory containing the ``libintl.h`` header file. | 
|  |  | 
|  | ``Intl_LIBRARY`` | 
|  | The path to the Intl library (if any). | 
|  |  | 
|  | ``Intl_IS_BUILT_IN`` | 
|  | .. versionadded:: 3.20 | 
|  |  | 
|  | Boolean indicating whether the found Intl functionality is provided by the | 
|  | standard C library rather than a separate ``libintl`` library. | 
|  |  | 
|  | .. note:: | 
|  | On some platforms, such as Linux with GNU libc, the gettext functions are | 
|  | present in the C standard library and libintl is not required.  The | 
|  | ``Intl_LIBRARY`` and ``Intl_INCLUDE_DIR`` will be empty in this case. | 
|  |  | 
|  | Examples | 
|  | ^^^^^^^^ | 
|  |  | 
|  | Finding the Intl support and linking the imported target for use in a project: | 
|  |  | 
|  | .. code-block:: cmake | 
|  |  | 
|  | find_package(Intl) | 
|  | target_link_libraries(app PRIVATE Intl::Intl) | 
|  |  | 
|  | See Also | 
|  | ^^^^^^^^ | 
|  |  | 
|  | * The :module:`FindGettext` module to find and use the GNU gettext tools | 
|  | (``msgmerge``, ``msgfmt``, etc.). | 
|  | #]=======================================================================] | 
|  |  | 
|  | cmake_policy(PUSH) | 
|  | cmake_policy(SET CMP0159 NEW) # file(STRINGS) with REGEX updates CMAKE_MATCH_<n> | 
|  |  | 
|  | include(${CMAKE_CURRENT_LIST_DIR}/CMakePushCheckState.cmake) | 
|  | if(CMAKE_C_COMPILER_LOADED) | 
|  | include(${CMAKE_CURRENT_LIST_DIR}/CheckCSourceCompiles.cmake) | 
|  | elseif(CMAKE_CXX_COMPILER_LOADED) | 
|  | include(${CMAKE_CURRENT_LIST_DIR}/CheckCXXSourceCompiles.cmake) | 
|  | else() | 
|  | # If neither C nor CXX are loaded, implicit intl makes no sense. | 
|  | set(Intl_IS_BUILT_IN FALSE) | 
|  | endif() | 
|  |  | 
|  | # Check if Intl is built in to the C library. | 
|  | if(NOT DEFINED Intl_IS_BUILT_IN) | 
|  | if(NOT DEFINED Intl_INCLUDE_DIR AND NOT DEFINED Intl_LIBRARY) | 
|  | cmake_push_check_state(RESET) | 
|  | set(CMAKE_REQUIRED_QUIET TRUE) | 
|  | set(Intl_IMPLICIT_TEST_CODE [[ | 
|  | #include <libintl.h> | 
|  | int main(void) { | 
|  | gettext(""); | 
|  | dgettext("", ""); | 
|  | dcgettext("", "", 0); | 
|  | return 0; | 
|  | } | 
|  | ]]) | 
|  | if(CMAKE_C_COMPILER_LOADED) | 
|  | check_c_source_compiles("${Intl_IMPLICIT_TEST_CODE}" Intl_IS_BUILT_IN) | 
|  | else() | 
|  | check_cxx_source_compiles("${Intl_IMPLICIT_TEST_CODE}" Intl_IS_BUILT_IN) | 
|  | endif() | 
|  | cmake_pop_check_state() | 
|  | else() | 
|  | set(Intl_IS_BUILT_IN FALSE) | 
|  | endif() | 
|  | endif() | 
|  |  | 
|  | set(_Intl_REQUIRED_VARS) | 
|  | if(Intl_IS_BUILT_IN) | 
|  | set(_Intl_REQUIRED_VARS _Intl_IS_BUILT_IN_MSG) | 
|  | set(_Intl_IS_BUILT_IN_MSG "built in to C library") | 
|  | else() | 
|  | set(_Intl_REQUIRED_VARS Intl_LIBRARY Intl_INCLUDE_DIR) | 
|  |  | 
|  | find_path(Intl_INCLUDE_DIR | 
|  | NAMES "libintl.h" | 
|  | DOC "libintl include directory") | 
|  | mark_as_advanced(Intl_INCLUDE_DIR) | 
|  |  | 
|  | find_library(Intl_LIBRARY | 
|  | NAMES "intl" "libintl" | 
|  | NAMES_PER_DIR | 
|  | DOC "libintl libraries (if not in the C library)") | 
|  | mark_as_advanced(Intl_LIBRARY) | 
|  | endif() | 
|  |  | 
|  | # NOTE: glibc's libintl.h does not define LIBINTL_VERSION | 
|  | if(Intl_INCLUDE_DIR AND EXISTS "${Intl_INCLUDE_DIR}/libintl.h") | 
|  | file(STRINGS ${Intl_INCLUDE_DIR}/libintl.h Intl_VERSION_DEFINE REGEX "LIBINTL_VERSION (.*)") | 
|  |  | 
|  | if(Intl_VERSION_DEFINE MATCHES "(0x[A-Fa-f0-9]+)") | 
|  | set(Intl_VERSION_NUMBER "${CMAKE_MATCH_1}") | 
|  | # encoding -> version number: (major<<16) + (minor<<8) + patch | 
|  | math(EXPR Intl_VERSION_MAJOR "${Intl_VERSION_NUMBER} >> 16" OUTPUT_FORMAT HEXADECIMAL) | 
|  | math(EXPR Intl_VERSION_MINOR "(${Intl_VERSION_NUMBER} - (${Intl_VERSION_MAJOR} << 16)) >> 8" OUTPUT_FORMAT HEXADECIMAL) | 
|  | math(EXPR Intl_VERSION_PATCH "${Intl_VERSION_NUMBER} - ((${Intl_VERSION_MAJOR} << 16) + (${Intl_VERSION_MINOR} << 8))" OUTPUT_FORMAT HEXADECIMAL) | 
|  |  | 
|  | math(EXPR Intl_VERSION_MAJOR "${Intl_VERSION_MAJOR}" OUTPUT_FORMAT DECIMAL) | 
|  | math(EXPR Intl_VERSION_MINOR "${Intl_VERSION_MINOR}" OUTPUT_FORMAT DECIMAL) | 
|  | math(EXPR Intl_VERSION_PATCH "${Intl_VERSION_PATCH}" OUTPUT_FORMAT DECIMAL) | 
|  | set(Intl_VERSION "${Intl_VERSION_MAJOR}.${Intl_VERSION_MINOR}.${Intl_VERSION_PATCH}") | 
|  | endif() | 
|  |  | 
|  | unset(Intl_VERSION_DEFINE) | 
|  | unset(Intl_VERSION_NUMBER) | 
|  | endif() | 
|  |  | 
|  | include(FindPackageHandleStandardArgs) | 
|  | find_package_handle_standard_args(Intl | 
|  | REQUIRED_VARS ${_Intl_REQUIRED_VARS} | 
|  | VERSION_VAR Intl_VERSION | 
|  | FAIL_MESSAGE "Failed to find Gettext libintl") | 
|  | unset(_Intl_REQUIRED_VARS) | 
|  | unset(_Intl_IS_BUILT_IN_MSG) | 
|  |  | 
|  | if(Intl_FOUND) | 
|  | if(Intl_IS_BUILT_IN) | 
|  | set(Intl_INCLUDE_DIRS "") | 
|  | set(Intl_LIBRARIES "") | 
|  | else() | 
|  | set(Intl_INCLUDE_DIRS "${Intl_INCLUDE_DIR}") | 
|  | set(Intl_LIBRARIES "${Intl_LIBRARY}") | 
|  | endif() | 
|  | if(NOT TARGET Intl::Intl) | 
|  | add_library(Intl::Intl INTERFACE IMPORTED) | 
|  | set_target_properties(Intl::Intl PROPERTIES | 
|  | INTERFACE_INCLUDE_DIRECTORIES "${Intl_INCLUDE_DIRS}" | 
|  | INTERFACE_LINK_LIBRARIES "${Intl_LIBRARIES}") | 
|  | endif() | 
|  | endif() | 
|  |  | 
|  | cmake_policy(POP) |