mirror of
https://github.com/Kitware/CMake.git
synced 2025-12-30 18:29:37 -06:00
- Added examples section, highlighting the imported target usage. - Synced the module documentation with other similar find modules. - Extended gettext and intl introduction. - Moved FindGettext module to the "See Also" section.
206 lines
6.1 KiB
CMake
206 lines
6.1 KiB
CMake
# 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)
|