blob: 2a9110f8eba7e78dfc4ad8a4dbd873ad735de46f [file] [log] [blame]
//===--- ClangCommentHTMLTagsEmitter.cpp - Generate HTML tag list for Clang -=//
//
// The LLVM Compiler Infrastructure
//
// This file is distributed under the University of Illinois Open Source
// License. See LICENSE.TXT for details.
//
//===----------------------------------------------------------------------===//
//
// This tablegen backend emits efficient matchers for HTML tags that are used
// in documentation comments.
//
//===----------------------------------------------------------------------===//
#include "TableGenBackends.h"
#include "llvm/TableGen/Record.h"
#include "llvm/TableGen/StringMatcher.h"
#include "llvm/TableGen/TableGenBackend.h"
#include <vector>
using namespace llvm;
void clang::EmitClangCommentHTMLTags(RecordKeeper &Records, raw_ostream &OS) {
std::vector<Record *> Tags = Records.getAllDerivedDefinitions("Tag");
std::vector<StringMatcher::StringPair> Matches;
for (Record *Tag : Tags) {
std::string Spelling = Tag->getValueAsString("Spelling");
Matches.push_back(StringMatcher::StringPair(Spelling, "return true;"));
}
emitSourceFileHeader("HTML tag name matcher", OS);
OS << "bool isHTMLTagName(StringRef Name) {\n";
StringMatcher("Name", Matches, OS).Emit();
OS << " return false;\n"
<< "}\n\n";
}
void clang::EmitClangCommentHTMLTagsProperties(RecordKeeper &Records,
raw_ostream &OS) {
std::vector<Record *> Tags = Records.getAllDerivedDefinitions("Tag");
std::vector<StringMatcher::StringPair> MatchesEndTagOptional;
std::vector<StringMatcher::StringPair> MatchesEndTagForbidden;
for (Record *Tag : Tags) {
std::string Spelling = Tag->getValueAsString("Spelling");
StringMatcher::StringPair Match(Spelling, "return true;");
if (Tag->getValueAsBit("EndTagOptional"))
MatchesEndTagOptional.push_back(Match);
if (Tag->getValueAsBit("EndTagForbidden"))
MatchesEndTagForbidden.push_back(Match);
}
emitSourceFileHeader("HTML tag properties", OS);
OS << "bool isHTMLEndTagOptional(StringRef Name) {\n";
StringMatcher("Name", MatchesEndTagOptional, OS).Emit();
OS << " return false;\n"
<< "}\n\n";
OS << "bool isHTMLEndTagForbidden(StringRef Name) {\n";
StringMatcher("Name", MatchesEndTagForbidden, OS).Emit();
OS << " return false;\n"
<< "}\n\n";
std::vector<Record *> Attributes =
Records.getAllDerivedDefinitions("Attribute");
std::vector<StringMatcher::StringPair> Matches;
for (Record *Attribute : Attributes) {
std::string Spelling = Attribute->getValueAsString("Spelling");
if (!Attribute->getValueAsBit("IsSafeToPassThrough"))
Matches.push_back(StringMatcher::StringPair(Spelling, "return false;"));
}
emitSourceFileHeader("HTML attribute name matcher", OS);
OS << "bool isHTMLAttributeSafeToPassThrough(StringRef Name) {\n";
StringMatcher("Name", Matches, OS).Emit();
OS << " return true;\n"
<< "}\n\n";
}