git-svn-id: svn://db.shs.com.ru/pip@288 12ceb7fc-bf1f-11e4-8940-5bc7170c53b5
This commit is contained in:
@@ -1,33 +1,41 @@
|
|||||||
|
macro (PIP_EXTRACT_OPTIONS _pip_files _pip_options)
|
||||||
|
set(${_pip_files})
|
||||||
|
set(${_pip_options})
|
||||||
|
set(_PIP_DOING_OPTIONS FALSE)
|
||||||
|
foreach(_currentArg ${ARGN})
|
||||||
|
if ("x${_currentArg}" STREQUAL "xOPTIONS")
|
||||||
|
set(_PIP_DOING_OPTIONS TRUE)
|
||||||
|
else ()
|
||||||
|
if(_PIP_DOING_OPTIONS)
|
||||||
|
list(APPEND ${_pip_options} "${_currentArg}")
|
||||||
|
else()
|
||||||
|
list(APPEND ${_pip_files} "${_currentArg}")
|
||||||
|
endif()
|
||||||
|
endif ()
|
||||||
|
endforeach()
|
||||||
|
endmacro ()
|
||||||
|
|
||||||
macro (pip_code_model SRC RESULT)
|
macro (pip_code_model RESULT)
|
||||||
set(RESULT "")
|
PIP_EXTRACT_OPTIONS(CCM_SRC OPTS ${ARGN})
|
||||||
set(OPTS "")
|
set(CCM_OPTS)
|
||||||
set(_IS_OPT false)
|
foreach (it ${OPTS})
|
||||||
foreach (_A ${ARGN})
|
set(CCM_OPTS "${CCM_OPTS} ${it}")
|
||||||
#message(STATUS ${_A})
|
|
||||||
if (_IS_OPT)
|
|
||||||
list (APPEND OPTS ${_A})
|
|
||||||
else ()
|
|
||||||
if ("${_A}" STREQUAL "OPTIONS")
|
|
||||||
set(_IS_OPT true)
|
|
||||||
else ()
|
|
||||||
set (RESULT ${_A})
|
|
||||||
endif ()
|
|
||||||
endif ()
|
|
||||||
endforeach()
|
endforeach()
|
||||||
#message(STATUS "src = ${CMAKE_CURRENT_SOURCE_DIR}/${SRC}")
|
message(STATUS "src = ${CCM_SRC}")
|
||||||
#message(STATUS "result = ${RESULT}")
|
#message(STATUS "result = ${RESULT}")
|
||||||
#message(STATUS "options = ${OPTS}")
|
message(STATUS "options = ${CCM_OPTS}")
|
||||||
set(${RESULT} ${CMAKE_CURRENT_BINARY_DIR}/${PROJECT_NAME}_ccm.cpp)
|
set(CCM_OUT ${CMAKE_CURRENT_BINARY_DIR}/${PROJECT_NAME}_ccm.cpp)
|
||||||
#message(STATUS "Res = ${${RESULT}}")
|
set(${RESULT} ${${RESULT}} ${CCM_OUT})
|
||||||
add_custom_command(OUTPUT ${RESULT}
|
message(STATUS "CCM = ${CCM_OUT}")
|
||||||
COMMAND ${PIP_CMG} -qP ${OPTS} -o ${CMAKE_CURRENT_BINARY_DIR}/${PROJECT_NAME}_ccm -I${PIP_INCLUDES} ${CMAKE_CURRENT_SOURCE_DIR}/${SRC}
|
add_custom_command(OUTPUT ${CCM_OUT}
|
||||||
DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/${SRC}
|
COMMAND ${PIP_CMG}
|
||||||
VERBATIM)
|
ARGS -qP ${CCM_OPTS} -o ${CMAKE_CURRENT_BINARY_DIR}/${PROJECT_NAME}_ccm -I${PIP_INCLUDES} ${CMAKE_CURRENT_SOURCE_DIR}/${CCM_SRC}
|
||||||
#message(STATUS "Creating code model based on \"${SRC}\", please wait ... ")
|
DEPENDS ${CCM_SRC}
|
||||||
#message(STATUS "exec \"-qP ${OPTS} -o ${PROJECT_NAME}_ccm -I${PIP_INCLUDES} ${SRC}\"")
|
VERBATIM)
|
||||||
#message(STATUS "exec ${PIP_CMG} -P ${OPTS} -o ${CMAKE_CURRENT_BINARY_DIR}/${PROJECT_NAME}_ccm -I${PIP_INCLUDES} ${CMAKE_CURRENT_SOURCE_DIR}/${SRC}")
|
#message(STATUS "Creating code model based on \"${CCM_SRC}\", please wait ... ")
|
||||||
#execute_process(OUTPUT_VARIABLE CMG_OUT COMMAND ${PIP_CMG} -qP ${OPTS} -o ${CMAKE_CURRENT_BINARY_DIR}/${PROJECT_NAME}_ccm -I${PIP_INCLUDES} ${CMAKE_CURRENT_SOURCE_DIR}/${SRC})
|
#message(STATUS "exec \"-qP ${CCM_OPTS} -o ${PROJECT_NAME}_ccm -I${PIP_INCLUDES} ${CCM_SRC}\"")
|
||||||
|
message(STATUS "exec ${PIP_CMG} -qP ${CCM_OPTS} -o ${CMAKE_CURRENT_BINARY_DIR}/${PROJECT_NAME}_ccm -I${PIP_INCLUDES} ${CMAKE_CURRENT_SOURCE_DIR}/${CCM_SRC}")
|
||||||
|
#execute_process(OUTPUT_VARIABLE CMG_OUT COMMAND ${PIP_CMG} -qP ${CCM_OPTS} -o ${CMAKE_CURRENT_BINARY_DIR}/${PROJECT_NAME}_ccm -I${PIP_INCLUDES} ${CMAKE_CURRENT_SOURCE_DIR}/${CCM_SRC})
|
||||||
#message(STATUS "Creating code model done, to use it include \"${PROJECT_NAME}_ccm.h\"")
|
#message(STATUS "Creating code model done, to use it include \"${PROJECT_NAME}_ccm.h\"")
|
||||||
#message(STATUS ${CMG_OUT})
|
#message(STATUS ${CMG_OUT})
|
||||||
#message(STATUS ${CACHE_CMG_FILES})
|
#message(STATUS ${CACHE_CMG_FILES})
|
||||||
|
|||||||
Reference in New Issue
Block a user