-#-----------------------------------------------------------------------------
-# As of 09/10/2003 there was no FindSWIG.cmake
-# later we should use SWIG instead of swig
-# Build our custom command :
-ADD_CUSTOM_COMMAND(
- SOURCE ${GDCM_SOURCE_DIR}/gdcmPython/gdcm.i
- COMMAND swig
- ARGS -python -c++ -I${GDCM_SOURCE_DIR}/src -o
- ${GDCM_BINARY_DIR}/gdcmPython/gdcm_wrap.cxx
- ${GDCM_SOURCE_DIR}/gdcmPython/gdcm.i
- TARGET pygdcm
- OUTPUTS ${GDCM_BINARY_DIR}/gdcmPython/gdcm_wrap.cxx
- COMMENT "Generating gdcm_wrap.cxx based on gdcm.i"
-)
+ SET(GDCM_CXX_FLAGS ${CMAKE_SWIG_FLAGS})
+ # Get rid of -Wall / -W / -pedantic if exist
+ SET(CMAKE_CXX_FLAGS "")
+ # I guess I need to put them back on the this file:
+ SET_SOURCE_FILES_PROPERTIES(${GDCM_BINARY_DIR}/gdcmPython/gdcm_wrap.cxx
+ PROPERTIES COMPILE_FLAGS "")
+# SET_TARGET_PROPERTIES(${GDCM_BINARY_DIR}/gdcmPython/gdcm_wrap.cxx
+# PROPERTIES CMAKE_CXX_FLAGS "-foo")
+
+ELSE(${CMAKE_MAJOR_VERSION}.${CMAKE_MINOR_VERSION} GREATER 1.9)
+
+ # As of 09/10/2003 there was no FindSWIG.cmake
+ # later we should use SWIG instead of swig
+ FIND_PROGRAM(SWIG_EXECUTABLE
+ NAMES swig-1.3 swig
+ )
+
+ IF(NOT SWIG_EXECUTABLE)
+ MESSAGE(FATAL_ERROR "Swig could not be found wrapping is impossible")
+ ENDIF(NOT SWIG_EXECUTABLE)
+
+ # Build our custom command :
+ ADD_CUSTOM_COMMAND(
+ OUTPUT ${GDCM_BINARY_DIR}/gdcmPython/gdcm_wrap.cxx
+ COMMAND ${SWIG_EXECUTABLE}
+ ARGS -python -c++ -I${GDCM_SOURCE_DIR}/src -o
+ ${GDCM_BINARY_DIR}/gdcmPython/gdcm_wrap.cxx
+ ${GDCM_SOURCE_DIR}/gdcmPython/gdcm.i
+ DEPENDS ${GDCM_SOURCE_DIR}/gdcmPython/gdcm.i
+ COMMENT "Generating gdcm_wrap.cxx/gdcm.py based on gdcm.i"
+ )
+ # Since the file gdcm_wrap.cxx does not exist, mark it as GENERATED:
+ SET_SOURCE_FILES_PROPERTIES(${GDCM_BINARY_DIR}/gdcmPython/gdcm_wrap.cxx GENERATED)
+
+ ADD_LIBRARY(pygdcm gdcm_wrap.cxx)
+ TARGET_LINK_LIBRARIES(pygdcm
+ ${PYTHON_LIBRARY}
+ gdcm
+ )
+ # http://www.cmake.org/pipermail/cmake/2003-August/004190.html
+ #SET_TARGET_PROPERTIES(pygdcm PROPERTIES PREFIX "_")
+
+ # This swig command will also outputs gdcm.py :
+ SET_SOURCE_FILES_PROPERTIES(${GDCM_BINARY_DIR}/gdcmPython/gdcm.py GENERATED)
+
+ # Instead of a simple copy operation let create our own gdcm.py file:
+ # First read what swig dumped:
+ IF(EXISTS ${GDCM_BINARY_DIR}/gdcmPython/gdcm.py)
+ FILE(READ ${GDCM_BINARY_DIR}/gdcmPython/gdcm.py SWIG_GDCM_PY)
+ ENDIF(EXISTS ${GDCM_BINARY_DIR}/gdcmPython/gdcm.py)
+
+ # Then create the gdcm.py = gdcmVersion.py + gdcm.py (swig) file:
+ FILE(WRITE ${GDCM_BINARY_DIR}/bin/gdcmVersion.py
+ "import os\n"
+ "gdcmVERSION=\"${GDCM_VERSION}\"\n"
+ "GDCM_DATA_PATH=\"${GDCM_DATA_ROOT}\"\n\n"
+ ${SWIG_GDCM_PY}
+ )
+
+ # Seems like they want instead a file called gdcmPython.py
+ # Thus add the custom command to copy it to proper location:
+# ADD_CUSTOM_COMMAND(
+# TARGET pygdcm
+# POST_BUILD
+# COMMAND ${CMAKE_COMMAND}
+# ARGS -E copy
+# ${GDCM_BINARY_DIR}/bin/gdcm.py
+# ${GDCM_BINARY_DIR}/bin/gdcmPython.py
+# )
+
+ # Here comes the hack to rename the library to a more 'swig' compliant scheme"
+ SET(LIB_NAME ${CMAKE_SHARED_LIBRARY_PREFIX}pygdcm${CMAKE_SHARED_LIBRARY_SUFFIX})
+ SET(EXE_DIR ${GDCM_BINARY_DIR}/Executable)
+ IF(EXECUTABLE_OUTPUT_PATH)
+ SET(EXE_DIR ${EXECUTABLE_OUTPUT_PATH})
+ ENDIF(EXECUTABLE_OUTPUT_PATH)
+ SET(LIB_DIR ${GDCM_BINARY_DIR}/Library/Shared)
+ IF(LIBRARY_OUTPUT_PATH)
+ SET(LIB_DIR ${LIBRARY_OUTPUT_PATH})
+ ENDIF(LIBRARY_OUTPUT_PATH)
+
+ IF(WIN32 OR APPLE)
+ SET(SHARED_MUST_BE_IN_EXE_DIR 1)
+ ENDIF(WIN32 OR APPLE)