mirror of
https://github.com/Kitware/CMake.git
synced 2025-10-14 02:08:27 +08:00

This updates the following modules: - CheckCSourceRuns - CheckCXXSourceRuns - CheckFortranSourceRuns - CheckOBJCSourceRuns - CheckOBJCXXSourceRuns - CheckSourceRuns Changes: - Added intro code blocks showing how to include these modules. - Used word "command" instead of "macro". - Added "Commands" sections to have a clearer overview of the modules at first encounter. - Reworded commands descriptions and arguments a bit. - Added a rubric title for variables that affect the checks. - Added "Examples" sections. - Added "See Also" sections. - Added few more examples in the CheckSourceRuns module to show how to use this module with different languages, `CMAKE_REQUIRED_*` variables, and mentioned bracket argument syntax a bit.
95 lines
2.6 KiB
CMake
95 lines
2.6 KiB
CMake
# Distributed under the OSI-approved BSD 3-Clause License. See accompanying
|
|
# file LICENSE.rst or https://cmake.org/licensing for details.
|
|
|
|
#[=======================================================================[.rst:
|
|
CheckOBJCSourceRuns
|
|
-------------------
|
|
|
|
.. versionadded:: 3.16
|
|
|
|
This module provides a command to check whether an Objective-C source can
|
|
be built and run.
|
|
|
|
Load this module in a CMake project with:
|
|
|
|
.. code-block:: cmake
|
|
|
|
include(CheckOBJCSourceRuns)
|
|
|
|
Commands
|
|
^^^^^^^^
|
|
|
|
This module provides the following command:
|
|
|
|
.. command:: check_objc_source_runs
|
|
|
|
Checks once whether the given Objective-C source code compiles and links
|
|
into an executable that can subsequently be run:
|
|
|
|
.. code-block:: cmake
|
|
|
|
check_objc_source_runs(<code> <variable>)
|
|
|
|
The Objective-C source supplied in ``<code>`` must contain at least a
|
|
``main()`` function. The result of the check is stored in the internal
|
|
cache variable specified by ``<variable>``. If the code builds and runs
|
|
with exit code ``0``, success is indicated by a boolean true value.
|
|
Failure to build or run is indicated by a boolean false value, such as an
|
|
empty string or an error message.
|
|
|
|
.. rubric:: Variables Affecting the Check
|
|
|
|
The following variables may be set before calling this command to modify
|
|
the way the check is run:
|
|
|
|
.. include:: /module/include/CMAKE_REQUIRED_FLAGS.rst
|
|
|
|
.. include:: /module/include/CMAKE_REQUIRED_DEFINITIONS.rst
|
|
|
|
.. include:: /module/include/CMAKE_REQUIRED_INCLUDES.rst
|
|
|
|
.. include:: /module/include/CMAKE_REQUIRED_LINK_OPTIONS.rst
|
|
|
|
.. include:: /module/include/CMAKE_REQUIRED_LIBRARIES.rst
|
|
|
|
.. include:: /module/include/CMAKE_REQUIRED_LINK_DIRECTORIES.rst
|
|
|
|
.. include:: /module/include/CMAKE_REQUIRED_QUIET.rst
|
|
|
|
Examples
|
|
^^^^^^^^
|
|
|
|
In the following example, this module is used to check whether the provided
|
|
Objective-C source code builds and runs. Result of the check is stored in
|
|
an internal cache variable ``HAVE_WORKING_CODE``.
|
|
|
|
.. code-block:: cmake
|
|
|
|
include(CheckOBJCSourceRuns)
|
|
|
|
check_objc_source_runs("
|
|
#import <Foundation/Foundation.h>
|
|
int main()
|
|
{
|
|
NSObject *foo;
|
|
return 0;
|
|
}
|
|
" HAVE_WORKING_CODE)
|
|
|
|
See Also
|
|
^^^^^^^^
|
|
|
|
* The :module:`CheckSourceRuns` module for a more general command syntax.
|
|
* The :module:`CheckSourceCompiles` module to check whether a source code
|
|
can be built.
|
|
#]=======================================================================]
|
|
|
|
include_guard(GLOBAL)
|
|
include(Internal/CheckSourceRuns)
|
|
|
|
macro(CHECK_OBJC_SOURCE_RUNS SOURCE VAR)
|
|
set(_CheckSourceRuns_old_signature 1)
|
|
cmake_check_source_runs(OBJC "${SOURCE}" ${VAR} ${ARGN})
|
|
unset(_CheckSourceRuns_old_signature)
|
|
endmacro()
|