diff options
| author | Dimitry Andric <dim@FreeBSD.org> | 2019-08-20 20:50:49 +0000 | 
|---|---|---|
| committer | Dimitry Andric <dim@FreeBSD.org> | 2019-08-20 20:50:49 +0000 | 
| commit | 2298981669bf3bd63335a4be179bc0f96823a8f4 (patch) | |
| tree | 1cbe2eb27f030d2d70b80ee5ca3c86bee7326a9f /lib/Frontend/FrontendAction.cpp | |
| parent | 9a83721404652cea39e9f02ae3e3b5c964602a5c (diff) | |
Diffstat (limited to 'lib/Frontend/FrontendAction.cpp')
| -rw-r--r-- | lib/Frontend/FrontendAction.cpp | 30 | 
1 files changed, 19 insertions, 11 deletions
| diff --git a/lib/Frontend/FrontendAction.cpp b/lib/Frontend/FrontendAction.cpp index f5226380b4dd5..d724bbce3749e 100644 --- a/lib/Frontend/FrontendAction.cpp +++ b/lib/Frontend/FrontendAction.cpp @@ -1,9 +1,8 @@  //===--- FrontendAction.cpp -----------------------------------------------===//  // -//                     The LLVM Compiler Infrastructure -// -// This file is distributed under the University of Illinois Open Source -// License. See LICENSE.TXT for details. +// 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  //  //===----------------------------------------------------------------------===// @@ -361,7 +360,7 @@ static std::error_code collectModuleHeaderIncludes(      SmallString<128> DirNative;      llvm::sys::path::native(UmbrellaDir.Entry->getName(), DirNative); -    llvm::vfs::FileSystem &FS = *FileMgr.getVirtualFileSystem(); +    llvm::vfs::FileSystem &FS = FileMgr.getVirtualFileSystem();      for (llvm::vfs::recursive_directory_iterator Dir(FS, DirNative, EC), End;           Dir != End && !EC; Dir.increment(EC)) {        // Check whether this entry has an extension typically associated with @@ -715,7 +714,7 @@ bool FrontendAction::BeginSourceFile(CompilerInstance &CI,        SmallString<128> DirNative;        llvm::sys::path::native(PCHDir->getName(), DirNative);        bool Found = false; -      llvm::vfs::FileSystem &FS = *FileMgr.getVirtualFileSystem(); +      llvm::vfs::FileSystem &FS = FileMgr.getVirtualFileSystem();        for (llvm::vfs::directory_iterator Dir = FS.dir_begin(DirNative, EC),                                           DirEnd;             Dir != DirEnd && !EC; Dir.increment(EC)) { @@ -925,7 +924,7 @@ failure:    return false;  } -bool FrontendAction::Execute() { +llvm::Error FrontendAction::Execute() {    CompilerInstance &CI = getCompilerInstance();    if (CI.hasFrontendTimer()) { @@ -940,12 +939,18 @@ bool FrontendAction::Execute() {        CI.hasPreprocessor()) {      StringRef Cache =          CI.getPreprocessor().getHeaderSearchInfo().getModuleCachePath(); -    if (!Cache.empty()) -      GlobalModuleIndex::writeIndex(CI.getFileManager(), -                                    CI.getPCHContainerReader(), Cache); +    if (!Cache.empty()) { +      if (llvm::Error Err = GlobalModuleIndex::writeIndex( +              CI.getFileManager(), CI.getPCHContainerReader(), Cache)) { +        // FIXME this drops the error on the floor, but +        // Index/pch-from-libclang.c seems to rely on dropping at least some of +        // the error conditions! +        consumeError(std::move(Err)); +      } +    }    } -  return true; +  return llvm::Error::success();  }  void FrontendAction::EndSourceFile() { @@ -1045,6 +1050,9 @@ PreprocessorFrontendAction::CreateASTConsumer(CompilerInstance &CI,    llvm_unreachable("Invalid CreateASTConsumer on preprocessor action!");  } +bool WrapperFrontendAction::PrepareToExecuteAction(CompilerInstance &CI) { +  return WrappedAction->PrepareToExecuteAction(CI); +}  std::unique_ptr<ASTConsumer>  WrapperFrontendAction::CreateASTConsumer(CompilerInstance &CI,                                           StringRef InFile) { | 
