mirror of
https://git.salome-platform.org/gitpub/modules/smesh.git
synced 2024-12-25 08:50:35 +05:00
split wasm_to_py from wasm_to_js
- disable wasm_to_js which needs pthread and boost headers
This commit is contained in:
parent
833235848b
commit
fa8979eb56
@ -69,7 +69,8 @@ IF(SALOME_BUILD_GUI)
|
||||
ENDIF(SALOME_BUILD_GUI)
|
||||
|
||||
IF (DEFINED EMSCRIPTEN)
|
||||
SET(SUBDIRS_WASM webassembly)
|
||||
SET(SUBDIRS_WASM wasm_to_py)
|
||||
# SET(SUBDIRS_WASM wasm_to_js wasm_to_py)
|
||||
ENDIF()
|
||||
|
||||
SET(SUBDIRS
|
||||
|
59
src/wasm_to_js/CMakeLists.txt
Normal file
59
src/wasm_to_js/CMakeLists.txt
Normal file
@ -0,0 +1,59 @@
|
||||
add_executable(smeshjs Bindings.cxx)
|
||||
|
||||
set(CMAKE_CXX_VISIBILITY_PRESET hidden)
|
||||
|
||||
set_target_properties(smeshjs PROPERTIES
|
||||
OUTPUT_NAME smesh
|
||||
)
|
||||
|
||||
target_link_libraries(smeshjs PRIVATE SalomeIDLKernel GEOMImpl SMESHDS SMESHimpl StdMeshers SMESHEngine)
|
||||
target_include_directories(smeshjs PRIVATE
|
||||
${OpenCASCADE_INCLUDE_DIR}
|
||||
${KERNEL_INCLUDE_DIRS}
|
||||
${KERNEL_INCLUDE_DIRS}
|
||||
${MEDFILE_INCLUDE_DIRS}
|
||||
${MEDCOUPLING_INCLUDE_DIRS}
|
||||
${PROJECT_SOURCE_DIR}/src/Controls
|
||||
${PROJECT_SOURCE_DIR}/src/SMDS
|
||||
${PROJECT_SOURCE_DIR}/src/SMESH
|
||||
${PROJECT_SOURCE_DIR}/src/SMESHDS
|
||||
${PROJECT_SOURCE_DIR}/src/StdMeshers
|
||||
${PROJECT_SOURCE_DIR}/src/SMESHUtils
|
||||
)
|
||||
|
||||
target_link_options(smeshjs PRIVATE
|
||||
"-O0"
|
||||
"--bind"
|
||||
"--closure 1"
|
||||
"SHELL:-sEXPORT_NAME=smesh"
|
||||
"SHELL:-sALLOW_MEMORY_GROWTH=1"
|
||||
"SHELL:-sEMULATE_FUNCTION_POINTER_CASTS=0"
|
||||
"SHELL:-sMODULARIZE=1"
|
||||
"SHELL:-sWASM=1"
|
||||
"SHELL:-sFORCE_FILESYSTEM"
|
||||
"SHELL:-sEXPORTED_RUNTIME_METHODS=FS"
|
||||
"SHELL:-sWASM_BIGINT"
|
||||
"SHELL:-sNO_DISABLE_EXCEPTION_CATCHING"
|
||||
)
|
||||
|
||||
target_compile_options(smeshjs PRIVATE
|
||||
"-Oz" "-flto"
|
||||
)
|
||||
|
||||
configure_file(
|
||||
"${CMAKE_CURRENT_SOURCE_DIR}/app.html"
|
||||
"${CMAKE_BINARY_DIR}/wasm_to_js/index.html"
|
||||
COPYONLY)
|
||||
|
||||
configure_file(
|
||||
"${CMAKE_CURRENT_SOURCE_DIR}/server.py"
|
||||
"${CMAKE_BINARY_DIR}/wasm_to_js/server.py"
|
||||
COPYONLY)
|
||||
|
||||
install(FILES
|
||||
${CMAKE_BINARY_DIR}/wasm_to_js/index.html
|
||||
${CMAKE_BINARY_DIR}/wasm_to_js/server.py
|
||||
${CMAKE_BINARY_DIR}/src/wasm_to_js/smesh.wasm
|
||||
${CMAKE_BINARY_DIR}/src/wasm_to_js/smesh.js
|
||||
|
||||
DESTINATION wasm_to_js)
|
34
src/wasm_to_py/CMakeLists.txt
Normal file
34
src/wasm_to_py/CMakeLists.txt
Normal file
@ -0,0 +1,34 @@
|
||||
INCLUDE(${SWIG_USE_FILE})
|
||||
|
||||
set_source_files_properties(smeshpy.i PROPERTIES CPLUSPLUS ON)
|
||||
SWIG_ADD_LIBRARY(smeshpy LANGUAGE python SOURCES smeshpy.i)
|
||||
|
||||
target_compile_options(${SWIG_MODULE_smeshpy_REAL_NAME} PRIVATE "-sSIDE_MODULE=2" "-Oz")
|
||||
target_link_options(${SWIG_MODULE_smeshpy_REAL_NAME} PRIVATE "-sSIDE_MODULE=2" "-sEXPORTED_FUNCTIONS=_PyInit_smesh" "-sWARN_UNALIGNED=1" "-Oz")
|
||||
|
||||
target_link_libraries(${SWIG_MODULE_smeshpy_REAL_NAME} PRIVATE GEOMImpl SMESHEngine)
|
||||
|
||||
set_target_properties(${SWIG_MODULE_smeshpy_REAL_NAME} PROPERTIES
|
||||
OUTPUT_NAME smesh
|
||||
SWIG_USE_TARGET_INCLUDE_DIRECTORIES TRUE
|
||||
)
|
||||
|
||||
target_include_directories(${SWIG_MODULE_smeshpy_REAL_NAME} PRIVATE
|
||||
${OpenCASCADE_INCLUDE_DIR}
|
||||
${KERNEL_INCLUDE_DIRS}
|
||||
${MEDFILE_INCLUDE_DIRS}
|
||||
${MEDCOUPLING_INCLUDE_DIRS}
|
||||
${PROJECT_SOURCE_DIR}/src/Controls
|
||||
${PROJECT_SOURCE_DIR}/src/SMDS
|
||||
${PROJECT_SOURCE_DIR}/src/SMESH
|
||||
${PROJECT_SOURCE_DIR}/src/SMESHDS
|
||||
${PROJECT_SOURCE_DIR}/src/StdMeshers
|
||||
${PROJECT_SOURCE_DIR}/src/SMESHUtils
|
||||
${PYTHONWASM_INCLUDE_DIR}
|
||||
)
|
||||
|
||||
install(FILES
|
||||
${CMAKE_BINARY_DIR}/src/wasm_to_py/smesh.so
|
||||
${CMAKE_BINARY_DIR}/src/wasm_to_py/smeshpy.py
|
||||
DESTINATION smeshpywheel
|
||||
)
|
@ -1,95 +0,0 @@
|
||||
INCLUDE(${SWIG_USE_FILE})
|
||||
|
||||
# add_executable(smeshjs Bindings.cxx)
|
||||
|
||||
set_source_files_properties(smeshpy.i PROPERTIES CPLUSPLUS ON)
|
||||
SWIG_ADD_LIBRARY(smeshpy LANGUAGE python SOURCES smeshpy.i)
|
||||
|
||||
target_compile_options(${SWIG_MODULE_smeshpy_REAL_NAME} PRIVATE "-sSIDE_MODULE=2" "-Oz")
|
||||
target_link_options(${SWIG_MODULE_smeshpy_REAL_NAME} PRIVATE "-sSIDE_MODULE=2" "-sEXPORTED_FUNCTIONS=_PyInit_smesh" "-sWARN_UNALIGNED=1" "-Oz")
|
||||
|
||||
|
||||
# set(CMAKE_CXX_VISIBILITY_PRESET hidden)
|
||||
target_link_libraries(${SWIG_MODULE_smeshpy_REAL_NAME} PRIVATE GEOMImpl SMESHEngine)
|
||||
|
||||
# set_target_properties(smeshjs PROPERTIES
|
||||
# OUTPUT_NAME smesh
|
||||
# )
|
||||
|
||||
set_target_properties(${SWIG_MODULE_smeshpy_REAL_NAME} PROPERTIES
|
||||
OUTPUT_NAME smesh
|
||||
SWIG_USE_TARGET_INCLUDE_DIRECTORIES TRUE
|
||||
)
|
||||
|
||||
# target_link_libraries(smeshjs PRIVATE SalomeIDLKernel GEOMImpl SMESHDS SMESHimpl StdMeshers SMESHEngine)
|
||||
# target_include_directories(smeshjs PRIVATE
|
||||
# ${OpenCASCADE_INCLUDE_DIR}
|
||||
# ${KERNEL_INCLUDE_DIRS}
|
||||
# ${KERNEL_INCLUDE_DIRS}
|
||||
# ${MEDFILE_INCLUDE_DIRS}
|
||||
# ${MEDCOUPLING_INCLUDE_DIRS}
|
||||
# ${PROJECT_SOURCE_DIR}/src/Controls
|
||||
# ${PROJECT_SOURCE_DIR}/src/SMDS
|
||||
# ${PROJECT_SOURCE_DIR}/src/SMESH
|
||||
# ${PROJECT_SOURCE_DIR}/src/SMESHDS
|
||||
# ${PROJECT_SOURCE_DIR}/src/StdMeshers
|
||||
# ${PROJECT_SOURCE_DIR}/src/SMESHUtils
|
||||
# )
|
||||
|
||||
target_include_directories(${SWIG_MODULE_smeshpy_REAL_NAME} PRIVATE
|
||||
${OpenCASCADE_INCLUDE_DIR}
|
||||
${KERNEL_INCLUDE_DIRS}
|
||||
${MEDFILE_INCLUDE_DIRS}
|
||||
${MEDCOUPLING_INCLUDE_DIRS}
|
||||
${PROJECT_SOURCE_DIR}/src/Controls
|
||||
${PROJECT_SOURCE_DIR}/src/SMDS
|
||||
${PROJECT_SOURCE_DIR}/src/SMESH
|
||||
${PROJECT_SOURCE_DIR}/src/SMESHDS
|
||||
${PROJECT_SOURCE_DIR}/src/StdMeshers
|
||||
${PROJECT_SOURCE_DIR}/src/SMESHUtils
|
||||
${PYTHONWASM_INCLUDE_DIR}
|
||||
)
|
||||
|
||||
install(FILES
|
||||
${CMAKE_BINARY_DIR}/src/webassembly/smesh.so
|
||||
${CMAKE_BINARY_DIR}/src/webassembly/smeshpy.py
|
||||
DESTINATION smeshpywheel
|
||||
)
|
||||
|
||||
# target_link_options(smeshjs PRIVATE
|
||||
# "-O0"
|
||||
# "--bind"
|
||||
# "--closure 1"
|
||||
# "SHELL:-sEXPORT_NAME=smesh"
|
||||
# "SHELL:-sALLOW_MEMORY_GROWTH=1"
|
||||
# "SHELL:-sEMULATE_FUNCTION_POINTER_CASTS=0"
|
||||
# "SHELL:-sMODULARIZE=1"
|
||||
# "SHELL:-sWASM=1"
|
||||
# "SHELL:-sFORCE_FILESYSTEM"
|
||||
# "SHELL:-sEXPORTED_RUNTIME_METHODS=FS"
|
||||
# "SHELL:-sWASM_BIGINT"
|
||||
# "SHELL:-sNO_DISABLE_EXCEPTION_CATCHING"
|
||||
# )
|
||||
|
||||
# target_compile_options(smeshjs PRIVATE
|
||||
# "-Oz" "-flto"
|
||||
# )
|
||||
|
||||
# configure_file(
|
||||
# "${CMAKE_CURRENT_SOURCE_DIR}/app.html"
|
||||
# "${CMAKE_BINARY_DIR}/webassembly/index.html"
|
||||
# COPYONLY)
|
||||
|
||||
# configure_file(
|
||||
# "${CMAKE_CURRENT_SOURCE_DIR}/server.py"
|
||||
# "${CMAKE_BINARY_DIR}/webassembly/server.py"
|
||||
# COPYONLY)
|
||||
|
||||
# install(FILES
|
||||
# ${CMAKE_BINARY_DIR}/webassembly/index.html
|
||||
# ${CMAKE_BINARY_DIR}/webassembly/server.py
|
||||
# ${CMAKE_BINARY_DIR}/webassembly/server.py
|
||||
# ${CMAKE_BINARY_DIR}/src/webassembly/smesh.wasm
|
||||
# ${CMAKE_BINARY_DIR}/src/webassembly/smesh.js
|
||||
|
||||
# DESTINATION webassembly)
|
Loading…
Reference in New Issue
Block a user