[X86] AMD Zen 5 Initial enablement
[llvm-project.git] / flang / docs / CMakeLists.txt
blob3e4883e881ffac766d569444f75a0871a299e26d
2 find_package(Doxygen)
3 if (DOXYGEN_FOUND)
4 if (LLVM_ENABLE_DOXYGEN)
5   set(abs_top_srcdir ${CMAKE_CURRENT_SOURCE_DIR})
6   set(abs_top_builddir ${CMAKE_CURRENT_BINARY_DIR})
8   if (HAVE_DOT)
9     set(DOT ${LLVM_PATH_DOT})
10   endif()
12   if (LLVM_DOXYGEN_EXTERNAL_SEARCH)
13     set(enable_searchengine "YES")
14     set(searchengine_url "${LLVM_DOXYGEN_SEARCHENGINE_URL}")
15     set(enable_server_based_search "YES")
16     set(enable_external_search "YES")
17     set(extra_search_mappings "${LLVM_DOXYGEN_SEARCH_MAPPINGS}")
18   else()
19     set(enable_searchengine "NO")
20     set(searchengine_url "")
21     set(enable_server_based_search "NO")
22     set(enable_external_search "NO")
23     set(extra_search_mappings "")
24   endif()
26   # If asked, configure doxygen for the creation of a Qt Compressed Help file.
27   if (LLVM_ENABLE_DOXYGEN_QT_HELP)
28     set(FLANG_DOXYGEN_QCH_FILENAME "org.llvm.flang.qch" CACHE STRING
29       "Filename of the Qt Compressed help file")
30     set(FLANG_DOXYGEN_QHP_NAMESPACE "org.llvm.flang" CACHE STRING
31       "Namespace under which the intermediate Qt Help Project file lives")
32     set(FLANG_DOXYGEN_QHP_CUST_FILTER_NAME "FLANG ${FLANG_VERSION}" CACHE STRING
33       "See http://qt-project.org/doc/qt-4.8/qthelpproject.html#custom-filters")
34     set(FLANG_DOXYGEN_QHP_CUST_FILTER_ATTRS "FLANG,${FLANG_VERSION}" CACHE STRING
35       "See http://qt-project.org/doc/qt-4.8/qthelpproject.html#filter-attributes")
36     set(flang_doxygen_generate_qhp "YES")
37     set(flang_doxygen_qch_filename "${FLANG_DOXYGEN_QCH_FILENAME}")
38     set(flang_doxygen_qhp_namespace "${FLANG_DOXYGEN_QHP_NAMESPACE}")
39     set(flang_doxygen_qhelpgenerator_path "${LLVM_DOXYGEN_QHELPGENERATOR_PATH}")
40     set(flang_doxygen_qhp_cust_filter_name "${FLANG_DOXYGEN_QHP_CUST_FILTER_NAME}")
41     set(flang_doxygen_qhp_cust_filter_attrs "${FLANG_DOXYGEN_QHP_CUST_FILTER_ATTRS}")
42   else()
43     set(flang_doxygen_generate_qhp "NO")
44     set(flang_doxygen_qch_filename "")
45     set(flang_doxygen_qhp_namespace "")
46     set(flang_doxygen_qhelpgenerator_path "")
47     set(flang_doxygen_qhp_cust_filter_name "")
48     set(flang_doxygen_qhp_cust_filter_attrs "")
49   endif()
51   option(LLVM_DOXYGEN_SVG
52     "Use svg instead of png files for doxygen graphs." OFF)
53   if (LLVM_DOXYGEN_SVG)
54     set(DOT_IMAGE_FORMAT "svg")
55   else()
56     set(DOT_IMAGE_FORMAT "png")
57   endif()
59   configure_file(${CMAKE_CURRENT_SOURCE_DIR}/doxygen.cfg.in
60     ${CMAKE_CURRENT_BINARY_DIR}/doxygen.cfg @ONLY)
62   set(abs_top_srcdir)
63   set(abs_top_builddir)
64   set(DOT)
65   set(enable_searchengine)
66   set(searchengine_url)
67   set(enable_server_based_search)
68   set(enable_external_search)
69   set(extra_search_mappings)
70   set(flang_doxygen_generate_qhp)
71   set(flang_doxygen_qch_filename)
72   set(flang_doxygen_qhp_namespace)
73   set(flang_doxygen_qhelpgenerator_path)
74   set(flang_doxygen_qhp_cust_filter_name)
75   set(flang_doxygen_qhp_cust_filter_attrs)
76   set(DOT_IMAGE_FORMAT)
78   add_custom_target(doxygen-flang
79     COMMAND ${DOXYGEN_EXECUTABLE} ${CMAKE_CURRENT_BINARY_DIR}/doxygen.cfg
80     WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}
81     COMMENT "Generating flang doxygen documentation." VERBATIM)
82   set_target_properties(doxygen-flang PROPERTIES FOLDER "Flang/Docs")
83   if (LLVM_BUILD_DOCS)
84    add_dependencies(doxygen doxygen-flang)
85   endif()
87   if (NOT LLVM_INSTALL_TOOLCHAIN_ONLY AND LLVM_BUILD_DOCS)
88     install(DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}/doxygen/html
89       DESTINATION docs/html)
90   endif()
91 endif()
92 endif()
94 function (gen_rst_file_from_td output_file td_option source docs_target)
95   if (NOT EXISTS "${CMAKE_CURRENT_SOURCE_DIR}/${source}")
96     message(FATAL_ERROR "Cannot find source file: ${source} in ${CMAKE_CURRENT_SOURCE_DIR}")
97   endif()
98   get_filename_component(TABLEGEN_INCLUDE_DIR "${CMAKE_CURRENT_SOURCE_DIR}/${source}" DIRECTORY)
99   list(APPEND LLVM_TABLEGEN_FLAGS "-I${TABLEGEN_INCLUDE_DIR}")
100   list(APPEND LLVM_TABLEGEN_FLAGS "-I${CMAKE_CURRENT_SOURCE_DIR}/../../clang/include/clang/Driver/")
101   clang_tablegen(Source/${output_file} ${td_option} SOURCE ${source} TARGET "gen-${output_file}")
102   add_dependencies(${docs_target} "gen-${output_file}")
103 endfunction()
105 if (LLVM_ENABLE_SPHINX)
106   include(AddSphinxTarget)
107   if (SPHINX_FOUND)
108     if (${SPHINX_OUTPUT_HTML})
109       add_sphinx_target(html flang SOURCE_DIR "${CMAKE_CURRENT_BINARY_DIR}/Source")
111       add_dependencies(docs-flang-html copy-flang-src-docs)
113       # Copy the flang/docs directory and the generated FIRLangRef.md file to a place in the binary directory.
114       # Having all the files in a single directory makes it possible for Sphinx to process them together.
115       # Add a dependency to the flang-doc target to ensure that the FIRLangRef.md file is generated before the copying happens.
116       add_custom_target(copy-flang-src-docs
117         COMMAND "${CMAKE_COMMAND}" -E copy_directory
118         "${CMAKE_CURRENT_SOURCE_DIR}"
119         "${CMAKE_CURRENT_BINARY_DIR}/Source"
120         DEPENDS flang-doc)
122       # Runs a python script prior to HTML generation to prepend a header to FIRLangRef,
123       # Without the header, the page is incorrectly formatted, as it assumes the first entry is the page title.
124       add_custom_command(TARGET copy-flang-src-docs
125         COMMAND "${Python3_EXECUTABLE}"
126         ARGS ${CMAKE_CURRENT_BINARY_DIR}/Source/FIR/CreateFIRLangRef.py)
128       # CLANG_TABLEGEN_EXE variable needs to be set for clang_tablegen to run without error
129       find_program(CLANG_TABLEGEN_EXE "clang-tblgen" ${LLVM_TOOLS_BINARY_DIR} NO_DEFAULT_PATH)
130       gen_rst_file_from_td(FlangCommandLineReference.rst -gen-opt-docs FlangOptionsDocs.td docs-flang-html)
131     endif()
132     if (${SPHINX_OUTPUT_MAN})
133       add_sphinx_target(man flang)
134     endif()
135   endif()
136 endif()