IF(${CMAKE_MAJOR_VERSION}.${CMAKE_MINOR_VERSION} GREATER 1.9)
+ # We need to pass that to swig to be sure all modules are generated in the proper dir
+ SET(CMAKE_SWIG_FLAGS "-outdir ${GDCM_BINARY_DIR}/gdcmPython")
+ # Looks like a bug to me in cmake 2.0.x:
+ SEPARATE_ARGUMENTS(CMAKE_SWIG_FLAGS)
+
FIND_PACKAGE(SWIG REQUIRED)
INCLUDE(${SWIG_USE_FILE})
- #INCLUDE_DIRECTORIES(${CMAKE_CURRENT_SOURCE_DIR})
- #SET(CMAKE_SWIG_FLAGS "")
-
#SET_SOURCE_FILES_PROPERTIES(gdcm.i PROPERTIES PYTHON ON)
SET_SOURCE_FILES_PROPERTIES(gdcm.i PROPERTIES CPLUSPLUS ON)
# Setting SWIG_FLAGS to "-includeall" at the following line looks like
- # a bad idea since swig tries to reculsively include all the referenced
+ # a bad idea since swig tries to recursively include all the referenced
# files, "including" the C++ <sstream>, <list>, <map>... Of course swig
# has no way of finding the path to those files (unless it is told by
# cmake) since they are related to the compiler installation layout.
SET_SOURCE_FILES_PROPERTIES(gdcm.i PROPERTIES SWIG_FLAGS "")
SWIG_ADD_MODULE(gdcm python gdcm.i) #gdcm_wrap.cxx
SWIG_LINK_LIBRARIES(gdcm gdcm ${PYTHON_LIBRARIES})
-
- #SWIG_GET_EXTRA_OUTPUT_FILES(python foobar "/usr/" "gdcm" )
- #MESSAGE(FATAL_ERROR ${swig_generated_file_fullname})
- #MESSAGE(FATAL_ERROR ${swig_source_file_fullname})
-
- # Swig creates a gdcm.py file put it in the right place, if only cmake
- # was able to do stuff properly ...
- ADD_CUSTOM_TARGET( CMAKE_S____ ALL)
- ADD_CUSTOM_COMMAND(
- TARGET CMAKE_S____
- POST_BUILD
- COMMAND ${CMAKE_COMMAND}
- ARGS -E copy
- ${GDCM_BINARY_DIR}/gdcmPython/gdcm.py
- ${GDCM_BINARY_DIR}/bin/gdcm.py
- )
+ 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
# VTK Wrapping
#
IF(GDCM_VTK)
+ # Include the VTK library
+ INCLUDE(${VTK_USE_FILE})
+
INCLUDE_DIRECTORIES(
${GDCM_SOURCE_DIR}/vtk
)
ENDIF (GDCM_WRAP_PYTHON)
ENDIF(GDCM_VTK)
- # generate a setup.py according to VTK installation
- # put it in subdir in order to not override old one
-
- GET_FILENAME_COMPONENT(VTKPATH ${VTK_DIR}/../../ ABSOLUTE)
- CONFIGURE_FILE(
- ${GDCM_SOURCE_DIR}/gdcmPython/setup.py.in
- ${GDCM_BINARY_DIR}/setup.py
- )
+# generate a setup.py according to VTK installation
+# put it in subdir in order to not override old one
+
+GET_FILENAME_COMPONENT(VTKPATH ${VTK_DIR}/../../ ABSOLUTE)
+CONFIGURE_FILE(
+ ${GDCM_SOURCE_DIR}/gdcmPython/setup.py.in
+ ${GDCM_BINARY_DIR}/setup.py
+)
#-----------------------------------------------------------------------------
# Install stuff:
# Create a gdcm.pth file:
+FILE(WRITE ${GDCM_BINARY_DIR}/gdcmPython/gdcmVersion.py
+ "gdcmVERSION=\"${GDCM_VERSION}\"\n"
+ )
+
FILE(WRITE ${GDCM_BINARY_DIR}/gdcmPython/gdcm.pth
"gdcmPython\n"
)
FILE(WRITE ${GDCM_BINARY_DIR}/gdcmPython/__init__.py
+ "__all__ = [\"core\",\n"
+ " \"vtk\",\n"
+ " ]\n"
+ )
+
+FILE(WRITE ${GDCM_BINARY_DIR}/gdcmPython/core.py
"import gdcm\n"
+ "GDCM_DATA_PATH =\"${GDCM_DATA_ROOT}\"\n"
+ "GDCM_TEST_DATA_PATH=\"${GDCM_DATA_ROOT}\"\n"
)
IF(GDCM_VTK)
- FILE(APPEND ${GDCM_BINARY_DIR}/gdcmPython/__init__.py
+ FILE(WRITE ${GDCM_BINARY_DIR}/gdcmPython/vtk.py
"import os\n"
"if os.name == 'posix':\n"
" from libvtkgdcmPython import *\n"
"else:\n"
" from vtkgdcmPython import *\n"
+ "GDCM_DATA_PATH =\"${GDCM_DATA_ROOT}\"\n"
+ "GDCM_TEST_DATA_PATH=\"${GDCM_DATA_ROOT}\"\n"
)
ENDIF(GDCM_VTK)