diff options
Diffstat (limited to 'contrib/llvm/tools/clang/lib/Frontend/CompilerInvocation.cpp')
| -rw-r--r-- | contrib/llvm/tools/clang/lib/Frontend/CompilerInvocation.cpp | 19 | 
1 files changed, 15 insertions, 4 deletions
| diff --git a/contrib/llvm/tools/clang/lib/Frontend/CompilerInvocation.cpp b/contrib/llvm/tools/clang/lib/Frontend/CompilerInvocation.cpp index 51147b6f9499..7d7e7d49e9f0 100644 --- a/contrib/llvm/tools/clang/lib/Frontend/CompilerInvocation.cpp +++ b/contrib/llvm/tools/clang/lib/Frontend/CompilerInvocation.cpp @@ -534,6 +534,7 @@ static bool ParseCodeGenArgs(CodeGenOptions &Opts, ArgList &Args, InputKind IK,    Opts.DisableLLVMPasses = Args.hasArg(OPT_disable_llvm_passes);    Opts.DisableLifetimeMarkers = Args.hasArg(OPT_disable_lifetimemarkers); +  Opts.DisableO0ImplyOptNone = Args.hasArg(OPT_disable_O0_optnone);    Opts.DisableRedZone = Args.hasArg(OPT_disable_red_zone);    Opts.ForbidGuardVariables = Args.hasArg(OPT_fforbid_guard_variables);    Opts.UseRegisterSizedBitfieldAccess = Args.hasArg( @@ -1087,6 +1088,9 @@ bool clang::ParseDiagnosticArgs(DiagnosticOptions &Opts, ArgList &Args,    Opts.SpellCheckingLimit = getLastArgIntValue(        Args, OPT_fspell_checking_limit,        DiagnosticOptions::DefaultSpellCheckingLimit, Diags); +  Opts.SnippetLineLimit = getLastArgIntValue( +      Args, OPT_fcaret_diagnostics_max_lines, +      DiagnosticOptions::DefaultSnippetLineLimit, Diags);    Opts.TabStop = getLastArgIntValue(Args, OPT_ftabstop,                                      DiagnosticOptions::DefaultTabStop, Diags);    if (Opts.TabStop == 0 || Opts.TabStop > DiagnosticOptions::MaxTabStop) { @@ -2747,15 +2751,22 @@ void BuryPointer(const void *Ptr) {  IntrusiveRefCntPtr<vfs::FileSystem>  createVFSFromCompilerInvocation(const CompilerInvocation &CI,                                  DiagnosticsEngine &Diags) { +  return createVFSFromCompilerInvocation(CI, Diags, vfs::getRealFileSystem()); +} + +IntrusiveRefCntPtr<vfs::FileSystem> +createVFSFromCompilerInvocation(const CompilerInvocation &CI, +                                DiagnosticsEngine &Diags, +                                IntrusiveRefCntPtr<vfs::FileSystem> BaseFS) {    if (CI.getHeaderSearchOpts().VFSOverlayFiles.empty()) -    return vfs::getRealFileSystem(); +    return BaseFS; -  IntrusiveRefCntPtr<vfs::OverlayFileSystem> -    Overlay(new vfs::OverlayFileSystem(vfs::getRealFileSystem())); +  IntrusiveRefCntPtr<vfs::OverlayFileSystem> Overlay( +      new vfs::OverlayFileSystem(BaseFS));    // earlier vfs files are on the bottom    for (const std::string &File : CI.getHeaderSearchOpts().VFSOverlayFiles) {      llvm::ErrorOr<std::unique_ptr<llvm::MemoryBuffer>> Buffer = -        llvm::MemoryBuffer::getFile(File); +        BaseFS->getBufferForFile(File);      if (!Buffer) {        Diags.Report(diag::err_missing_vfs_overlay_file) << File;        return IntrusiveRefCntPtr<vfs::FileSystem>(); | 
