Index: clang-tools-extra/clang-doc/HTMLGenerator.cpp
===================================================================
--- clang-tools-extra/clang-doc/HTMLGenerator.cpp
+++ clang-tools-extra/clang-doc/HTMLGenerator.cpp
@@ -693,6 +693,24 @@
return true;
}
+static bool GenIndex(const ClangDocContext &CDCtx) {
+ std::error_code FileErr, OK;
+ llvm::SmallString<128> IndexPath;
+ llvm::sys::path::native(CDCtx.OutDirectory, IndexPath);
+ llvm::sys::path::append(IndexPath, "index.html");
+ llvm::raw_fd_ostream IndexOS(IndexPath, FileErr, llvm::sys::fs::F_None);
+ if (FileErr != OK) {
+ llvm::errs() << "Error creating main index: " << FileErr.message() << "\n";
+ return false;
+ }
+ HTMLFile F;
+ std::vector> BasicNodes =
+ genCommonFileNodes("Index", "", CDCtx);
+ AppendVector(std::move(BasicNodes), F.Children);
+ F.Render(IndexOS);
+ return true;
+}
+
static bool CopyFile(StringRef FilePath, StringRef OutDirectory) {
llvm::SmallString<128> PathWrite;
llvm::sys::path::native(OutDirectory, PathWrite);
@@ -711,7 +729,7 @@
}
bool HTMLGenerator::createResources(ClangDocContext &CDCtx) {
- if (!SerializeIndex(CDCtx))
+ if (!SerializeIndex(CDCtx) || !GenIndex(CDCtx))
return false;
for (const auto &FilePath : CDCtx.UserStylesheets)
if (!CopyFile(FilePath, CDCtx.OutDirectory))