123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105 |
- //===- OptParserEmitter.cpp - Table Driven Command Line Parsing -----------===//
- //
- // 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
- //
- //===----------------------------------------------------------------------===//
- #include "OptEmitter.h"
- #include "llvm/ADT/STLExtras.h"
- #include "llvm/ADT/StringMap.h"
- #include "llvm/TableGen/Record.h"
- using namespace llvm;
- /// OptParserEmitter - This tablegen backend takes an input .td file
- /// describing a list of options and emits a RST man page.
- namespace llvm {
- void EmitOptRST(RecordKeeper &Records, raw_ostream &OS) {
- llvm::StringMap<std::vector<Record *>> OptionsByGroup;
- std::vector<Record *> OptionsWithoutGroup;
- // Get the options.
- std::vector<Record *> Opts = Records.getAllDerivedDefinitions("Option");
- array_pod_sort(Opts.begin(), Opts.end(), CompareOptionRecords);
- // Get the option groups.
- const std::vector<Record *> &Groups =
- Records.getAllDerivedDefinitions("OptionGroup");
- for (unsigned i = 0, e = Groups.size(); i != e; ++i) {
- const Record &R = *Groups[i];
- OptionsByGroup.try_emplace(R.getValueAsString("Name"));
- }
- // Map options to their group.
- for (unsigned i = 0, e = Opts.size(); i != e; ++i) {
- const Record &R = *Opts[i];
- if (const DefInit *DI = dyn_cast<DefInit>(R.getValueInit("Group"))) {
- OptionsByGroup[DI->getDef()->getValueAsString("Name")].push_back(Opts[i]);
- } else {
- OptionsByGroup["options"].push_back(Opts[i]);
- }
- }
- // Print options under their group.
- for (const auto &KV : OptionsByGroup) {
- std::string GroupName = KV.getKey().upper();
- OS << GroupName << '\n';
- OS << std::string(GroupName.size(), '-') << '\n';
- OS << '\n';
- for (Record *R : KV.getValue()) {
- OS << ".. option:: ";
- // Print the prefix.
- std::vector<StringRef> Prefixes = R->getValueAsListOfStrings("Prefixes");
- if (!Prefixes.empty())
- OS << Prefixes[0];
- // Print the option name.
- OS << R->getValueAsString("Name");
- StringRef MetaVarName;
- // Print the meta-variable.
- if (!isa<UnsetInit>(R->getValueInit("MetaVarName"))) {
- MetaVarName = R->getValueAsString("MetaVarName");
- } else if (!isa<UnsetInit>(R->getValueInit("Values")))
- MetaVarName = "<value>";
- if (!MetaVarName.empty()) {
- OS << '=';
- OS.write_escaped(MetaVarName);
- }
- OS << "\n\n";
- std::string HelpText;
- // The option help text.
- if (!isa<UnsetInit>(R->getValueInit("HelpText"))) {
- HelpText = R->getValueAsString("HelpText").trim().str();
- if (!HelpText.empty() && HelpText.back() != '.')
- HelpText.push_back('.');
- }
- if (!isa<UnsetInit>(R->getValueInit("Values"))) {
- SmallVector<StringRef> Values;
- SplitString(R->getValueAsString("Values"), Values, ",");
- HelpText += (" " + MetaVarName + " must be '").str();
- if (Values.size() > 1) {
- HelpText += join(Values.begin(), Values.end() - 1, "', '");
- HelpText += "' or '";
- }
- HelpText += (Values.front() + "'.").str();
- }
- if (!HelpText.empty()) {
- OS << ' ';
- OS.write_escaped(HelpText);
- OS << "\n\n";
- }
- }
- }
- }
- } // end namespace llvm
|