mirror of
https://github.com/opencv/opencv.git
synced 2025-06-07 17:44:04 +08:00
Matlab binding generation now at build time
This commit is contained in:
parent
884f36ba65
commit
31415e344f
@ -3,7 +3,7 @@
|
|||||||
#
|
#
|
||||||
# Matlab code generation and compilation is broken down into two distinct
|
# Matlab code generation and compilation is broken down into two distinct
|
||||||
# stages: configure time and build time. The idea is that we want to give
|
# stages: configure time and build time. The idea is that we want to give
|
||||||
# the user reasonable guarantees that once they type 'make' wrapper
|
# the user reasonable guarantees that once they type 'make', wrapper
|
||||||
# generation is unlikely to fail. Therefore we run a series of tests at
|
# generation is unlikely to fail. Therefore we run a series of tests at
|
||||||
# configure time to check the working status of the core components.
|
# configure time to check the working status of the core components.
|
||||||
#
|
#
|
||||||
@ -37,6 +37,7 @@ endmacro()
|
|||||||
# make sure we're on a supported architecture with Matlab and python installed
|
# make sure we're on a supported architecture with Matlab and python installed
|
||||||
if (IOS OR ANDROID OR NOT MATLAB_FOUND OR NOT PYTHONLIBS_FOUND)
|
if (IOS OR ANDROID OR NOT MATLAB_FOUND OR NOT PYTHONLIBS_FOUND)
|
||||||
ocv_module_disable(matlab)
|
ocv_module_disable(matlab)
|
||||||
|
return()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
set(the_description "The Matlab/Octave bindings")
|
set(the_description "The Matlab/Octave bindings")
|
||||||
@ -45,9 +46,7 @@ ocv_add_module(matlab BINDINGS opencv_core opencv_imgproc
|
|||||||
opencv_highgui opencv_ml opencv_calib3d opencv_photo
|
opencv_highgui opencv_ml opencv_calib3d opencv_photo
|
||||||
opencv_nonfree opencv_calib)
|
opencv_nonfree opencv_calib)
|
||||||
|
|
||||||
# add the python generator to the python path
|
set(HDR_PARSER_PATH ${OPENCV_MODULE_opencv_python_LOCATION}/src2)
|
||||||
set(PYPATH_CACHE $ENV{PYTHONPATH})
|
|
||||||
set(ENV{PYTHONPATH} ${OPENCV_MODULE_opencv_python_LOCATION}/src2:$ENV{PYTHONPATH})
|
|
||||||
|
|
||||||
# get the include path of the Bridge
|
# get the include path of the Bridge
|
||||||
prepend("-I" MEX_INCLUDES ${CMAKE_CURRENT_SOURCE_DIR}/include)
|
prepend("-I" MEX_INCLUDES ${CMAKE_CURRENT_SOURCE_DIR}/include)
|
||||||
@ -57,7 +56,8 @@ prepend("-I" MEX_INCLUDES ${CMAKE_CURRENT_SOURCE_DIR}/include)
|
|||||||
# ----------------------------------------------------------------------------
|
# ----------------------------------------------------------------------------
|
||||||
message("-- Trying to generate Matlab code")
|
message("-- Trying to generate Matlab code")
|
||||||
execute_process(
|
execute_process(
|
||||||
COMMAND ${PYTHON_EXECUTABLE} ${CMAKE_CURRENT_SOURCE_DIR}/generator/gen_matlab_caller.py
|
COMMAND ${PYTHON_EXECUTABLE}
|
||||||
|
${CMAKE_CURRENT_SOURCE_DIR}/generator/gen_matlab_caller.py ${HDR_PARSER_PATH}
|
||||||
${CMAKE_CURRENT_SOURCE_DIR}/test/test_generator.hpp ${CMAKE_CURRENT_BINARY_DIR}
|
${CMAKE_CURRENT_SOURCE_DIR}/test/test_generator.hpp ${CMAKE_CURRENT_BINARY_DIR}
|
||||||
ERROR_VARIABLE GEN_ERROR
|
ERROR_VARIABLE GEN_ERROR
|
||||||
OUTPUT_QUIET
|
OUTPUT_QUIET
|
||||||
@ -66,8 +66,6 @@ execute_process(
|
|||||||
if (GEN_ERROR)
|
if (GEN_ERROR)
|
||||||
message(${GEN_ERROR})
|
message(${GEN_ERROR})
|
||||||
message("-- Error generating Matlab code. Disabling Matlab bindings...")
|
message("-- Error generating Matlab code. Disabling Matlab bindings...")
|
||||||
# restore the pythonpath
|
|
||||||
set(ENV{PYTHONPATH} ${PYPATH_CACHE})
|
|
||||||
return()
|
return()
|
||||||
else()
|
else()
|
||||||
message("-- Trying to generate Matlab code - OK")
|
message("-- Trying to generate Matlab code - OK")
|
||||||
@ -86,8 +84,6 @@ execute_process(
|
|||||||
if (MEX_ERROR)
|
if (MEX_ERROR)
|
||||||
message(${MEX_ERROR})
|
message(${MEX_ERROR})
|
||||||
message("-- Error compiling mex file. Disabling Matlab bindings...")
|
message("-- Error compiling mex file. Disabling Matlab bindings...")
|
||||||
# restore the pythonpath
|
|
||||||
set(ENV{PYTHONPATH} ${PYPATH_CACHE})
|
|
||||||
return()
|
return()
|
||||||
else()
|
else()
|
||||||
message("-- Trying to compile mex file - OK")
|
message("-- Trying to compile mex file - OK")
|
||||||
@ -95,7 +91,6 @@ endif()
|
|||||||
|
|
||||||
# if we make it here, mex works!
|
# if we make it here, mex works!
|
||||||
set_property(GLOBAL PROPERTY MEX_WORKS TRUE)
|
set_property(GLOBAL PROPERTY MEX_WORKS TRUE)
|
||||||
return()
|
|
||||||
|
|
||||||
# ----------------------------------------------------------------------------
|
# ----------------------------------------------------------------------------
|
||||||
# Build time components
|
# Build time components
|
||||||
@ -108,19 +103,24 @@ foreach(module ${OPENCV_MATLAB_MODULES})
|
|||||||
prepend("-I" MEX_INCLUDES "${OPENCV_MODULE_opencv_${module}_LOCATION}/include")
|
prepend("-I" MEX_INCLUDES "${OPENCV_MODULE_opencv_${module}_LOCATION}/include")
|
||||||
endif()
|
endif()
|
||||||
endforeach()
|
endforeach()
|
||||||
message(${MEX_INCLUDES})
|
|
||||||
|
|
||||||
# synthesise the matlab sources
|
# synthesise the matlab sources
|
||||||
# TODO:These should be build-time (ie add_custom_command)
|
add_custom_target(opencv_matlab_sources ALL
|
||||||
execute_process(
|
COMMAND ${PYTHON_EXECUTABLE}
|
||||||
COMMAND ${PYTHON_EXECUTABLE} ${CMAKE_CURRENT_SOURCE_DIR}/generator/gen_matlab_caller.py
|
${CMAKE_CURRENT_SOURCE_DIR}/generator/gen_matlab_caller.py ${HDR_PARSER_PATH}
|
||||||
${opencv_hdrs} ${CMAKE_CURRENT_BINARY_DIR})
|
${opencv_hdrs} ${CMAKE_CURRENT_BINARY_DIR}
|
||||||
|
)
|
||||||
|
|
||||||
# compile the matlab sources
|
# get the matlab sources
|
||||||
file(GLOB SOURCE_FILES ${CMAKE_CURRENT_BINARY_DIR}/src)
|
file(GLOB SOURCE_FILES "${CMAKE_CURRENT_BINARY_DIR}/src/*.cpp")
|
||||||
foreach(SOURCE_FILE ${SOURCE_FILES})
|
foreach(SOURCE_FILE ${SOURCE_FILES})
|
||||||
|
get_filename_component(FILENAME ${SOURCE_FILE} NAME_WE)
|
||||||
# compile the source file using mex
|
# compile the source file using mex
|
||||||
|
add_custom_target("opencv_matlab_${FILENAME}" ALL
|
||||||
|
COMMAND "/usr/bin/true"
|
||||||
|
#COMMAND ${MATLAB_MEX_SCRIPT} ${MEX_INCLUDES}
|
||||||
|
# ${SOURCE_FILE}
|
||||||
|
WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}/src
|
||||||
|
DEPENDS opencv_matlab_sources
|
||||||
|
)
|
||||||
endforeach()
|
endforeach()
|
||||||
|
|
||||||
# restore the pythonpath
|
|
||||||
set(ENV{PYTHONPATH} ${PYPATH_CACHE})
|
|
||||||
|
@ -18,12 +18,10 @@ class MatlabWrapperGenerator(object):
|
|||||||
# get the file name
|
# get the file name
|
||||||
name = os.path.splitext(os.path.basename(file))[0]
|
name = os.path.splitext(os.path.basename(file))[0]
|
||||||
ns[name] = parser.parse(file)
|
ns[name] = parser.parse(file)
|
||||||
print ns[name]
|
|
||||||
|
|
||||||
# cleanify the parser output
|
# cleanify the parser output
|
||||||
parse_tree = ParseTree()
|
parse_tree = ParseTree()
|
||||||
parse_tree.build(ns)
|
parse_tree.build(ns)
|
||||||
print parse_tree
|
|
||||||
|
|
||||||
# setup the template engine
|
# setup the template engine
|
||||||
jtemplate = Environment(loader=PackageLoader('templates', ''), trim_blocks=True, lstrip_blocks=True)
|
jtemplate = Environment(loader=PackageLoader('templates', ''), trim_blocks=True, lstrip_blocks=True)
|
||||||
|
@ -1,12 +1,14 @@
|
|||||||
#/usr/bin/env python
|
#/usr/bin/env python
|
||||||
|
|
||||||
|
# add the hdr_parser to the path
|
||||||
import sys
|
import sys
|
||||||
from gen_matlab import MatlabWrapperGenerator
|
sys.path.append(sys.argv[1])
|
||||||
|
|
||||||
# get the IO from the command line arguments
|
# get the IO from the command line arguments
|
||||||
input_files = sys.argv[1:-1]
|
input_files = sys.argv[2:-1]
|
||||||
output_dir = sys.argv[-1]
|
output_dir = sys.argv[-1]
|
||||||
|
|
||||||
# create the generator
|
# create the generator
|
||||||
|
from gen_matlab import MatlabWrapperGenerator
|
||||||
mwg = MatlabWrapperGenerator()
|
mwg = MatlabWrapperGenerator()
|
||||||
mwg.gen(input_files, output_dir)
|
mwg.gen(input_files, output_dir)
|
||||||
|
Loading…
Reference in New Issue
Block a user