Matlab binding generation now at build time

pull/1384/head
hbristow 12 years ago
parent 884f36ba65
commit 31415e344f
  1. 40
      modules/matlab/CMakeLists.txt
  2. 2
      modules/matlab/generator/gen_matlab.py
  3. 6
      modules/matlab/generator/gen_matlab_caller.py

@ -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…
Cancel
Save