X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=development%2Fautotests%2Fexport.cmake;h=e42317937ac61bf9c9c8bfaa7fdfa963afe8f757;hb=c6b17b685a8cc0982a1544d90cdfdb6fba60a2e0;hp=75ef3d645b3a745eafc68abb8a83dd1a3196b53e;hpb=33f23ae8e5250b76542877681846bc0125da3548;p=lyx.git diff --git a/development/autotests/export.cmake b/development/autotests/export.cmake index 75ef3d645b..e42317937a 100755 --- a/development/autotests/export.cmake +++ b/development/autotests/export.cmake @@ -5,28 +5,74 @@ # # # LYX_ROOT = ${TOP_SRC_DIR}/lib/{doc,examples,templates} -# lyx = +# LYX_USERDIR_VER = Name of environment variable for the user directory +# lyx = # format = lyx16x|xhtml # extension = 16.lyx|xhtml # file = xxx # # Script should be called like: # cmake -DLYX_ROOT=xxx \ -# -DWORKDIR=${BUILD_DIR}/autotests/out-home +# -DLYX_TESTS_USERDIR=${LYX_TESTS_USERDIR} \ +# -DWORKDIR=${BUILD_DIR}/autotests/out-home \ +# -DLYX_USERDIR_VER=${LYX_USERDIR_VER} \ # -Dlyx=xxx \ # -Dformat=xxx \ +# -Dfonttype=xxx \ # -Dextension=xxx \ # -Dfile=xxx \ +# -Dreverted=[01] \ +# -DTOP_SRC_DIR=${TOP_SRC_DIR} +# -DPERL_EXECUTABLE=${PERL_EXECUTABLE} # -P "${TOP_SRC_DIR}/development/autotests/export.cmake" # -message(STATUS "Executing ${lyx} -E ${format} ${file}.${extension} ${LYX_ROOT}/${file}.lyx") -set(ENV{LYX_USERDIR} "${WORKDIR}/.lyx") -execute_process(COMMAND ${CMAKE_COMMAND} -E remove ${file}.${extension}) +set(Perl_Script "${TOP_SRC_DIR}/development/autotests/useSystemFonts.pl") +set(GetTempDir "${TOP_SRC_DIR}/development/autotests/getTempDir.pl") +set(_ft ${fonttype}) +execute_process(COMMAND ${PERL_EXECUTABLE} "${GetTempDir}" "${WORKDIR}" OUTPUT_VARIABLE TempDir) +message(STATUS "using fonttype = ${_ft}") +if(format MATCHES "dvi3|pdf4|pdf5") + message(STATUS "LYX_TESTS_USERDIR = ${LYX_TESTS_USERDIR}") + message(STATUS "Converting with perl ${Perl_Script}") + set(LYX_SOURCE "${TempDir}/${file}_${format}_${_ft}.lyx") + message(STATUS "Using source \"${LYX_ROOT}/${file}.lyx\"") + message(STATUS "Using dest \"${LYX_SOURCE}\"") + execute_process(COMMAND ${PERL_EXECUTABLE} "${Perl_Script}" "${LYX_ROOT}/${file}.lyx" "${LYX_SOURCE}" ${format} ${_ft} + RESULT_VARIABLE _err) + string(COMPARE EQUAL ${_err} 0 _erg) + if(NOT _erg) + message(FATAL_ERROR "Export failed while converting") + endif() +else() + message(STATUS "Not converting") + set(LYX_SOURCE "${LYX_ROOT}/${file}.lyx") +endif() + +set(result_file_name ${file}_${_ft}.${extension}) +message(STATUS "Executing ${lyx} -userdir \"${LYX_TESTS_USERDIR}\" -E ${format} ${result_file_name} \"${LYX_SOURCE}\"") +set(ENV{${LYX_USERDIR_VER}} "${LYX_TESTS_USERDIR}") +execute_process(COMMAND ${CMAKE_COMMAND} -E remove ${result_file_name}) execute_process( - COMMAND ${lyx} -E ${format} ${file}.${extension} "${LYX_ROOT}/${file}.lyx" + COMMAND ${lyx} -userdir "${LYX_TESTS_USERDIR}" -E ${format} ${result_file_name} "${LYX_SOURCE}" RESULT_VARIABLE _err) -string(COMPARE NOTEQUAL ${_err} 0 _erg) + +#check if result file created +if (NOT _err) + if (NOT EXISTS "${result_file_name}") + message(STATUS "Expected result file \"${result_file_name}\" does not exist") + set(_err -1) + else() + message(STATUS "Expected result file \"${result_file_name}\" exists") + endif() +endif() + +if(reverted) + string(COMPARE EQUAL ${_err} 0 _erg) +else() + string(COMPARE NOTEQUAL ${_err} 0 _erg) +endif() +execute_process(COMMAND ${CMAKE_COMMAND} -E remove_directory "${TempDir}") if(_erg) message(STATUS "Exporting ${f}.lyx to ${format}") message(FATAL_ERROR "Export failed")