[Flang] Generate documentation for compiler flags

This patch aims to create a webpage to document
Flang's command line options on https://flang.llvm.org/docs/
in a similar way to Clang's
https://clang.llvm.org/docs/ClangCommandLineReference.html

This is done by using clang_tablegen to generate an .rst
file from Options.td (which is current shared with Clang)
For this to work, ClangOptionDocEmitter.cpp was updated
to allow specific Flang flags to be included,
rather than bulk excluding clang flags.

Reviewed By: awarzynski

Differential Revision: https://reviews.llvm.org/D129864
This commit is contained in:
Dylan Fleming 2022-07-21 11:11:48 +00:00
parent 8bb4451a65
commit 396e944d82
4 changed files with 75 additions and 0 deletions

View File

@ -168,6 +168,29 @@ bool hasFlag(const Record *OptionOrGroup, StringRef OptionFlag) {
return false; return false;
} }
bool isIncluded(const Record *OptionOrGroup, const Record *DocInfo) {
assert(DocInfo->getValue("IncludedFlags") && "Missing includeFlags");
for (StringRef Inclusion : DocInfo->getValueAsListOfStrings("IncludedFlags"))
if (hasFlag(OptionOrGroup, Inclusion))
return true;
return false;
}
bool isGroupIncluded(const DocumentedGroup &Group, const Record *DocInfo) {
if (isIncluded(Group.Group, DocInfo))
return true;
for (auto &O : Group.Options)
if (isIncluded(O.Option, DocInfo))
return true;
for (auto &G : Group.Groups) {
if (isIncluded(G.Group, DocInfo))
return true;
if (isGroupIncluded(G, DocInfo))
return true;
}
return false;
}
bool isExcluded(const Record *OptionOrGroup, const Record *DocInfo) { bool isExcluded(const Record *OptionOrGroup, const Record *DocInfo) {
// FIXME: Provide a flag to specify the set of exclusions. // FIXME: Provide a flag to specify the set of exclusions.
for (StringRef Exclusion : DocInfo->getValueAsListOfStrings("ExcludedFlags")) for (StringRef Exclusion : DocInfo->getValueAsListOfStrings("ExcludedFlags"))
@ -304,6 +327,8 @@ void emitOption(const DocumentedOption &Option, const Record *DocInfo,
raw_ostream &OS) { raw_ostream &OS) {
if (isExcluded(Option.Option, DocInfo)) if (isExcluded(Option.Option, DocInfo))
return; return;
if (DocInfo->getValue("IncludedFlags") && !isIncluded(Option.Option, DocInfo))
return;
if (Option.Option->getValueAsDef("Kind")->getName() == "KIND_UNKNOWN" || if (Option.Option->getValueAsDef("Kind")->getName() == "KIND_UNKNOWN" ||
Option.Option->getValueAsDef("Kind")->getName() == "KIND_INPUT") Option.Option->getValueAsDef("Kind")->getName() == "KIND_INPUT")
return; return;
@ -379,6 +404,9 @@ void emitGroup(int Depth, const DocumentedGroup &Group, const Record *DocInfo,
if (isExcluded(Group.Group, DocInfo)) if (isExcluded(Group.Group, DocInfo))
return; return;
if (DocInfo->getValue("IncludedFlags") && !isGroupIncluded(Group, DocInfo))
return;
emitHeading(Depth, emitHeading(Depth,
getRSTStringWithTextFallback(Group.Group, "DocName", "Name"), OS); getRSTStringWithTextFallback(Group.Group, "DocName", "Name"), OS);

View File

@ -91,6 +91,16 @@ if (LLVM_ENABLE_DOXYGEN)
endif() endif()
endif() endif()
function (gen_rst_file_from_td output_file td_option source docs_target)
if (NOT EXISTS "${CMAKE_CURRENT_SOURCE_DIR}/${source}")
message(FATAL_ERROR "Cannot find source file: ${source} in ${CMAKE_CURRENT_SOURCE_DIR}")
endif()
get_filename_component(TABLEGEN_INCLUDE_DIR "${CMAKE_CURRENT_SOURCE_DIR}/${source}" DIRECTORY)
list(APPEND LLVM_TABLEGEN_FLAGS "-I${TABLEGEN_INCLUDE_DIR}")
clang_tablegen(Source/${output_file} ${td_option} SOURCE ${source} TARGET "gen-${output_file}")
add_dependencies(${docs_target} "gen-${output_file}")
endfunction()
if (LLVM_ENABLE_SPHINX) if (LLVM_ENABLE_SPHINX)
include(AddSphinxTarget) include(AddSphinxTarget)
if (SPHINX_FOUND) if (SPHINX_FOUND)
@ -114,6 +124,7 @@ if (LLVM_ENABLE_SPHINX)
COMMAND "${Python3_EXECUTABLE}" COMMAND "${Python3_EXECUTABLE}"
ARGS ${CMAKE_CURRENT_BINARY_DIR}/Source/FIR/CreateFIRLangRef.py) ARGS ${CMAKE_CURRENT_BINARY_DIR}/Source/FIR/CreateFIRLangRef.py)
gen_rst_file_from_td(FlangCommandLineReference.rst -gen-opt-docs ../include/flang/FlangOptionsDocs.td docs-flang-html)
endif() endif()
if (${SPHINX_OUTPUT_MAN}) if (${SPHINX_OUTPUT_MAN})
add_sphinx_target(man flang) add_sphinx_target(man flang)

View File

@ -45,6 +45,7 @@ on how to get in touch with us and to learn more about the current status.
DoConcurrent DoConcurrent
Extensions Extensions
FIRLangRef FIRLangRef
FlangCommandLineReference
FlangDriver FlangDriver
FortranIR FortranIR
FortranLLVMTestSuite FortranLLVMTestSuite

View File

@ -0,0 +1,35 @@
//==--- FlangOptionDocs.td - Option documentation -------------------------===//
//
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
// See https://llvm.org/LICENSE.txt for license information.
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
//
//===----------------------------------------------------------------------===//
def GlobalDocumentation {
code Intro =[{..
-------------------------------------------------------------------
NOTE: This file is automatically generated by running clang-tblgen
-gen-opt-docs. Do not edit this file by hand!!
-------------------------------------------------------------------
=====================================
Flang command line argument reference
=====================================
.. contents::
:local:
Introduction
============
}];
string Program = "flang";
list<string> ExcludedFlags = [];
list<string> IncludedFlags = ["FlangOption"];
}
include "../../../clang/include/clang/Driver/Options.td"