mirror of
https://github.com/Kitware/CMake.git
synced 2026-02-23 07:28:51 -06:00
Merge topic 'swig_add_library'
a57e7630Help: Add notes for topic 'swig_add_library'013193d0SwigTest: Update for swig_add_library and add lua exampleec1d585cUseSWIG: Do not set PREFIX property for SHARED and STATIC lua libraries4c5b3c1cUseSWIG: Do not set NO_SONAME property for SHARED and STATIC librariesd0a9d8bbUseSWIG: Add swig_add_library macro.
This commit is contained in:
8
Help/release/dev/swig_add_library.rst
Normal file
8
Help/release/dev/swig_add_library.rst
Normal file
@@ -0,0 +1,8 @@
|
||||
swig_add_library
|
||||
----------------
|
||||
|
||||
* The :module:`UseSWIG` module gained a ``swig_add_library`` command
|
||||
to give more flexibility over the old ``swig_add_module`` command.
|
||||
|
||||
* The :module:`UseSWIG` module ``swig_add_module`` command is now
|
||||
deprecated in favor of ``swig_add_library``.
|
||||
@@ -9,18 +9,22 @@
|
||||
#
|
||||
# ::
|
||||
#
|
||||
# SWIG_ADD_MODULE(name language [ files ])
|
||||
# SWIG_ADD_LIBRARY(<name>
|
||||
# [TYPE <SHARED|MODULE|STATIC>]
|
||||
# LANGUAGE <language>
|
||||
# SOURCES <file>...
|
||||
# )
|
||||
# - Define swig module with given name and specified language
|
||||
# SWIG_LINK_LIBRARIES(name [ libraries ])
|
||||
# - Link libraries to swig module
|
||||
#
|
||||
# Source files properties on module files can be set before the invocation
|
||||
# of the SWIG_ADD_MODULE macro to specify special behavior of SWIG.
|
||||
# of the SWIG_ADD_LIBRARY macro to specify special behavior of SWIG.
|
||||
#
|
||||
# The source file property CPLUSPLUS calls SWIG in c++ mode, e.g.::
|
||||
#
|
||||
# set_property(SOURCE mymod.i PROPERTY CPLUSPLUS ON)
|
||||
# swig_add_module(mymod python mymod.i)
|
||||
# swig_add_library(mymod LANGUAGE python SOURCES mymod.i)
|
||||
#
|
||||
# The source file property SWIG_FLAGS adds custom flags to the SWIG executable.
|
||||
#
|
||||
@@ -217,10 +221,40 @@ endmacro()
|
||||
# Create Swig module
|
||||
#
|
||||
macro(SWIG_ADD_MODULE name language)
|
||||
SWIG_MODULE_INITIALIZE(${name} ${language})
|
||||
message(DEPRECATION "SWIG_ADD_MODULE is deprecated. Use SWIG_ADD_LIBRARY instead.")
|
||||
swig_add_library(${name}
|
||||
LANGUAGE ${language}
|
||||
TYPE MODULE
|
||||
SOURCES ${ARGN})
|
||||
endmacro()
|
||||
|
||||
|
||||
macro(SWIG_ADD_LIBRARY name)
|
||||
|
||||
include(CMakeParseArguments)
|
||||
set(options "")
|
||||
set(oneValueArgs LANGUAGE
|
||||
TYPE)
|
||||
set(multiValueArgs SOURCES)
|
||||
cmake_parse_arguments(_SAM "${options}" "${oneValueArgs}" "${multiValueArgs}" ${ARGN})
|
||||
|
||||
if(NOT DEFINED _SAM_LANGUAGE)
|
||||
message(FATAL_ERROR "SWIG_ADD_LIBRARY: Missing LANGUAGE argument")
|
||||
endif()
|
||||
|
||||
if(NOT DEFINED _SAM_SOURCES)
|
||||
message(FATAL_ERROR "SWIG_ADD_LIBRARY: Missing SOURCES argument")
|
||||
endif()
|
||||
|
||||
if(NOT DEFINED _SAM_TYPE)
|
||||
set(_SAM_TYPE MODULE)
|
||||
endif()
|
||||
|
||||
swig_module_initialize(${name} ${_SAM_LANGUAGE})
|
||||
|
||||
set(swig_dot_i_sources)
|
||||
set(swig_other_sources)
|
||||
foreach(it ${ARGN})
|
||||
foreach(it ${_SAM_SOURCES})
|
||||
if(${it} MATCHES "\\.i$")
|
||||
set(swig_dot_i_sources ${swig_dot_i_sources} "${it}")
|
||||
else()
|
||||
@@ -237,11 +271,13 @@ macro(SWIG_ADD_MODULE name language)
|
||||
set_directory_properties(PROPERTIES
|
||||
ADDITIONAL_MAKE_CLEAN_FILES "${swig_extra_clean_files};${swig_generated_sources}")
|
||||
add_library(${SWIG_MODULE_${name}_REAL_NAME}
|
||||
MODULE
|
||||
${_SAM_TYPE}
|
||||
${swig_generated_sources}
|
||||
${swig_other_sources})
|
||||
set_target_properties(${SWIG_MODULE_${name}_REAL_NAME} PROPERTIES NO_SONAME ON)
|
||||
string(TOLOWER "${language}" swig_lowercase_language)
|
||||
if("${_SAM_TYPE}" STREQUAL "MODULE")
|
||||
set_target_properties(${SWIG_MODULE_${name}_REAL_NAME} PROPERTIES NO_SONAME ON)
|
||||
endif()
|
||||
string(TOLOWER "${_SAM_LANGUAGE}" swig_lowercase_language)
|
||||
if ("${swig_lowercase_language}" STREQUAL "octave")
|
||||
set_target_properties(${SWIG_MODULE_${name}_REAL_NAME} PROPERTIES PREFIX "")
|
||||
set_target_properties(${SWIG_MODULE_${name}_REAL_NAME} PROPERTIES SUFFIX ".oct")
|
||||
@@ -258,7 +294,9 @@ macro(SWIG_ADD_MODULE name language)
|
||||
set_target_properties (${SWIG_MODULE_${name}_REAL_NAME} PROPERTIES SUFFIX ".jnilib")
|
||||
endif ()
|
||||
elseif ("${swig_lowercase_language}" STREQUAL "lua")
|
||||
set_target_properties(${SWIG_MODULE_${name}_REAL_NAME} PROPERTIES PREFIX "")
|
||||
if("${_SAM_TYPE}" STREQUAL "MODULE")
|
||||
set_target_properties(${SWIG_MODULE_${name}_REAL_NAME} PROPERTIES PREFIX "")
|
||||
endif()
|
||||
elseif ("${swig_lowercase_language}" STREQUAL "python")
|
||||
# this is only needed for the python case where a _modulename.so is generated
|
||||
set_target_properties(${SWIG_MODULE_${name}_REAL_NAME} PROPERTIES PREFIX "")
|
||||
|
||||
@@ -7,6 +7,7 @@ project(example_${language}_class)
|
||||
find_package(SWIG REQUIRED)
|
||||
include(${SWIG_USE_FILE})
|
||||
|
||||
unset(SWIG_LANG_TYPE)
|
||||
if(${language} MATCHES python)
|
||||
find_package(PythonLibs)
|
||||
include_directories(${PYTHON_INCLUDE_PATH})
|
||||
@@ -38,6 +39,12 @@ if(${language} MATCHES pike)
|
||||
include_directories(${PIKE_INCLUDE_PATH})
|
||||
set(SWIG_LANG_LIBRARIES ${PIKE_LIBRARY})
|
||||
endif()
|
||||
if(${language} MATCHES lua)
|
||||
find_package(Lua)
|
||||
include_directories(${LUA_INCLUDE_DIR})
|
||||
set(SWIG_LANG_TYPE TYPE SHARED)
|
||||
set(SWIG_LANG_LIBRARIES ${LUA_LIBRARIES})
|
||||
endif()
|
||||
|
||||
include_directories(${CMAKE_CURRENT_SOURCE_DIR})
|
||||
|
||||
@@ -45,6 +52,8 @@ set(CMAKE_SWIG_FLAGS "")
|
||||
|
||||
set_source_files_properties(example.i PROPERTIES CPLUSPLUS ON)
|
||||
set_source_files_properties(example.i PROPERTIES SWIG_FLAGS "-includeall")
|
||||
SWIG_ADD_MODULE(example "${language}"
|
||||
example.i example.cxx)
|
||||
SWIG_ADD_LIBRARY(example
|
||||
LANGUAGE "${language}"
|
||||
${SWIG_LANG_TYPE}
|
||||
SOURCES example.i example.cxx)
|
||||
SWIG_LINK_LIBRARIES(example ${SWIG_LANG_LIBRARIES})
|
||||
|
||||
Reference in New Issue
Block a user