From: Aaron Ballman Date: Tue, 17 Jul 2012 23:19:16 +0000 (+0000) Subject: Adding a fixit for includes that cannot be found with angle brackets, but can be... X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=a52f5a3ee2156849b3b91255c360b9f0bb1ebd51;p=clang Adding a fixit for includes that cannot be found with angle brackets, but can be found with quoted strings instead. Implements PR13201. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@160406 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/include/clang/Basic/DiagnosticLexKinds.td b/include/clang/Basic/DiagnosticLexKinds.td index 77b7f42872..1d55d6e50d 100644 --- a/include/clang/Basic/DiagnosticLexKinds.td +++ b/include/clang/Basic/DiagnosticLexKinds.td @@ -279,6 +279,8 @@ def note_macro_here : Note<"macro %0 defined here">; def err_pp_invalid_directive : Error<"invalid preprocessing directive">; def err_pp_file_not_found : Error<"'%0' file not found">, DefaultFatal; +def err_pp_file_not_found_not_fatal : Error< + "'%0' file not found with include; use \"quotes\" instead">; def err_pp_error_opening_file : Error< "error opening file '%0': %1">, DefaultFatal; def err_pp_empty_filename : Error<"empty filename">; diff --git a/lib/Lex/PPDirectives.cpp b/lib/Lex/PPDirectives.cpp index a6b7b52624..74b9cbc881 100644 --- a/lib/Lex/PPDirectives.cpp +++ b/lib/Lex/PPDirectives.cpp @@ -1390,9 +1390,28 @@ void Preprocessor::HandleIncludeDirective(SourceLocation HashLoc, } if (File == 0) { - if (!SuppressIncludeNotFoundError) - Diag(FilenameTok, diag::err_pp_file_not_found) << Filename; - return; + if (!SuppressIncludeNotFoundError) { + // If the file could not be located and it was included via angle + // brackets, we can attempt a lookup as though it were a quoted path to + // provide the user with a possible fixit. + if (isAngled) { + File = LookupFile(Filename, false, LookupFrom, CurDir, + Callbacks ? &SearchPath : 0, + Callbacks ? &RelativePath : 0, + getLangOpts().Modules ? &SuggestedModule : 0); + if (File) { + SourceRange Range(FilenameTok.getLocation(), CharEnd); + Diag(FilenameTok, diag::err_pp_file_not_found_not_fatal) << + Filename << + FixItHint::CreateReplacement(Range, "\"" + Filename.str() + "\""); + } + } + // If the file is still not found, just go with the vanilla diagnostic + if (!File) + Diag(FilenameTok, diag::err_pp_file_not_found) << Filename; + } + if (!File) + return; } // If we are supposed to import a module rather than including the header, diff --git a/test/FixIt/fixit-include.c b/test/FixIt/fixit-include.c new file mode 100644 index 0000000000..9da9409a7e --- /dev/null +++ b/test/FixIt/fixit-include.c @@ -0,0 +1,13 @@ +// RUN: %clang_cc1 -fsyntax-only -Wall -pedantic -verify %s +// RUN: cp %s %t +// RUN: cp %S/fixit-include.h %T +// RUN: not %clang_cc1 -fsyntax-only -fixit %t +// RUN: %clang_cc1 -Wall -pedantic %t + +#include // expected-error {{'fixit-include.h' file not found with include; use "quotes" instead}} + +#pragma does_not_exist // expected-warning {{unknown pragma ignored}} + +int main( void ) { + return 0; +} diff --git a/test/FixIt/fixit-include.h b/test/FixIt/fixit-include.h new file mode 100644 index 0000000000..6a22d2e88e --- /dev/null +++ b/test/FixIt/fixit-include.h @@ -0,0 +1 @@ +// This file is purposefully left empty