Salome HOME
Merge branch 'master' of newgeom:newgeom.git
[modules/shaper.git] / src / GeomAPI / CMakeLists.txt
1 FIND_PACKAGE(SWIG REQUIRED)
2
3 INCLUDE(${SWIG_USE_FILE})
4 INCLUDE_DIRECTORIES(${CMAKE_CURRENT_SOURCE_DIR})
5
6 SET(PROJECT_HEADERS
7     GeomAPI.h
8     GeomAPI_Circ.h
9     GeomAPI_Circ2d.h
10     GeomAPI_Interface.h
11     GeomAPI_XY.h
12     GeomAPI_XYZ.h
13     GeomAPI_Pnt.h
14     GeomAPI_Pnt2d.h
15     GeomAPI_Lin.h
16     GeomAPI_Lin2d.h
17     GeomAPI_Dir.h
18     GeomAPI_Dir2d.h
19     GeomAPI_Pln.h
20     GeomAPI_Shape.h
21     GeomAPI_AISObject.h
22         GeomAPI_IPresentable.h
23 )
24
25 SET(PROJECT_SOURCES
26     GeomAPI_Circ.cpp
27     GeomAPI_Circ2d.cpp
28     GeomAPI_Interface.cpp
29     GeomAPI_XY.cpp
30     GeomAPI_XYZ.cpp
31     GeomAPI_Pnt.cpp
32     GeomAPI_Pnt2d.cpp
33     GeomAPI_Lin.cpp
34     GeomAPI_Lin2d.cpp
35     GeomAPI_Dir.cpp
36     GeomAPI_Dir2d.cpp
37     GeomAPI_Pln.cpp
38     GeomAPI_Shape.cpp
39     GeomAPI_AISObject.cpp
40 )
41
42 ADD_DEFINITIONS(-DGEOMAPI_EXPORTS ${CAS_DEFINITIONS})
43 ADD_LIBRARY(GeomAPI SHARED ${PROJECT_SOURCES} ${PROJECT_HEADERS})
44
45 SET(CMAKE_SWIG_FLAGS "")
46
47 SET_SOURCE_FILES_PROPERTIES(GeomAPI.i PROPERTIES CPLUSPLUS ON)
48 SET_SOURCE_FILES_PROPERTIES(GeomAPI.i PROPERTIES SWIG_DEFINITIONS "-shadow")
49
50 INCLUDE_DIRECTORIES(
51   ${CAS_INCLUDE_DIRS}
52 )
53
54 TARGET_LINK_LIBRARIES(GeomAPI ${PROJECT_LIBRARIES} ${CAS_KERNEL} ${CAS_MODELER} ${CAS_VIEWER})
55
56 SET(SWIG_SCRIPTS
57   ${CMAKE_CURRENT_BINARY_DIR}/GeomAPI.py
58 )
59
60 SET(SWIG_LINK_LIBRARIES
61   GeomAPI
62   ${PYTHON_LIBRARIES}
63 )
64
65 SWIG_ADD_MODULE(GeomAPI python GeomAPI.i ${PROJECT_HEADERS})
66 SWIG_LINK_LIBRARIES(GeomAPI ${SWIG_LINK_LIBRARIES})
67
68 IF(WIN32)
69   SET_TARGET_PROPERTIES(_GeomAPI PROPERTIES DEBUG_OUTPUT_NAME _GeomAPI_d)
70 ENDIF(WIN32)
71
72 INSTALL(TARGETS _GeomAPI DESTINATION swig)
73 INSTALL(TARGETS GeomAPI DESTINATION bin)
74 INSTALL(FILES ${SWIG_SCRIPTS} DESTINATION swig)