1
0
mirror of https://git.dev.opencascade.org/repos/occt.git synced 2025-04-04 18:06:22 +03:00
occt/adm/cmake/occt_gendoc.cmake
ibs 19286d7cf7 0025114: CMake-based build tools for OCCT 7.0
All CMake meta-projects for OCCT are put to OCCT code (including fragments previously generated by WOK).

"/bigobj" compiler flag added to TKQADraw because of the size of its object file

[GeomToStep & Graphic3d] private headers are included from current dir of including source file
2015-07-12 13:57:22 +03:00

1326 lines
49 KiB
CMake

# ==========================================================================#
# Brief: This script compiles OCCT documents from *.md files to HTML pages #
# ==========================================================================#
# ======================================
# Common functions
# ======================================
# Print single line or print the line to the file
function(puts theLine)
if(${ARGC} EQUAL 1)
message(STATUS "${theLine}")
elseif(${ARGC} EQUAL 2)
file(APPEND ${ARGV0} "${ARGV1}\n")
endif()
endfunction()
# Print CMake Error, stop processing and generation
function(error theLine)
message(FATAL_ERROR "${theLine}")
endfunction()
# Prints help message
function (OCCDoc_PrintHelpMessage)
puts("Usage: gendoc [-h] {-refman|-overview} [-html|-pdf|-chm] [-m=<list of modules>|-ug=<list of docs>] [-v] [-s=<search_mode>] [-mathjax=<path>]")
puts("")
puts("Options are:")
puts("")
puts("choice of documentation to be generated:")
puts(" -overview : To generate Overview and User Guides")
puts(" (cannot be used with -refman)")
puts(" -refman : To generate class Reference Manual")
puts(" (cannot be used with -overview)")
puts("")
puts("choice of output format:")
puts(" -html : To generate HTML files")
puts(" (default, cannot be used with -pdf or -chm)")
puts(" -pdf : To generate PDF files")
puts(" (cannot be used with -refman, -html, or -chm)")
puts(" -chm : To generate CHM files")
puts(" (cannot be used with -html or -pdf)")
puts("")
puts("additional options:")
puts(" -m=<modules_list> : List of OCCT modules (separated with comma),")
puts(" for generation of Reference Manual")
puts(" -ug=<docs_list> : List of MarkDown documents (separated with comma),")
puts(" to use for generation of Overview / User Guides")
puts(" -mathjax=<path> : To use local or alternative copy of MathJax")
puts(" -s=<search_mode> : Specifies the Search mode of HTML documents")
puts(" Can be: none | local | server | external")
puts(" -h : Prints this help message")
puts(" -v : Enables more verbose output")
endfunction()
# A command for User Documentation compilation
function (gendoc)
# Parameters
set (DOC_TYPE "REFMAN")
set (GEN_MODE "HTML_ONLY")
set (DOCFILES)
set (MODULES)
set (DOCLABEL "")
set (VERB_MODE "NO")
set (SEARCH_MODE "none")
set (MATHJAX_LOCATION "http://cdn.mathjax.org/mathjax/latest")
set (mathjax_js_name "MathJax.js")
set (DOCTYPE_COMBO_FLAG 0)
set (GENMODE_COMBO_FLAG 0)
set (GENERATE_PRODUCTS_REFMAN "NO")
#available_docfiles; # The full list of md files for HTML or CHM generation
#available_pdf; # The full list of md files for PDF generation
#args_names
#args_values
# Load list of docfiles
OCCDoc_LoadFilesList()
# Parse CL arguments
OCCDoc_ParseArguments(${ARGV})
# Print help message if no arguments provided
separate_arguments(args_names)
list(LENGTH args_names length)
if (${length} EQUAL 0)
OCCDoc_PrintHelpMessage()
return()
endif()
list(FIND args_names "pdf" FIND_pdf)
list(FIND args_names "chm" FIND_chm)
list(FIND args_names "ug" FIND_ug)
list(FIND args_names "m" FIND_m)
list(FIND args_names "refman" FIND_refman)
list(FIND args_names "overview" FIND_overview)
foreach (arg_n ${args_names})
if ("${arg_n}" STREQUAL "h")
OCCDoc_PrintHelpMessage()
return()
elseif ("${arg_n}" STREQUAL "html")
if(${FIND_refman} EQUAL -1 AND ${FIND_overview} EQUAL -1 )
error("Error: Please specify -refman or -overview argument.")
endif()
if(${FIND_refman} EQUAL -1)
if (NOT ${GENMODE_COMBO_FLAG} EQUAL 1)
set (GEN_MODE "HTML_ONLY")
set (GENMODE_COMBO_FLAG 1)
else()
error("Error: Options -html, -pdf and -chm can not be combined.")
endif()
endif()
elseif ("${arg_n}" STREQUAL "chm")
if(${FIND_refman} EQUAL -1 AND ${FIND_overview} EQUAL -1 )
error("Error: Please specify -refman or -overview argument.")
endif()
if(${FIND_refman} EQUAL -1)
if(NOT ${GENMODE_COMBO_FLAG} EQUAL 1)
set (GEN_MODE "CHM_ONLY")
set (GENMODE_COMBO_FLAG 1)
else()
error("Error: Options -html, -pdf and -chm cannot be combined.")
endif()
endif()
elseif ("${arg_n}" STREQUAL "pdf")
if(${FIND_refman} EQUAL -1 AND ${FIND_overview} EQUAL -1 )
error("Error: Please specify -refman or -overview argument.")
endif()
if(${FIND_refman} EQUAL -1)
if (NOT ${GENMODE_COMBO_FLAG} EQUAL 1)
set (GEN_MODE "PDF_ONLY")
set (GENMODE_COMBO_FLAG 1)
else()
error("Error: Options -html, -pdf and -chm cannot be combined.")
endif()
endif()
elseif ("${arg_n}" STREQUAL "overview")
if (NOT ${DOCTYPE_COMBO_FLAG} EQUAL 1)
set (DOC_TYPE "OVERVIEW")
set (DOCTYPE_COMBO_FLAG 1)
else()
error("Error: Options -refman and -overview cannot be combined.")
endif()
# Print ignored options
if ( NOT ${FIND_m} EQUAL -1 )
puts ("Info: The following options will be ignored:")
puts (" * -m")
endif()
puts ("")
elseif ("${arg_n}" STREQUAL "refman")
if (NOT ${DOCTYPE_COMBO_FLAG} EQUAL 1)
set (DOC_TYPE "REFMAN")
set (DOCTYPE_COMBO_FLAG 1)
if ( EXISTS "${PRODUCTS_SOURCE_DIR}/src/VAS/Products.tcl")
set (GENERATE_PRODUCTS_REFMAN "YES")
endif()
else()
error("Error: Options -refman and -overview cannot be combined.")
endif()
# Print ignored options
if (NOT ${FIND_pdf} EQUAL -1 OR NOT ${FIND_chm} EQUAL -1 OR NOT ${FIND_ug} EQUAL -1)
puts ("Info: The following options will be ignored:")
if (NOT ${FIND_pdf} EQUAL -1)
puts (" * -pdf")
endif()
if (NOT ${FIND_chm} EQUAL -1)
puts (" * -chm")
endif()
if (NOT ${FIND_ug} EQUAL -1)
puts (" * -ug")
endif()
puts("")
endif()
if ( "${GENERATE_PRODUCTS_REFMAN}" STREQUAL "YES")
if (${FIND_m} EQUAL -1)
error("Error: Cannot generate Reference Manual for the whole set of OCC Products.")
endif()
endif()
elseif ("${arg_n}" STREQUAL "v")
set (VERB_MODE "YES")
elseif ("${arg_n}" STREQUAL "ug")
if(${FIND_refman} EQUAL -1)
list(FIND args_names "ug" curIndex)
list(GET args_values ${curIndex} curValue)
if ( NOT "${curValue}" STREQUAL "NULL")
string(REPLACE "," " " curValue "${curValue}")
separate_arguments(curValue)
set (DOCFILES ${curValue})
else()
error("Error in argument ug.")
endif()
# Check if all chosen docfiles are correct
foreach (docfile ${DOCFILES})
if(${FIND_pdf} EQUAL -1)
# Check to generate HTMLs
list(FIND available_docfiles "${docfile}" FIND_doc)
if (${FIND_doc} EQUAL -1)
error("Error: File \"${docfile}\" is not presented in the list of available docfiles.")
endif()
else()
# Check to generate PDFs
list(FIND available_pdf "${docfile}" FIND_doc)
if ( ${FIND_doc} EQUAL -1)
error("Error: File \"${docfile}\" is not presented in the list of generic PDFs.")
endif()
endif()
endforeach()
endif()
elseif ("${arg_n}" STREQUAL "m")
if (${FIND_overview} EQUAL -1)
list(FIND args_names "m" curIndex)
list(GET args_values ${curIndex} curValue)
if ( NOT "${curValue}" STREQUAL "NULL")
string(REPLACE "," " " curValue "${curValue}")
separate_arguments(curValue)
set(MODULES ${curValue})
else()
error("Error in argument m.")
endif()
endif()
elseif ("${arg_n}" STREQUAL "s")
if (${FIND_pdf} EQUAL -1)
list(FIND args_names "s" curIndex)
list(GET args_values ${curIndex} curValue)
if ( NOT "${curValue}" STREQUAL "NULL")
string(REPLACE "," " " curValue "${curValue}")
separate_arguments(curValue)
set (SEARCH_MODE ${curValue})
else()
error("Error in argument s.")
endif()
endif()
elseif ("${arg_n}" STREQUAL "mathjax")
if (NOT ${FIND_pdf} EQUAL -1)
list(FIND args_names "mathjax" curIndex)
list(GET args_values ${curIndex} curValue)
string(REPLACE "," " " curValue "${curValue}")
separate_arguments(curValue)
set (possible_mathjax_loc ${curValue})
if (EXISTS "${possible_mathjax_loc}/${mathjax_js_name}")
set (MATHJAX_LOCATION ${curValue})
puts ("${MATHJAX_LOCATION}")
else()
puts ("Warning: ${mathjax_js_name} is not found in ${possible_mathjax_loc}.")
puts (" MathJax will be used from ${MATHJAX_LOCATION}")
endif()
else()
puts("Warning: MathJax is not used with pdf and will be ignored.")
endif()
else()
OCCDoc_PrintHelpMessage()
error("Wrong argument: ${arg_n}")
endif()
endforeach()
# Check the existence of the necessary tools
find_program(DOC_DOXYGEN_PATH "doxygen")
if ("${DOC_DOXYGEN_PATH}" STREQUAL "DOC_DOXYGEN_PATH-NOTFOUND")
error(" Aborting... Could not find Doxygen, check DOC_DOXYGEN_PATH variable")
endif()
if("${DOC_TYPE}" STREQUAL "REFMAN")
find_program(DOC_GRAPHVIZ_PATH "dot")
if ("${DOC_GRAPHVIZ_PATH}" STREQUAL "DOC_GRAPHVIZ_PATH-NOTFOUND")
puts("Warning: Could not find Dot Part of Graphviz software. Doxygen will skip generation of class diagrams in Reference Manual, check DOC_GRAPHVIZ_PATH variable")
endif()
endif()
if (WIN32)
if ("${GEN_MODE}" STREQUAL "CHM_ONLY")
find_program(DOC_HHC_PATH "hhc")
if("${DOC_HHC_PATH}" STREQUAL "DOC_HHC_PATH-NOTFOUND")
error(" Aborting... Could not find HHC, check DOC_HHC_PATH variable")
endif()
endif()
endif()
if ("${GEN_MODE}" STREQUAL "PDF_ONLY")
find_program(DOC_INKSCAPE_PATH "inkscape")
if("${DOC_INKSCAPE_PATH}" STREQUAL "DOC_INKSCAPE_PATH-NOTFOUND")
puts ("Warning: Could not find Inkscape, check DOC_INKSCAPE_PATH variable.")
puts ("\tSVG images will be lost in PDF documents.")
endif()
find_program(DOC_PDFLATEX_PATH "pdflatex")
if("${DOC_PDFLATEX_PATH}" STREQUAL "DOC_PDFLATEX_PATH-NOTFOUND")
error(" Aborting... Could not find PDFLATEX, check DOC_PDFLATEX_PATH variable")
endif()
endif()
# If we do not specify list for docfiles with -m argument,
# we assume that we have to generate all docfiles
list(LENGTH DOCFILES DOCFILES_length)
if (${DOCFILES_length} EQUAL 0)
if (NOT "${GEN_MODE}" STREQUAL "PDF_ONLY")
set (DOCFILES ${available_docfiles})
else()
set (DOCFILES ${available_pdf})
endif()
endif()
OCCDoc_GetRootDir(ROOTDIR)
# Clean logfiles
set (OUTDIR "${ROOTDIR}/doc")
set (DOXYLOG "${OUTDIR}/doxygen_warnings_and_errors.log")
set (PDFLOG "${OUTDIR}/pdflatex_warnings_and_errors.log")
file(REMOVE "${PDFLOG}")
file(REMOVE "${DOXYLOG}")
# Start main activities
if (NOT "${GEN_MODE}" STREQUAL "PDF_ONLY")
OCCDoc_Main(${DOC_TYPE} DOCFILES MODULES ${GEN_MODE} ${VERB_MODE} ${SEARCH_MODE} ${MATHJAX_LOCATION} ${GENERATE_PRODUCTS_REFMAN} available_docfiles available_pdf)
else()
puts ("Generating OCCT User Guides in PDF format...")
foreach (pdf ${DOCFILES})
puts ("Info: Processing file ${pdf}")
# Some values are hardcoded because they are related only to PDF generation
separate_arguments(pdf)
OCCDoc_Main("OVERVIEW" pdf "" "PDF_ONLY" ${VERB_MODE} "none" ${MATHJAX_LOCATION} "NO" available_docfiles available_pdf)
endforeach()
string(TIMESTAMP time "%Y-%m-%d %H:%M")
puts ("${time} Generation completed.")
puts ("PDF files are generated in \n\t${OUTDIR}/pdf")
endif()
endfunction()
# Main procedure for documents compilation
function (OCCDoc_Main docType docfiles modules generatorMode verboseMode searchMode mathjaxLocation generateProductsRefman the_available_docfiles the_available_pdf)
set(docfiles ${${docfiles}})
set(modules ${${modules}})
set(available_docfiles ${${the_available_docfiles}})
set(available_pdf ${${the_available_pdf}})
if ("${generateProductsRefman}" STREQUAL "YES")
set (ROOTDIR "${PRODUCTS_SOURCE_DIR}")
else()
set (ROOTDIR "${OCCT_SOURCE_DIR}")
endif()
OCCDoc_GetDoxDir(INDIR)
set (OUTDIR "${ROOTDIR}/doc")
set (PDFDIR "${OUTDIR}/pdf")
set (UGDIR "${PDFDIR}/user_guides")
set (DGDIR "${PDFDIR}/dev_guides")
set (TAGFILEDIR "${OUTDIR}/refman")
set (HTMLDIR "${OUTDIR}/overview/html")
set (LATEXDIR "${OUTDIR}/overview/latex")
set (DOXYFILE "${OUTDIR}/OCCT.cfg")
# Create or cleanup the output folders
if (NOT "${generateProductsRefman}" STREQUAL "YES")
foreach(dir ${OUTDIR} ${HTMLDIR} ${PDFDIR} ${UGDIR} ${DGDIR})
if (NOT EXISTS "${dir}")
file(MAKE_DIRECTORY "${dir}")
endif()
endforeach()
if (EXISTS "${LATEXDIR}")
file(REMOVE_RECURSE "${LATEXDIR}")
endif()
file(MAKE_DIRECTORY "${LATEXDIR}")
endif()
if ("${docType}" STREQUAL "REFMAN")
if (NOT EXISTS "${TAGFILEDIR}")
file(MAKE_DIRECTORY "${TAGFILEDIR}")
endif()
endif()
# is MathJax HLink?
set (mathjax_relative_location "${mathjaxLocation}")
if (IS_DIRECTORY "${mathjaxLocation}")
if ( "${generatorMode}" STREQUAL "HTML_ONLY")
# related path
file(RELATIVE_PATH mathjax_relative_location ${HTMLDIR} ${mathjaxLocation})
elseif ("${generatorMode}" STREQUAL "CHM_ONLY")
# absolute path
set (mathjax_relative_location ${mathjaxLocation})
endif()
endif()
if ( "${generateProductsRefman}" STREQUAL "YES")
set (DOCDIR "${OUTDIR}/refman")
puts ("Generating OCC Products Reference Manual")
else()
if ( "${docType}" STREQUAL "REFMAN")
set (DOCDIR "${OUTDIR}/refman")
puts ("Generating Open CASCADE Reference Manual")
elseif ("${docType}" STREQUAL "OVERVIEW")
set (DOCDIR "${OUTDIR}/overview")
set (FORMAT "")
if ( "${generatorMode}" STREQUAL "HTML_ONLY" OR "${generatorMode}" STREQUAL "CHM_ONLY")
if ( "${generatorMode}" STREQUAL "HTML_ONLY")
set (FORMAT " in HTML format...")
elseif ( "${generatorMode}" STREQUAL "CHM_ONLY")
set (FORMAT " in CHM format...")
endif()
puts ("Generating OCCT User Guides${FORMAT}")
endif()
else()
error("Error: Invalid documentation type: ${docType}. Can not process.")
endif()
endif()
# Generate Doxyfile
string(TIMESTAMP time "%Y-%m-%d %H:%M")
puts ("${time} Generating Doxyfile...")
OCCDoc_MakeDoxyfile(${docType} ${DOCDIR} ${TAGFILEDIR} ${DOXYFILE} ${generatorMode} docfiles modules ${verboseMode} ${searchMode} ${mathjax_relative_location})
# Run doxygen tool
string(TIMESTAMP starttimestamp "%Y-%m-%d %H:%M")
if ("${generatorMode}" STREQUAL "HTML_ONLY" OR "${docType}" STREQUAL "REFMAN")
puts("${starttimestamp} Generating HTML files...")
# Copy index file to provide fast access to HTML documentation
file(COPY "${INDIR}/resources/index.html" DESTINATION "${DOCDIR}")
elseif ("${generatorMode}" STREQUAL "CHM_ONLY")
puts ("${starttimestamp} Generating CHM file...")
elseif ("${generatorMode}" STREQUAL "PDF_ONLY")
puts ("${starttimestamp} Generating PDF file...")
endif()
execute_process(COMMAND ${DOC_DOXYGEN_PATH} ${DOXYFILE}
OUTPUT_FILE ${OUTDIR}/doxygen_out.log
ERROR_FILE ${OUTDIR}/doxygen_warnings_and_errors.log
)
# Start Post Processing
string(TIMESTAMP curtime "%Y-%m-%d %H:%M")
if( "${docType}" STREQUAL "REFMAN")
# Post Process generated HTML pages and draw dependency graphs
OCCDoc_PostProcessor(${DOCDIR})
if (${isOK} EQUAL 0)
puts ("${curtime} Generation completed.")
puts ("Info: doxygen log file is located in:")
puts ("\t${OUTDIR}/doxygen_out.log.")
puts ("Reference Manual is generated in \n\t${DOCDIR}")
endif()
elseif ("${docType}" STREQUAL "OVERVIEW")
# Start PDF generation routine
if ("${generatorMode}" STREQUAL "PDF_ONLY")
# Prepare a list of TeX files, generated by Doxygen
file(GLOB TEXFILES RELATIVE "${LATEXDIR}" "${LATEXDIR}/*.tex")
list(REMOVE_ITEM TEXFILES "refman.tex")
if ("${verboseMode}" STREQUAL "YES")
puts ("Info: Preprocessing generated TeX files...")
endif()
OCCDoc_ProcessTex(TEXFILES ${LATEXDIR} ${verboseMode})
if ("${verboseMode}" STREQUAL "YES")
puts ("Info: Converting SVG images to PNG format...")
endif()
if (NOT "${DOC_INKSCAPE_PATH}" STREQUAL "DOC_INKSCAPE_PATH-NOTFOUND")
OCCDoc_ProcessSvg(${LATEXDIR} ${verboseMode})
endif()
if ("${verboseMode}" STREQUAL "YES")
puts ("Info: Generating PDF file from TeX files...")
endif()
foreach (TEX ${TEXFILES})
# Rewrite existing REFMAN.tex file...
get_filename_component(TEX ${TEX} NAME_WE)
if ("${verboseMode}" STREQUAL "YES")
puts ("Info: Generating PDF file from ${TEX}...")
endif()
OCCDoc_MakeRefmanTex(${TEX} ${LATEXDIR} ${verboseMode} available_pdf)
if ("${verboseMode}" STREQUAL "YES")
# ...and use it to generate PDF from TeX...
if (WIN32)
puts ("Info: Executing ${LATEXDIR}/make.bat...")
else()
puts ("Info: Executing ${LATEXDIR}/Makefile...")
endif()
endif()
set (PDFLOG "${OUTDIR}/pdflatex_warnings_and_errors.log")
if (WIN32)
execute_process(COMMAND ${LATEXDIR}/make.bat
OUTPUT_FILE ${OUTDIR}/pdflatex_out.log
WORKING_DIRECTORY ${LATEXDIR}
ERROR_FILE ${OUTDIR}/pdflatex_warnings_and_errors.log
)
else()
execute_process(COMMAND make -f ${LATEXDIR}/Makefile
OUTPUT_FILE ${OUTDIR}/pdflatex_out.log
WORKING_DIRECTORY ${LATEXDIR}
ERROR_FILE ${OUTDIR}/pdflatex_warnings_and_errors.log
)
# Small workaround for *nix stations
execute_process(COMMAND ${DOC_PDFLATEX_PATH} ${LATEXDIR}/refman.tex
WORKING_DIRECTORY ${LATEXDIR}
OUTPUT_FILE ${OUTDIR}/pdflatex_out.log
ERROR_FILE ${OUTDIR}/pdflatex_warnings_and_errors.log
)
endif()
if (NOT EXISTS "${LATEXDIR}/refman.pdf")
error("Fatal: PDFLaTeX failed to create output file, stopping!\n\tCheck \"${OUTDIR}/pdflatex_warnings_and_errors.log\" log file")
endif()
set (destFolder "${PDFDIR}")
string(REGEX MATCHALL "([a-zA-Z]+)" parsed_string ${TEX})
list(FIND parsed_string "tutorial" isTUTORIAL)
list(FIND parsed_string "user" isUSER)
list(FIND parsed_string "dev" isDEV)
if (NOT ${isTUTORIAL} EQUAL -1)
string(REPLACE "occt__" "occt_" TEX ${TEX})
set (destFolder ${PDFDIR})
elseif (NOT ${isUSER} EQUAL -1)
string(REPLACE "user_guides__" "" TEX ${TEX})
set (destFolder ${UGDIR})
elseif (NOT ${isDEV} EQUAL -1)
string(REPLACE "dev_guides__" "" TEX ${TEX})
set (destFolder ${DGDIR})
endif()
file (RENAME "${LATEXDIR}/refman.pdf" "${destFolder}/${TEX}.pdf")
endforeach()
elseif ( "${generatorMode}" STREQUAL "CHM_ONLY" )
file (RENAME "${OUTDIR}/overview.chm" "${OUTDIR}/occt_overview.chm")
endif()
if ( "${generatorMode}" STREQUAL "HTML_ONLY" )
puts ("HTML documentation is generated in \n\t${DOCDIR}")
endif()
if ( "${generatorMode}" STREQUAL "CHM_ONLY" )
puts ("Generated CHM documentation is in \n\t${OUTDIR}/overview.chm")
endif()
puts ("")
endif()
file(GLOB_RECURSE deleteList "${OUTDIR}/*.tmp")
foreach(file ${deleteList})
file (REMOVE ${file})
endforeach()
endfunction()
# Generates Doxygen configuration file for Overview documentation
function (OCCDoc_MakeDoxyfile docType outDir tagFileDir doxyFileName generatorMode DocFilesList ModulesList verboseMode searchMode mathjaxLocation)
set(DocFilesList ${${DocFilesList}})
set(ModulesList ${${ModulesList}})
OCCDoc_GetDoxDir(inputDir)
set (TEMPLATES_DIR ${inputDir}/resources)
OCCDoc_DetectCasVersion(occt_version)
# Delete existent doxyfile
file (REMOVE "${doxyFileName}")
# Copy specific template to the target folder
if ( "${docType}" STREQUAL "REFMAN")
configure_file("${TEMPLATES_DIR}/occt_rm.doxyfile" "${doxyFileName}" COPYONLY)
elseif ("${docType}" STREQUAL "OVERVIEW")
if ("${generatorMode}" STREQUAL "HTML_ONLY" OR "${generatorMode}" STREQUAL "CHM_ONLY")
configure_file("${TEMPLATES_DIR}/occt_ug_html.doxyfile" "${doxyFileName}" COPYONLY)
elseif ("${generatorMode}" STREQUAL "PDF_ONLY")
configure_file("${TEMPLATES_DIR}/occt_ug_pdf.doxyfile" "${doxyFileName}" COPYONLY)
else()
error("Error: Unknown generation mode")
endif()
else()
error("Error: Cannot generate unknown document type")
endif()
# Write specific options
if ("${docType}" STREQUAL "REFMAN")
GET_OCCT_MODULES(modules)
if (NOT "${ModulesList}" STREQUAL "")
# Detect invalid names of modules
foreach (module ${ModulesList})
list(FIND modules "${module}" isFound)
if (${isFound} EQUAL -1)
error("Error: No module ${module} is known. Aborting...")
endif()
endforeach()
set (modules "${ModulesList}")
endif()
# Set context
list(LENGTH modules length)
if (${length} EQUAL 1)
set (title "OCCT ${modules}")
set (name "${modules}")
else()
set (title "Open CASCADE Technology")
set (name "OCCT")
endif()
# Get list of header files in the specified modules
set (filelist)
foreach (module ${modules})
foreach (tk ${${module}_TOOLKITS})
OCCDoc_GetPackagesList(${tk} ${tk}_PACKAGES)
foreach (pk ${${tk}_PACKAGES})
OCCDoc_GetRootDir(theRoot)
file(GLOB INC_FILES "${theRoot}/src/${pk}/*.[hg]*")
set(TEMP_INC_FILES)
foreach (INC_FILE ${INC_FILES})
string(FIND "${INC_FILE}" "/Handle_" isFound)
if(${isFound} EQUAL -1)
list(APPEND TEMP_INC_FILES "${INC_FILE}")
endif()
endforeach()
list(APPEND filelist "${TEMP_INC_FILES}")
endforeach()
endforeach()
endforeach()
puts (${doxyFileName} "PROJECT_NAME = \"${title}\"")
puts (${doxyFileName} "PROJECT_NUMBER = ${occt_version}")
puts (${doxyFileName} "OUTPUT_DIRECTORY = ${outDir}/.")
puts (${doxyFileName} "GENERATE_TAGFILE = ${outDir}/${name}.tag")
if ("${searchMode}" STREQUAL "none")
puts (${doxyFileName} "SEARCHENGINE = NO")
puts (${doxyFileName} "SERVER_BASED_SEARCH = NO")
puts (${doxyFileName} "EXTERNAL_SEARCH = NO")
else()
puts (${doxyFileName} "SEARCHENGINE = YES")
if ("${searchMode}" STREQUAL "local")
puts (${doxyFileName} "SERVER_BASED_SEARCH = NO")
puts (${doxyFileName} "EXTERNAL_SEARCH = NO")
elseif ("${searchMode}" STREQUAL "server")
puts (${doxyFileName} "SERVER_BASED_SEARCH = YES")
puts (${doxyFileName} "EXTERNAL_SEARCH = NO")
elseif ("${searchMode}" STREQUAL "external")
puts (${doxyFileName} "SERVER_BASED_SEARCH = YES")
puts (${doxyFileName} "EXTERNAL_SEARCH = YES")
else()
error("Error: Wrong search engine type: ${searchMode}.")
endif()
endif()
if(EXISTS "${DOC_GRAPHVIZ_PATH}")
set(DOT_PATH "${DOC_GRAPHVIZ_PATH}")
endif()
puts (${doxyFileName} "DOTFILE_DIRS = ${outDir}/html")
puts (${doxyFileName} "DOT_PATH = ${DOT_PATH}")
puts (${doxyFileName} "INCLUDE_PATH = ${INSTALL_DIR}/inc")
# list of files to generate
OCCDoc_MakeMainPage(${outDir} "${outDir}/${name}.dox" modules)
set (mainpage "${outDir}/${name}.dox")
puts (${doxyFileName} "")
puts (${doxyFileName} "INPUT = ${mainpage} \\")
foreach (header ${filelist})
puts (${doxyFileName} " ${header} \\")
endforeach()
puts (${doxyFileName} "MATHJAX_FORMAT = HTML-CSS")
puts (${doxyFileName} "MATHJAX_RELPATH = ${mathjaxLocation}")
puts (${doxyFileName} "")
elseif ( "${docType}" STREQUAL "OVERVIEW")
# Add common options for generation of Overview and User Guides
puts (${doxyFileName} "PROJECT_NUMBER = ${occt_version}")
puts (${doxyFileName} "OUTPUT_DIRECTORY = ${outDir}/.")
puts (${doxyFileName} "PROJECT_LOGO = ${inputDir}/resources/occ_logo.png")
set (PARAM_INPUT "INPUT =")
set (PARAM_IMAGEPATH "IMAGE_PATH = ${inputDir}/resources/ ")
foreach (docFile ${DocFilesList})
set (NEW_IMG_PATH "${inputDir}/${docFile}")
OCCDoc_GetRootDir(theRoot)
if (NOT "${NEW_IMG_PATH}" STREQUAL "${theRoot}")
get_filename_component(img_string ${NEW_IMG_PATH} DIRECTORY)
set (img_string "${img_string}/images")
if (EXISTS ${img_string})
set(PARAM_IMAGEPATH "${PARAM_IMAGEPATH} ${img_string}")
endif()
endif()
set(PARAM_INPUT "${PARAM_INPUT} ${inputDir}/${docFile}")
endforeach()
puts (${doxyFileName} ${PARAM_INPUT})
puts (${doxyFileName} ${PARAM_IMAGEPATH})
# Add document type-specific options
if ( "${generatorMode}" STREQUAL "HTML_ONLY")
# generate tree view
puts (${doxyFileName} "GENERATE_TREEVIEW = YES")
# Set a reference to a TAGFILE
if (NOT "${tagFileDir}" STREQUAL "")
if (EXISTS "${tagFileDir}/OCCT.tag")
set (tagPath ${tagFileDir})
puts (${doxyFileName} "TAGFILES = ${tagFileDir}/OCCT.tag=../../refman/html")
endif()
endif()
# HTML Search engine options
string(TOLOWER "${searchMode}" searchMode)
if ("${searchMode}" STREQUAL "none")
puts (${doxyFileName} "SEARCHENGINE = NO")
puts (${doxyFileName} "SERVER_BASED_SEARCH = NO")
puts (${doxyFileName} "EXTERNAL_SEARCH = NO")
else()
puts (${doxyFileName} "SEARCHENGINE = YES")
if ("${searchMode}" STREQUAL "local")
puts (${doxyFileName} "SERVER_BASED_SEARCH = NO")
puts (${doxyFileName} "EXTERNAL_SEARCH = NO")
elseif ("${searchMode}" STREQUAL "server")
puts (${doxyFileName} "SERVER_BASED_SEARCH = YES")
puts (${doxyFileName} "EXTERNAL_SEARCH = NO")
elseif ("${searchMode}" STREQUAL "external")
puts (${doxyFileName} "SERVER_BASED_SEARCH = YES")
puts (${doxyFileName} "EXTERNAL_SEARCH = YES")
else()
error("Error: Wrong search engine type: ${searchMode}.")
endif()
endif()
elseif ( "${generatorMode}" STREQUAL "CHM_ONLY")
# specific options for CHM file generation
if(EXISTS "${DOC_HHC_PATH}")
set(HHC_LOCATION "${DOC_HHC_PATH}")
endif()
puts (${doxyFileName} "GENERATE_TREEVIEW = NO")
puts (${doxyFileName} "SEARCHENGINE = NO")
puts (${doxyFileName} "GENERATE_HTMLHELP = YES")
puts (${doxyFileName} "CHM_FILE = ../../overview.chm")
puts (${doxyFileName} "HHC_LOCATION = \"${HHC_LOCATION}\"")
puts (${doxyFileName} "DISABLE_INDEX = YES")
endif()
# Formula options
puts (${doxyFileName} "MATHJAX_RELPATH = ${mathjaxLocation}")
endif()
endfunction()
# Parses arguments line like "-arg1=val1 -arg2=val2 ..." to array args_names and map args_values
function (OCCDoc_ParseArguments)
#args_names
#args_values
set (args_names)
set (args_values)
separate_arguments(ARGV)
string(REGEX MATCHALL "^[a-zA-Z]+$" single_var "${ARGV}")
string(REGEX MATCHALL "^[a-zA-Z]+[=].*$" multi_var "${ARGV}")
separate_arguments(ARGV)
foreach (arg ${ARGV})
STRING(FIND "${arg}" "=" equalChar)
STRING(FIND "${arg}" "-" firstChar)
if(NOT "${firstChar}" EQUAL 0)
error("Error in argument \"${arg}\".")
endif()
if(NOT "${equalChar}" EQUAL -1)
math(EXPR valueChar "${equalChar} + 1")
math(EXPR nameChar "${equalChar} - 1")
string(SUBSTRING "${arg}" "${valueChar}" -1 aValue)
string(SUBSTRING "${arg}" 1 "${nameChar}" aName)
else()
string(SUBSTRING "${arg}" 1 -1 aName)
set(aValue "NULL")
endif()
list(APPEND args_names "${aName}")
list(APPEND args_values "${aValue}")
endforeach()
set (args_names ${args_names} PARENT_SCOPE)
set (args_values ${args_values} PARENT_SCOPE)
set (isOK 0 PARENT_SCOPE)
endfunction()
# Returns script parent folder
function (OCCDoc_GetDoxDir result)
if (BUILD_PATCH_DIR AND EXISTS "${BUILD_PATCH_DIR}/dox")
set (filePATH ${BUILD_PATCH_DIR})
elseif (EXISTS "${CMAKE_SOURCE_DIR}/dox")
set (filePATH ${CMAKE_SOURCE_DIR})
endif()
set(${result} "${filePATH}/dox" PARENT_SCOPE)
endfunction()
# Returns OCCT root dir
function (OCCDoc_GetOCCTRootDir result)
OCCDoc_GetDoxDir(path)
get_filename_component(path "${path}" DIRECTORY)
set(${result} "${path}" PARENT_SCOPE)
endfunction()
# Returns root dir
function (OCCDoc_GetRootDir result)
OCCDoc_GetOCCTRootDir(path)
set(${result} "${path}" PARENT_SCOPE)
endfunction()
# Returns OCCT source dir
function (OCCDoc_GetSourceDir result)
OCCDoc_GetRootDir(theRoot)
set(${result} "${theRoot}/src" PARENT_SCOPE)
endfunction()
# Returns OCCT version string from file Standard_Version.hxx (if available)
function (OCCDoc_DetectCasVersion theVersion)
set (occt_ver 6.7.0)
set (occt_ver_add "")
OCCDoc_GetSourceDir(filename)
set(filename "${filename}/Standard/Standard_Version.hxx")
if(EXISTS "${filename}")
foreach (var OCC_VERSION_COMPLETE OCC_VERSION_DEVELOPMENT)
file (STRINGS "${filename}" ${var} REGEX "^#define ${var} .*")
STRING(REGEX REPLACE ".*${var} .*\"([^ ]+)\".*" "\\1" ${var} "${${var}}" )
endforeach()
if(NOT "${OCC_VERSION_DEVELOPMENT}" STREQUAL "")
set(${theVersion} "${OCC_VERSION_COMPLETE}.${OCC_VERSION_DEVELOPMENT}" PARENT_SCOPE)
else()
set(${theVersion} "${OCC_VERSION_COMPLETE}" PARENT_SCOPE)
endif()
endif()
endfunction()
# Convert SVG files to PDF format to allow including them to PDF
# (requires InkScape to be in PATH)
function (OCCDoc_ProcessSvg latexDir verboseMode)
file(GLOB aFILES "${latexDir}/*.svg")
foreach (file ${aFILES})
if ("${verboseMode}" STREQUAL "YES")
puts ("Info: Converting file ${file}...")
endif()
get_filename_component(aDir ${file} DIRECTORY )
get_filename_component(aName ${file} NAME_WE )
set (pdffile "${aDir}/${aName}.pdf")
execute_process(COMMAND ${DOC_INKSCAPE_PATH} -z -D --file=${file} --export-pdf=${pdffile}
WORKING_DIRECTORY ${LATEXDIR}
OUTPUT_FILE ${OUTDIR}/inkscape_out.log
ERROR_FILE ${OUTDIR}/inkscape_warnings_and_errors.log
)
endforeach()
endfunction()
# ==============================================
# Reference Manual-specific functions
# ==============================================
# Finds dependencies between all modules
function (OCCDoc_CreateModulesDependencyGraph dir filename modules mpageprefix)
set(modules ${${modules}})
#module_dependency
set (file "${dir}/${filename}.dot")
file(REMOVE ${file})
puts (${file} "digraph ${filename}")
puts (${file} "{")
foreach (mod ${modules})
if ( NOT "${mod}" STREQUAL "")
string(TOLOWER "${mpageprefix}${mod}.html" aLowerString)
puts (${file} "\t${mod} [ URL = \"${aLowerString}\" ]")
foreach (mod_depend ${${mod}_DEPS})
puts (${file} "\t${mod_depend} -> ${mod} [ dir = \"back\", color = \"midnightblue\", style = \"solid\" ]")
endforeach()
endif()
endforeach()
puts (${file} "}")
endfunction()
# Finds dependencies between all toolkits in module
function(OCCDoc_CreateModuleToolkitsDependencyGraph dir filename modulename tpageprefix)
#toolkits_in_module
#toolkit_dependency
#toolkit_parent_module
set (file "${dir}/${filename}.dot")
file(REMOVE ${file})
puts (${file} "digraph ${filename}")
puts (${file} "{")
foreach (tk ${${modulename}_TOOLKITS})
string(TOLOWER "${tpageprefix}${tk}.html" LowerString)
OCC_GetUnitType("${tk}" theType)
if("${theType}" STREQUAL "t")
puts (${file} "\t${tk} [ URL = \"${LowerString}\"]")
foreach (tkd ${${tk}_DEPS})
IS_OCCT_TOOLKIT(${tkd})
OCC_GetUnitType("${tkd}" theType)
if("${theType}" STREQUAL "t")
if(NOT ${isFOUND} EQUAL -1)
if("${isFOUND}" STREQUAL "${modulename}")
puts (${file} "\t${tkd} -> ${tk} [ dir = \"back\", color = \"midnightblue\", style = \"solid\" ]")
endif()
endif()
endif()
endforeach()
endif()
endforeach()
puts (${file} "}")
endfunction()
# Finds dependencies between the current toolkit and other toolkits
function(OCCDoc_CreateToolkitDependencyGraph dir filename toolkitname tpageprefix)
#toolkit_dependency
set (file "${dir}/${filename}.dot")
file(REMOVE ${file})
puts(${file} "digraph ${filename}")
puts(${file} "{")
string(TOLOWER "${tpageprefix}${toolkitname}.html" LowerString)
puts(${file} "\t${toolkitname} [ URL = \"${LowerString}\", shape = box ]")
foreach (tkd ${${toolkitname}_DEPS})
string(TOLOWER "${tpageprefix}${tkd}.html" LowerString)
puts(${file} "\t${tkd} [ URL = \"${LowerString}\"\ , shape = box ]")
puts(${file} "\t${toolkitname} -> ${tkd} [ color = \"midnightblue\", style = \"solid\" ]")
endforeach()
list(LENGTH ${toolkitname}_DEPS length)
if (${length} GREATER 1)
puts(${file} "\taspect = 1")
endif()
puts(${file} "}")
endfunction()
# Fills arrays of modules, toolkits, dependency of modules/toolkits etc
function (OCCDoc_LoadData)
#toolkits_in_module
#toolkit_dependency
#toolkit_parent_module
#module_dependency
GET_OCCT_MODULES(modules)
set(MODULES ${modules} PARENT_SCOPE)
foreach (mod ${modules})
set(${mod}_TOOLKITS "${${mod}_TOOLKITS}" PARENT_SCOPE)
foreach (tk ${${mod}_TOOLKITS})
OCCT_TOOLKIT_DEP(${tk})
foreach (dtk ${${tk}_DEPS})
IS_OCCT_TOOLKIT(${dtk})
if(${isFOUND} EQUAL -1)
list(REMOVE_ITEM ${tk}_DEPS ${dtk})
endif()
endforeach()
set(${tk}_DEPS ${${tk}_DEPS} PARENT_SCOPE)
endforeach()
endforeach()
# Get modules dependency
foreach (mod ${modules})
set(${mod}_DEPS)
foreach (tk ${${mod}_TOOLKITS})
foreach(dtk ${${tk}_DEPS})
IS_OCCT_TOOLKIT(${dtk})
if(NOT ${isFOUND} EQUAL -1)
if(NOT "${mod}" STREQUAL "${isFOUND}")
list(APPEND ${mod}_DEPS "${isFOUND}")
endif()
endif()
endforeach()
endforeach()
list(LENGTH ${mod}_DEPS length)
if(NOT ${length} EQUAL 0)
list(REMOVE_DUPLICATES ${mod}_DEPS)
endif()
set(${mod}_DEPS ${${mod}_DEPS} PARENT_SCOPE)
endforeach()
endfunction()
# Returns list of packages of the given toolkit
function (OCCDoc_GetExternLibList theToolkit theExternLibs)
OCCDoc_GetRootDir(theRoot)
# Open file with list of packages of the given toolkit
file(READ "${theRoot}/src/${theToolkit}/EXTERNLIB" CONTENT)
set(${theExternLibs} ${CONTENT} PARENT_SCOPE)
endfunction()
# Returns list of packages of the given toolkit
function (OCC_GetUnitType theName theResult)
OCCDoc_GetRootDir(theRoot)
# Open file with list of packages of the given toolkit
set(aType "")
if(EXISTS "${theRoot}/adm/UDLIST")
file(STRINGS "${theRoot}/adm/UDLIST" CONTENT REGEX ". ${theName}")
endif()
string(SUBSTRING "${CONTENT}" 0 1 aType)
set(${theResult} "${aType}" PARENT_SCOPE)
endfunction()
# Returns list of packages of the given toolkit
function (OCCDoc_GetPackagesList theToolkit thePackages)
OCCDoc_GetRootDir(theRoot)
# Open file with list of packages of the given toolkit
set(CONTENT "")
if(EXISTS "${theRoot}/src/${theToolkit}/PACKAGES")
file(STRINGS "${theRoot}/src/${theToolkit}/PACKAGES" CONTENT)
endif()
set(${thePackages} "${CONTENT}" PARENT_SCOPE)
endfunction()
# Function to get toolkits dependencies from file src/TOOLKIT_NAME/EXTERNLIB.
# Creates <TOOLKIT_NAME>_DEPS variable to store them.
function (OCCT_TOOLKIT_DEP TOOLKIT_NAME)
if (BUILD_PATCH_DIR AND EXISTS "${BUILD_PATCH_DIR}/src/${TOOLKIT_NAME}/EXTERNLIB")
set (MODULE_PATH_PREFIX ${BUILD_PATCH_DIR})
elseif (EXISTS "${CMAKE_SOURCE_DIR}/src/${TOOLKIT_NAME}/EXTERNLIB")
set (MODULE_PATH_PREFIX ${CMAKE_SOURCE_DIR})
else()
RETURN()
endif()
file (STRINGS "${MODULE_PATH_PREFIX}/src/${TOOLKIT_NAME}/EXTERNLIB" CONTENT)
set (${TOOLKIT_NAME}_DEPS ${CONTENT} PARENT_SCOPE)
endfunction()
# Function to determine if TOOLKIT is OCC toolkit
# Creates "isFOUND" variable to store result
function (IS_OCCT_TOOLKIT TOOLKIT_NAME)
set (isFOUND -1 PARENT_SCOPE)
GET_OCCT_MODULES(MODULES)
foreach(MODULE ${MODULES})
set(TOOLKITS ${${MODULE}_TOOLKITS})
list(FIND TOOLKITS ${TOOLKIT_NAME} isOK)
if (NOT ${isOK} EQUAL -1)
set (isFOUND "${MODULE}" PARENT_SCOPE)
return()
endif()
endforeach(MODULE)
endfunction()
# Function to get list of modules and toolkits from file adm/MODULES.
# Creates list <${MODULES_LIST}> to store list of MODULES and
# <NAME_OF_MODULE>_TOOLKITS foreach module to store its toolkits.
function (GET_OCCT_MODULES MODULES_LIST)
set (MODULE_PATH_POSTFIX "/adm/MODULES")
if (BUILD_PATCH_DIR AND EXISTS "${BUILD_PATCH_DIR}${MODULE_PATH_POSTFIX}")
set (MODULE_PATH_PREFIX "${BUILD_PATCH_DIR}")
elseif (EXISTS "${CMAKE_SOURCE_DIR}${MODULE_PATH_POSTFIX}")
set (MODULE_PATH_PREFIX "${CMAKE_SOURCE_DIR}")
else()
RETURN()
endif()
file (STRINGS "${MODULE_PATH_PREFIX}${MODULE_PATH_POSTFIX}" CONTENT)
set (${MODULES_LIST})
foreach (CONTENT_LINE ${CONTENT})
string (REPLACE " " ";" CONTENT_LINE ${CONTENT_LINE})
list (GET CONTENT_LINE 0 NAME_OF_MODULE)
list (REMOVE_AT CONTENT_LINE 0)
list (APPEND ${MODULES_LIST} ${NAME_OF_MODULE})
set (${NAME_OF_MODULE}_TOOLKITS "${CONTENT_LINE}" PARENT_SCOPE)
endforeach()
set (${MODULES_LIST} ${${MODULES_LIST}} PARENT_SCOPE)
endfunction()
# Gets contents of the given html node (for Post-processing)
function(OCCDoc_GetNodeContents node props html theResult)
set (openTag "<${node}${props}>")
set (closingTag "</${node}>")
string(FIND "${html}" "${openTag}" start)
if (${start} EQUAL -1)
set(theResult "" PARENT_SCOPE)
return()
endif()
string(LENGTH "${openTag}" length)
math(EXPR start "${start} + ${length}")
string(SUBSTRING "${html}" ${start} -1 html)
string(FIND "${html}" "${closingTag}" start)
if (${start} EQUAL -1)
set(theResult "" PARENT_SCOPE)
return()
endif()
math(EXPR start "${start} - 1")
string(SUBSTRING "${html}" 0 ${start} theResult)
set(theResult "" PARENT_SCOPE)
endfunction()
# Generates main page file describing module structure
function (OCCDoc_MakeMainPage outDir outFile inModules)
set(inModules "${${inModules}}")
#env
set (module_prefix "module_")
set (toolkit_prefix "toolkit_")
set (package_prefix "package_")
if (NOT EXISTS "${outDir}/html")
file(MAKE_DIRECTORY "${outDir}/html")
endif()
OCCDoc_LoadData()
# Main page: list of modules
separate_arguments(inModules)
list(LENGTH inModules length)
if (NOT ${length} EQUAL 1)
puts (${outFile} "/**")
puts (${outFile} "\\mainpage Open CASCADE Technology")
foreach (mod ${inModules})
string(TOLOWER "${module_prefix}${mod}" LowerString)
puts (${outFile} "\\li \\subpage ${LowerString}")
endforeach()
OCCDoc_CreateModulesDependencyGraph("${outDir}/html" "schema_all_modules" inModules ${module_prefix})
# insert modules relationship diagramm
puts (${outFile} "\\dotfile schema_all_modules")
puts (${outFile} "**/")
endif()
# One page per module: list of toolkits
set (toolkits)
foreach (mod ${inModules})
puts (${outFile} "/**")
if (${length} EQUAL 1)
puts (${outFile} "\\mainpage OCCT Module ${mod}")
else()
string(TOLOWER "module_${mod}" LowerString)
puts (${outFile} "\\page ${LowerString} Module ${mod}")
endif()
list(SORT ${mod}_TOOLKITS)
foreach (tk ${${mod}_TOOLKITS})
OCC_GetUnitType("${tk}" theType)
if("${theType}" STREQUAL "t")
list(APPEND toolkits ${tk})
string(TOLOWER "${toolkit_prefix}${tk}" LowerString)
puts (${outFile} "\\li \\subpage ${LowerString}")
endif()
endforeach()
OCCDoc_CreateModuleToolkitsDependencyGraph("${outDir}/html" "schema_${mod}" ${mod} ${toolkit_prefix})
puts (${outFile} "\\dotfile schema_${mod}")
puts (${outFile} "**/")
endforeach()
# One page per toolkit: list of packages
set (packages)
foreach (tk ${toolkits})
puts (${outFile} "/**")
string(TOLOWER "toolkit_${tk}" LowerString)
puts (${outFile} "\\page ${LowerString} Toolkit ${tk}")
OCCDoc_GetPackagesList(${tk} ${tk}_PACKAGES)
list(SORT ${tk}_PACKAGES)
foreach (pk ${${tk}_PACKAGES})
list(APPEND packages ${pk})
string(TOLOWER "${package_prefix}${pk}" LowerString)
puts (${outFile} "\\li \\subpage ${LowerString}")
endforeach()
OCCDoc_CreateToolkitDependencyGraph("${outDir}/html" "schema_${tk}" "${tk}" "${toolkit_prefix}")
puts (${outFile} "\\dotfile schema_${tk}")
puts (${outFile} "**/")
endforeach()
# One page per package: list of classes
foreach (pk ${packages})
puts (${outFile} "/**")
string(TOLOWER "${package_prefix}${pk}" LowerString)
puts (${outFile} "\\page ${LowerString} Package ${pk}")
file(GLOB INC_FILES RELATIVE "${theRoot}/src/${pk}" "${theRoot}/src/${pk}/*.hxx")
foreach (hdr ${INC_FILES})
string(FIND "${hdr}" "Handle_" isHandle)
if(NOT ${isHandle} EQUAL 0)
string(LENGTH "${hdr}" length)
math(EXPR length "${length} - 4")
string(SUBSTRING "${hdr}" 0 ${length} aName)
puts (${outFile} "\\li \\subpage ${aName}")
endif()
endforeach()
puts (${outFile} "**/")
endforeach()
endfunction()
# Parses generated files to add a navigation path
function(OCCDoc_PostProcessor outDir)
string(TIMESTAMP time "%Y-%m-%d %H:%M")
puts("${time} Post-process is started ...")
set(outDir "${outDir}/html")
file(GLOB files "${outDir}/package_*")
list(LENGTH files length)
if (NOT ${length} EQUAL 0)
list(SORT files)
foreach(f ${files})
file(READ ${f} packageFile)
OCCDoc_GetNodeContents("div" " id=\"nav-path\" class=\"navpath\"" "${packageFile}" navPath)
OCCDoc_GetNodeContents("div" " class=\"title\"" "${packageFile}" packageName)
get_filename_component(packageFileName "${f}" NAME)
# add package link to nav path
string(REPLACE "</ul>" "" navPath "${navPath}")
set (navPath "${navPath} <li class=\"navelem\"><a class=\"el\" href=\"${packageFileName}\">${packageName}</a> </li>\n </ul>")
# get list of files to update
OCCDoc_GetNodeContents("div" " class=\"textblock\"" "${packageFile}" listContents)
OCCDoc_GetNodeContents("ul" "" "${listContents}" listContents)
foreach(line ${listContents})
STRING(REGEX REPLACE ".*href=\"([^\"]+)\".*" "\\1" classFileName "${test}" )
if (NOT "${classFileName}" STREQUAL "${line}")
# check if anchor is there
string(FIND "${classFileName}" "#" anchorPos)
if (NOT ${anchorPos} EQUAL -1)
math(EXPR anchorPos "${anchorPos} - 1")
string(SUBSTRING "${classFileName}" 0 ${anchorPos} classFileName)
endif()
# read class file
set (classFilePnt "${outDir}/${classFileName}")
file(READ ${classFilePnt} classFile)
# find position of content block
string(FIND "${classFile}" "<div class=\"header\">" contentPos)
math(EXPR contentPos "${contentPos} - 1")
string(SUBSTRING "${classFile}" 0 ${contentPos} navPart)
# position where to insert nav path
string(FIND "${navPart}" "</div>" posToInsert REVERSE)
math(EXPR posToInsert "${posToInsert} - 1")
string(SUBSTRING "${classFile}" 0 ${posToInsert} prePart)
string(SUBSTRING "${classFile}" ${posToInsert} -1 postPart)
list(APPEND newClassFile "${prePart}" " <div id=\"nav-path\" class=\"navpath\">" "${navPath}" "\n" " </div>" "\n" "${postPart}")
# write updated content
file(WRITE ${classFilePnt} "${newClassFile}")
file(APPEND ${classFilePnt} "${classFile}")
endif()
endforeach()
endforeach()
else()
puts ("no files found")
endif()
endfunction()
# ======================================
# User Guides-specific functions
# ======================================
# Loads a list of docfiles from file FILES.txt
function(OCCDoc_LoadFilesList)
OCCDoc_GetDoxDir(INPUTDIR)
#available_docfiles
set (available_docfiles "")
# Read data from file
if ( EXISTS "${INPUTDIR}/FILES_HTML.txt" )
file (STRINGS "${INPUTDIR}/FILES_HTML.txt" available_docfiles REGEX "^[^#]+")
else()
error("File FILES_HTML.txt was not found on this computer.\nAborting...")
endif()
set(available_docfiles "${available_docfiles}" PARENT_SCOPE)
#available_pdf
set(available_pdf "")
# Read data from file
if ( EXISTS "${INPUTDIR}/FILES_PDF.txt" )
file (STRINGS "${INPUTDIR}/FILES_PDF.txt" available_pdf REGEX "^[^#]+")
else()
error("File FILES_PDF.txt was not found on this computer.\nAborting...")
endif()
set(available_pdf "${available_pdf}" PARENT_SCOPE)
endfunction()
# Writes new TeX file for conversion from tex to pdf for a specific doc
function(OCCDoc_MakeRefmanTex fileName latexDir verboseMode latexFilesList)
set(latexFilesList ${${latexFilesList}})
if ( "${verboseMode}" STREQUAL "YES")
puts ("Info: Making refman.tex file for ${fileName}...")
endif()
set (DOCNAME "${latexDir}/refman.tex")
if (EXISTS ${DOCNAME})
file(REMOVE ${DOCNAME})
endif()
# Copy template file to latex folder
OCCDoc_GetDoxDir(temp_path)
configure_file("${temp_path}/resources/occt_pdf_template.tex" "${DOCNAME}" COPYONLY)
# Get templatized data
file(READ ${DOCNAME} texfile_loaded)
# Replace dummy values
OCCDoc_DetectCasVersion(casVersion)
# Get name of the document
set (docLabel "")
foreach (aFileName ${latexFilesList})
# Find the file in FILES_PDF.txt
string(REPLACE "/" ";" parsedFileName "${aFileName}")
separate_arguments(parsedFileName)
string(FIND "${fileName}" "__" aFirst)
math(EXPR aFirst "${aFirst} + 2")
string(SUBSTRING "${fileName}" ${aFirst} -1 newfileName)
list(FIND parsedFileName "${newfileName}.md" isFOUND)
if (NOT ${isFOUND} EQUAL -1)
OCCDoc_GetDoxDir(temp_path)
set (filepath "${temp_path}/${aFileName}")
if (EXISTS ${filepath})
file(STRINGS "${filepath}" MDFile LIMIT_COUNT 1)
string(REPLACE "{" ";" MDFile "${MDFile}")
separate_arguments(MDFile)
list(GET MDFile 0 label)
set (docLabel "${label}")
break()
endif()
endif()
endforeach()
string(TIMESTAMP curYear "%Y")
string(REPLACE "DEFDOCLABEL" "${docLabel}" texfile_loaded "${texfile_loaded}")
string(REPLACE "DEFCASVERSION" "${casVersion}" texfile_loaded "${texfile_loaded}")
string(REPLACE "DEFFILENAME" "${fileName}" texfile_loaded "${texfile_loaded}")
string(REPLACE "DEFYEAR" "${curYear}" texfile_loaded "${texfile_loaded}")
# Get data
file(WRITE ${DOCNAME} "${texfile_loaded}")
endfunction()
# Postprocesses generated TeX files
function(OCCDoc_ProcessTex texFiles latexDir verboseMode)
set(texFiles ${${texFiles}})
foreach (TEX ${texFiles})
if ("${verboseMode}" STREQUAL "YES")
puts("Info: Preprocessing file ${TEX}...")
endif()
if (NOT EXISTS ${latexDir}/${TEX})
error("Error: file ${TEX} does not exist.")
endif()
file(STRINGS "${latexDir}/${TEX}" IN_F)
set(TEMP_LIST)
foreach(line ${IN_F})
string(FIND "${line}" "\\includegraphics" includegraphicsPos)
string(FIND "${line}" "\\subsection" subsectionPos)
string(FIND "${line}" "\\subsubsection" subsubsectionPos)
string(FIND "${line}" "\\paragraph" paragraphPos)
if (NOT ${includegraphicsPos} EQUAL -1)
# replace svg extension by pdf
string(REPLACE ".svg" ".pdf" line "${line}")
# Center images in TeX files
set(line "\\begin{center}\n ${line}\n\\end{center}")
elseif (NOT ${subsectionPos} EQUAL -1)
# Replace \subsection with \section tag
string(REPLACE "\\\\subsection" "\\\\section" line "${line}")
elseif (NOT ${subsubsectionPos} EQUAL -1)
# Replace \subsubsection with \subsection tag
string(REPLACE "\\\\subsubsection" "\\\\subsection" line "${line}")
elseif (NOT ${paragraphPos} EQUAL -1)
# Replace \paragraph with \subsubsection tag
string(REPLACE "\\\\paragraph" "\\\\subsubsection" line "${line}")
endif()
list(APPEND TEMP_LIST "${line}")
endforeach()
file(WRITE "${latexDir}/${TEX}" ${TEMP_LIST})
endforeach()
endfunction()