|
|
@@ -5,25 +5,49 @@
|
|
|
FindSWIG
|
|
|
--------
|
|
|
|
|
|
-Find Simplified Wrapper and Interface Generator (SWIG)
|
|
|
+Find the Simplified Wrapper and Interface Generator (SWIG_) executable.
|
|
|
|
|
|
-This module finds an installed SWIG. It sets the following variables:
|
|
|
-
|
|
|
-::
|
|
|
-
|
|
|
- SWIG_FOUND - set to "True" if SWIG is found
|
|
|
- SWIG_DIR - the directory where swig is installed
|
|
|
- SWIG_EXECUTABLE - the path to the swig executable
|
|
|
- SWIG_VERSION - the version number of the swig executable
|
|
|
|
|
|
+This module finds an installed SWIG and determines its version. If a
|
|
|
+``COMPONENTS`` or ``OPTIONAL_COMPONENTS`` argument is given to ``find_package``,
|
|
|
+it will also determine supported target languages. The module sents the
|
|
|
+following variables:
|
|
|
|
|
|
+``SWIG_FOUND``
|
|
|
+ Whether SWIG and any required components were found on the system.
|
|
|
+``SWIG_EXECUTABLE``
|
|
|
+ Path to the SWIG executable.
|
|
|
+``SWIG_DIR``
|
|
|
+ Path to the installed SWIG ``Lib`` directory (result of ``swig -swiglib``).
|
|
|
+``SWIG_VERSION``
|
|
|
+ SWIG executable version (result of ``swig -version``).
|
|
|
+``SWIG_<lang>_FOUND``
|
|
|
+ If ``COMPONENTS`` or ``OPTIONAL_COMPONENTS`` are requested, each available
|
|
|
+ target language ``<lang>`` (lowercase) will be set to TRUE.
|
|
|
|
|
|
-The minimum required version of SWIG can be specified using the
|
|
|
-standard syntax, e.g. :command:`find_package(SWIG 1.1)`
|
|
|
+Any ``COMPONENTS`` given to ``find_package`` should be the names of supported
|
|
|
+target languages as provided to the LANGUAGE argument of ``swig_add_library``,
|
|
|
+such as ``python`` or ``perl5``. Language names *must* be lowercase.
|
|
|
|
|
|
All information is collected from the ``SWIG_EXECUTABLE``, so the version
|
|
|
to be found can be changed from the command line by means of setting
|
|
|
-``SWIG_EXECUTABLE``
|
|
|
+``SWIG_EXECUTABLE``.
|
|
|
+
|
|
|
+Example usage requiring SWIG 4.0 or higher and Python language support, with
|
|
|
+optional Fortran support:
|
|
|
+
|
|
|
+.. code-block:: cmake
|
|
|
+
|
|
|
+ find_package(SWIG 4.0 COMPONENTS python OPTIONAL_COMPONENTS fortran)
|
|
|
+ if(SWIG_FOUND)
|
|
|
+ message("SWIG found: ${SWIG_EXECUTABLE}")
|
|
|
+ if(NOT SWIG_fortran_FOUND)
|
|
|
+ message(WARNING "SWIG Fortran bindings cannot be generated")
|
|
|
+ endif()
|
|
|
+ endif()
|
|
|
+
|
|
|
+.. _`SWIG`: http://swig.org
|
|
|
+
|
|
|
#]=======================================================================]
|
|
|
|
|
|
find_program(SWIG_EXECUTABLE NAMES swig4.0 swig3.0 swig2.0 swig)
|
|
|
@@ -58,10 +82,29 @@ if(SWIG_EXECUTABLE)
|
|
|
endif()
|
|
|
endif()
|
|
|
endif()
|
|
|
+
|
|
|
+ if(SWIG_FIND_COMPONENTS)
|
|
|
+ execute_process(COMMAND ${SWIG_EXECUTABLE} -help
|
|
|
+ OUTPUT_VARIABLE SWIG_swighelp_output
|
|
|
+ ERROR_VARIABLE SWIG_swighelp_error
|
|
|
+ RESULT_VARIABLE SWIG_swighelp_result)
|
|
|
+ if(SWIG_swighelp_result)
|
|
|
+ message(SEND_ERROR "Command \"${SWIG_EXECUTABLE} -help\" failed with output:\n${SWIG_swiglib_error}")
|
|
|
+ else()
|
|
|
+ string(REPLACE "\n" ";" SWIG_swighelp_output "${SWIG_swighelp_output}")
|
|
|
+ foreach(SWIG_line IN LISTS SWIG_swighelp_output)
|
|
|
+ if(SWIG_line MATCHES "-([A-Za-z0-9_]+) +- *Generate.*wrappers")
|
|
|
+ set(SWIG_${CMAKE_MATCH_1}_FOUND TRUE)
|
|
|
+ endif()
|
|
|
+ endforeach()
|
|
|
+ endif()
|
|
|
+ endif()
|
|
|
endif()
|
|
|
|
|
|
include(${CMAKE_CURRENT_LIST_DIR}/FindPackageHandleStandardArgs.cmake)
|
|
|
-FIND_PACKAGE_HANDLE_STANDARD_ARGS(SWIG REQUIRED_VARS SWIG_EXECUTABLE SWIG_DIR
|
|
|
- VERSION_VAR SWIG_VERSION )
|
|
|
+find_package_handle_standard_args(
|
|
|
+ SWIG HANDLE_COMPONENTS
|
|
|
+ REQUIRED_VARS SWIG_EXECUTABLE SWIG_DIR
|
|
|
+ VERSION_VAR SWIG_VERSION)
|
|
|
|
|
|
mark_as_advanced(SWIG_DIR SWIG_VERSION SWIG_EXECUTABLE)
|