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))