diff options
| -rw-r--r-- | clang/lib/Frontend/PrintPreprocessedOutput.cpp | 5 | ||||
| -rw-r--r-- | clang/lib/Rewrite/Frontend/InclusionRewriter.cpp | 4 | ||||
| -rw-r--r-- | clang/test/Preprocessor/line-directive-output.c | 3 | 
3 files changed, 8 insertions, 4 deletions
diff --git a/clang/lib/Frontend/PrintPreprocessedOutput.cpp b/clang/lib/Frontend/PrintPreprocessedOutput.cpp index 83b2a271ec3..e0ec08fb90a 100644 --- a/clang/lib/Frontend/PrintPreprocessedOutput.cpp +++ b/clang/lib/Frontend/PrintPreprocessedOutput.cpp @@ -190,11 +190,11 @@ void PrintPPOutputPPCallbacks::WriteLineInfo(unsigned LineNo,    // Emit #line directives or GNU line markers depending on what mode we're in.    if (UseLineDirective) {      OS << "#line" << ' ' << LineNo << ' ' << '"'; -    OS.write(CurFilename.data(), CurFilename.size()); +    OS.write_escaped(CurFilename);      OS << '"';    } else {      OS << '#' << ' ' << LineNo << ' ' << '"'; -    OS.write(CurFilename.data(), CurFilename.size()); +    OS.write_escaped(CurFilename);      OS << '"';      if (ExtraLen) @@ -285,7 +285,6 @@ void PrintPPOutputPPCallbacks::FileChanged(SourceLocation Loc,    CurFilename.clear();    CurFilename += UserLoc.getFilename(); -  Lexer::Stringify(CurFilename);    FileType = NewFileType;    if (DisableLineMarkers) { diff --git a/clang/lib/Rewrite/Frontend/InclusionRewriter.cpp b/clang/lib/Rewrite/Frontend/InclusionRewriter.cpp index a2297f9179d..3fba6905e1e 100644 --- a/clang/lib/Rewrite/Frontend/InclusionRewriter.cpp +++ b/clang/lib/Rewrite/Frontend/InclusionRewriter.cpp @@ -114,7 +114,9 @@ void InclusionRewriter::WriteLineInfo(const char *Filename, int Line,    } else {      // Use GNU linemarkers as described here:      // http://gcc.gnu.org/onlinedocs/cpp/Preprocessor-Output.html -    OS << '#' << ' ' << Line << ' ' << '"' << Filename << '"'; +    OS << '#' << ' ' << Line << ' ' << '"'; +    OS.write_escaped(Filename); +    OS << '"';      if (!Extra.empty())        OS << Extra;      if (FileType == SrcMgr::C_System) diff --git a/clang/test/Preprocessor/line-directive-output.c b/clang/test/Preprocessor/line-directive-output.c index bd3ea949ebd..5c0aef8b321 100644 --- a/clang/test/Preprocessor/line-directive-output.c +++ b/clang/test/Preprocessor/line-directive-output.c @@ -73,3 +73,6 @@ extern int z;  # 42 "A.c"  # 44 "A.c"  # 49 "A.c" + +// CHECK: # 50 "a\n.c" +# 50 "a\012.c"  | 

