1 //===--- PPDirectives.cpp - Directive Handling for Preprocessor -----------===//
2 //
3 //                     The LLVM Compiler Infrastructure
4 //
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
7 //
8 //===----------------------------------------------------------------------===//
9 ///
10 /// \file
11 /// \brief Implements # directive processing for the Preprocessor.
12 ///
13 //===----------------------------------------------------------------------===//
14 
15 #include "clang/Lex/Preprocessor.h"
16 #include "clang/Basic/FileManager.h"
17 #include "clang/Basic/SourceManager.h"
18 #include "clang/Lex/CodeCompletionHandler.h"
19 #include "clang/Lex/HeaderSearch.h"
20 #include "clang/Lex/HeaderSearchOptions.h"
21 #include "clang/Lex/LexDiagnostic.h"
22 #include "clang/Lex/LiteralSupport.h"
23 #include "clang/Lex/MacroInfo.h"
24 #include "clang/Lex/ModuleLoader.h"
25 #include "clang/Lex/Pragma.h"
26 #include "llvm/ADT/APInt.h"
27 #include "llvm/Support/ErrorHandling.h"
28 #include "llvm/Support/Path.h"
29 #include "llvm/Support/SaveAndRestore.h"
30 using namespace clang;
31 
32 //===----------------------------------------------------------------------===//
33 // Utility Methods for Preprocessor Directive Handling.
34 //===----------------------------------------------------------------------===//
35 
36 MacroInfo *Preprocessor::AllocateMacroInfo() {
37   MacroInfoChain *MIChain = BP.Allocate<MacroInfoChain>();
38   MIChain->Next = MIChainHead;
39   MIChainHead = MIChain;
40   return &MIChain->MI;
41 }
42 
43 MacroInfo *Preprocessor::AllocateMacroInfo(SourceLocation L) {
44   MacroInfo *MI = AllocateMacroInfo();
45   new (MI) MacroInfo(L);
46   return MI;
47 }
48 
49 MacroInfo *Preprocessor::AllocateDeserializedMacroInfo(SourceLocation L,
50                                                        unsigned SubModuleID) {
51   static_assert(llvm::AlignOf<MacroInfo>::Alignment >= sizeof(SubModuleID),
52                 "alignment for MacroInfo is less than the ID");
53   DeserializedMacroInfoChain *MIChain =
54       BP.Allocate<DeserializedMacroInfoChain>();
55   MIChain->Next = DeserialMIChainHead;
56   DeserialMIChainHead = MIChain;
57 
58   MacroInfo *MI = &MIChain->MI;
59   new (MI) MacroInfo(L);
60   MI->FromASTFile = true;
61   MI->setOwningModuleID(SubModuleID);
62   return MI;
63 }
64 
65 DefMacroDirective *
66 Preprocessor::AllocateDefMacroDirective(MacroInfo *MI, SourceLocation Loc,
67                                         unsigned ImportedFromModuleID,
68                                         ArrayRef<unsigned> Overrides) {
69   unsigned NumExtra = (ImportedFromModuleID ? 1 : 0) + Overrides.size();
70   return new (BP.Allocate(sizeof(DefMacroDirective) +
71                               sizeof(unsigned) * NumExtra,
72                           llvm::alignOf<DefMacroDirective>()))
73       DefMacroDirective(MI, Loc, ImportedFromModuleID, Overrides);
74 }
75 
76 UndefMacroDirective *
77 Preprocessor::AllocateUndefMacroDirective(SourceLocation UndefLoc,
78                                           unsigned ImportedFromModuleID,
79                                           ArrayRef<unsigned> Overrides) {
80   unsigned NumExtra = (ImportedFromModuleID ? 1 : 0) + Overrides.size();
81   return new (BP.Allocate(sizeof(UndefMacroDirective) +
82                               sizeof(unsigned) * NumExtra,
83                           llvm::alignOf<UndefMacroDirective>()))
84       UndefMacroDirective(UndefLoc, ImportedFromModuleID, Overrides);
85 }
86 
87 VisibilityMacroDirective *
88 Preprocessor::AllocateVisibilityMacroDirective(SourceLocation Loc,
89                                                bool isPublic) {
90   return new (BP) VisibilityMacroDirective(Loc, isPublic);
91 }
92 
93 /// \brief Read and discard all tokens remaining on the current line until
94 /// the tok::eod token is found.
95 void Preprocessor::DiscardUntilEndOfDirective() {
96   Token Tmp;
97   do {
98     LexUnexpandedToken(Tmp);
99     assert(Tmp.isNot(tok::eof) && "EOF seen while discarding directive tokens");
100   } while (Tmp.isNot(tok::eod));
101 }
102 
103 bool Preprocessor::CheckMacroName(Token &MacroNameTok, char isDefineUndef) {
104   // Missing macro name?
105   if (MacroNameTok.is(tok::eod))
106     return Diag(MacroNameTok, diag::err_pp_missing_macro_name);
107 
108   IdentifierInfo *II = MacroNameTok.getIdentifierInfo();
109   if (!II) {
110     bool Invalid = false;
111     std::string Spelling = getSpelling(MacroNameTok, &Invalid);
112     if (Invalid)
113       return Diag(MacroNameTok, diag::err_pp_macro_not_identifier);
114     II = getIdentifierInfo(Spelling);
115 
116     if (!II->isCPlusPlusOperatorKeyword())
117       return Diag(MacroNameTok, diag::err_pp_macro_not_identifier);
118 
119     // C++ 2.5p2: Alternative tokens behave the same as its primary token
120     // except for their spellings.
121     Diag(MacroNameTok, getLangOpts().MicrosoftExt
122                            ? diag::ext_pp_operator_used_as_macro_name
123                            : diag::err_pp_operator_used_as_macro_name)
124         << II << MacroNameTok.getKind();
125 
126     // Allow #defining |and| and friends for Microsoft compatibility or
127     // recovery when legacy C headers are included in C++.
128     MacroNameTok.setIdentifierInfo(II);
129   }
130 
131   if (isDefineUndef && II->getPPKeywordID() == tok::pp_defined) {
132     // Error if defining "defined": C99 6.10.8/4, C++ [cpp.predefined]p4.
133     return Diag(MacroNameTok, diag::err_defined_macro_name);
134   }
135 
136   if (isDefineUndef == 2 && II->hasMacroDefinition() &&
137       getMacroInfo(II)->isBuiltinMacro()) {
138     // Warn if undefining "__LINE__" and other builtins, per C99 6.10.8/4
139     // and C++ [cpp.predefined]p4], but allow it as an extension.
140     Diag(MacroNameTok, diag::ext_pp_undef_builtin_macro);
141   }
142 
143   // Okay, we got a good identifier.
144   return false;
145 }
146 
147 /// \brief Lex and validate a macro name, which occurs after a
148 /// \#define or \#undef.
149 ///
150 /// This sets the token kind to eod and discards the rest
151 /// of the macro line if the macro name is invalid.  \p isDefineUndef is 1 if
152 /// this is due to a a \#define, 2 if \#undef directive, 0 if it is something
153 /// else (e.g. \#ifdef).
154 void Preprocessor::ReadMacroName(Token &MacroNameTok, char isDefineUndef) {
155   // Read the token, don't allow macro expansion on it.
156   LexUnexpandedToken(MacroNameTok);
157 
158   if (MacroNameTok.is(tok::code_completion)) {
159     if (CodeComplete)
160       CodeComplete->CodeCompleteMacroName(isDefineUndef == 1);
161     setCodeCompletionReached();
162     LexUnexpandedToken(MacroNameTok);
163   }
164 
165   if (!CheckMacroName(MacroNameTok, isDefineUndef))
166     return;
167 
168   // Invalid macro name, read and discard the rest of the line and set the
169   // token kind to tok::eod if necessary.
170   if (MacroNameTok.isNot(tok::eod)) {
171     MacroNameTok.setKind(tok::eod);
172     DiscardUntilEndOfDirective();
173   }
174 }
175 
176 /// \brief Ensure that the next token is a tok::eod token.
177 ///
178 /// If not, emit a diagnostic and consume up until the eod.  If EnableMacros is
179 /// true, then we consider macros that expand to zero tokens as being ok.
180 void Preprocessor::CheckEndOfDirective(const char *DirType, bool EnableMacros) {
181   Token Tmp;
182   // Lex unexpanded tokens for most directives: macros might expand to zero
183   // tokens, causing us to miss diagnosing invalid lines.  Some directives (like
184   // #line) allow empty macros.
185   if (EnableMacros)
186     Lex(Tmp);
187   else
188     LexUnexpandedToken(Tmp);
189 
190   // There should be no tokens after the directive, but we allow them as an
191   // extension.
192   while (Tmp.is(tok::comment))  // Skip comments in -C mode.
193     LexUnexpandedToken(Tmp);
194 
195   if (Tmp.isNot(tok::eod)) {
196     // Add a fixit in GNU/C99/C++ mode.  Don't offer a fixit for strict-C89,
197     // or if this is a macro-style preprocessing directive, because it is more
198     // trouble than it is worth to insert /**/ and check that there is no /**/
199     // in the range also.
200     FixItHint Hint;
201     if ((LangOpts.GNUMode || LangOpts.C99 || LangOpts.CPlusPlus) &&
202         !CurTokenLexer)
203       Hint = FixItHint::CreateInsertion(Tmp.getLocation(),"//");
204     Diag(Tmp, diag::ext_pp_extra_tokens_at_eol) << DirType << Hint;
205     DiscardUntilEndOfDirective();
206   }
207 }
208 
209 
210 
211 /// SkipExcludedConditionalBlock - We just read a \#if or related directive and
212 /// decided that the subsequent tokens are in the \#if'd out portion of the
213 /// file.  Lex the rest of the file, until we see an \#endif.  If
214 /// FoundNonSkipPortion is true, then we have already emitted code for part of
215 /// this \#if directive, so \#else/\#elif blocks should never be entered.
216 /// If ElseOk is true, then \#else directives are ok, if not, then we have
217 /// already seen one so a \#else directive is a duplicate.  When this returns,
218 /// the caller can lex the first valid token.
219 void Preprocessor::SkipExcludedConditionalBlock(SourceLocation IfTokenLoc,
220                                                 bool FoundNonSkipPortion,
221                                                 bool FoundElse,
222                                                 SourceLocation ElseLoc) {
223   ++NumSkipped;
224   assert(!CurTokenLexer && CurPPLexer && "Lexing a macro, not a file?");
225 
226   CurPPLexer->pushConditionalLevel(IfTokenLoc, /*isSkipping*/false,
227                                  FoundNonSkipPortion, FoundElse);
228 
229   if (CurPTHLexer) {
230     PTHSkipExcludedConditionalBlock();
231     return;
232   }
233 
234   // Enter raw mode to disable identifier lookup (and thus macro expansion),
235   // disabling warnings, etc.
236   CurPPLexer->LexingRawMode = true;
237   Token Tok;
238   while (1) {
239     CurLexer->Lex(Tok);
240 
241     if (Tok.is(tok::code_completion)) {
242       if (CodeComplete)
243         CodeComplete->CodeCompleteInConditionalExclusion();
244       setCodeCompletionReached();
245       continue;
246     }
247 
248     // If this is the end of the buffer, we have an error.
249     if (Tok.is(tok::eof)) {
250       // Emit errors for each unterminated conditional on the stack, including
251       // the current one.
252       while (!CurPPLexer->ConditionalStack.empty()) {
253         if (CurLexer->getFileLoc() != CodeCompletionFileLoc)
254           Diag(CurPPLexer->ConditionalStack.back().IfLoc,
255                diag::err_pp_unterminated_conditional);
256         CurPPLexer->ConditionalStack.pop_back();
257       }
258 
259       // Just return and let the caller lex after this #include.
260       break;
261     }
262 
263     // If this token is not a preprocessor directive, just skip it.
264     if (Tok.isNot(tok::hash) || !Tok.isAtStartOfLine())
265       continue;
266 
267     // We just parsed a # character at the start of a line, so we're in
268     // directive mode.  Tell the lexer this so any newlines we see will be
269     // converted into an EOD token (this terminates the macro).
270     CurPPLexer->ParsingPreprocessorDirective = true;
271     if (CurLexer) CurLexer->SetKeepWhitespaceMode(false);
272 
273 
274     // Read the next token, the directive flavor.
275     LexUnexpandedToken(Tok);
276 
277     // If this isn't an identifier directive (e.g. is "# 1\n" or "#\n", or
278     // something bogus), skip it.
279     if (Tok.isNot(tok::raw_identifier)) {
280       CurPPLexer->ParsingPreprocessorDirective = false;
281       // Restore comment saving mode.
282       if (CurLexer) CurLexer->resetExtendedTokenMode();
283       continue;
284     }
285 
286     // If the first letter isn't i or e, it isn't intesting to us.  We know that
287     // this is safe in the face of spelling differences, because there is no way
288     // to spell an i/e in a strange way that is another letter.  Skipping this
289     // allows us to avoid looking up the identifier info for #define/#undef and
290     // other common directives.
291     StringRef RI = Tok.getRawIdentifier();
292 
293     char FirstChar = RI[0];
294     if (FirstChar >= 'a' && FirstChar <= 'z' &&
295         FirstChar != 'i' && FirstChar != 'e') {
296       CurPPLexer->ParsingPreprocessorDirective = false;
297       // Restore comment saving mode.
298       if (CurLexer) CurLexer->resetExtendedTokenMode();
299       continue;
300     }
301 
302     // Get the identifier name without trigraphs or embedded newlines.  Note
303     // that we can't use Tok.getIdentifierInfo() because its lookup is disabled
304     // when skipping.
305     char DirectiveBuf[20];
306     StringRef Directive;
307     if (!Tok.needsCleaning() && RI.size() < 20) {
308       Directive = RI;
309     } else {
310       std::string DirectiveStr = getSpelling(Tok);
311       unsigned IdLen = DirectiveStr.size();
312       if (IdLen >= 20) {
313         CurPPLexer->ParsingPreprocessorDirective = false;
314         // Restore comment saving mode.
315         if (CurLexer) CurLexer->resetExtendedTokenMode();
316         continue;
317       }
318       memcpy(DirectiveBuf, &DirectiveStr[0], IdLen);
319       Directive = StringRef(DirectiveBuf, IdLen);
320     }
321 
322     if (Directive.startswith("if")) {
323       StringRef Sub = Directive.substr(2);
324       if (Sub.empty() ||   // "if"
325           Sub == "def" ||   // "ifdef"
326           Sub == "ndef") {  // "ifndef"
327         // We know the entire #if/#ifdef/#ifndef block will be skipped, don't
328         // bother parsing the condition.
329         DiscardUntilEndOfDirective();
330         CurPPLexer->pushConditionalLevel(Tok.getLocation(), /*wasskipping*/true,
331                                        /*foundnonskip*/false,
332                                        /*foundelse*/false);
333       }
334     } else if (Directive[0] == 'e') {
335       StringRef Sub = Directive.substr(1);
336       if (Sub == "ndif") {  // "endif"
337         PPConditionalInfo CondInfo;
338         CondInfo.WasSkipping = true; // Silence bogus warning.
339         bool InCond = CurPPLexer->popConditionalLevel(CondInfo);
340         (void)InCond;  // Silence warning in no-asserts mode.
341         assert(!InCond && "Can't be skipping if not in a conditional!");
342 
343         // If we popped the outermost skipping block, we're done skipping!
344         if (!CondInfo.WasSkipping) {
345           // Restore the value of LexingRawMode so that trailing comments
346           // are handled correctly, if we've reached the outermost block.
347           CurPPLexer->LexingRawMode = false;
348           CheckEndOfDirective("endif");
349           CurPPLexer->LexingRawMode = true;
350           if (Callbacks)
351             Callbacks->Endif(Tok.getLocation(), CondInfo.IfLoc);
352           break;
353         } else {
354           DiscardUntilEndOfDirective();
355         }
356       } else if (Sub == "lse") { // "else".
357         // #else directive in a skipping conditional.  If not in some other
358         // skipping conditional, and if #else hasn't already been seen, enter it
359         // as a non-skipping conditional.
360         PPConditionalInfo &CondInfo = CurPPLexer->peekConditionalLevel();
361 
362         // If this is a #else with a #else before it, report the error.
363         if (CondInfo.FoundElse) Diag(Tok, diag::pp_err_else_after_else);
364 
365         // Note that we've seen a #else in this conditional.
366         CondInfo.FoundElse = true;
367 
368         // If the conditional is at the top level, and the #if block wasn't
369         // entered, enter the #else block now.
370         if (!CondInfo.WasSkipping && !CondInfo.FoundNonSkip) {
371           CondInfo.FoundNonSkip = true;
372           // Restore the value of LexingRawMode so that trailing comments
373           // are handled correctly.
374           CurPPLexer->LexingRawMode = false;
375           CheckEndOfDirective("else");
376           CurPPLexer->LexingRawMode = true;
377           if (Callbacks)
378             Callbacks->Else(Tok.getLocation(), CondInfo.IfLoc);
379           break;
380         } else {
381           DiscardUntilEndOfDirective();  // C99 6.10p4.
382         }
383       } else if (Sub == "lif") {  // "elif".
384         PPConditionalInfo &CondInfo = CurPPLexer->peekConditionalLevel();
385 
386         // If this is a #elif with a #else before it, report the error.
387         if (CondInfo.FoundElse) Diag(Tok, diag::pp_err_elif_after_else);
388 
389         // If this is in a skipping block or if we're already handled this #if
390         // block, don't bother parsing the condition.
391         if (CondInfo.WasSkipping || CondInfo.FoundNonSkip) {
392           DiscardUntilEndOfDirective();
393         } else {
394           const SourceLocation CondBegin = CurPPLexer->getSourceLocation();
395           // Restore the value of LexingRawMode so that identifiers are
396           // looked up, etc, inside the #elif expression.
397           assert(CurPPLexer->LexingRawMode && "We have to be skipping here!");
398           CurPPLexer->LexingRawMode = false;
399           IdentifierInfo *IfNDefMacro = nullptr;
400           const bool CondValue = EvaluateDirectiveExpression(IfNDefMacro);
401           CurPPLexer->LexingRawMode = true;
402           if (Callbacks) {
403             const SourceLocation CondEnd = CurPPLexer->getSourceLocation();
404             Callbacks->Elif(Tok.getLocation(),
405                             SourceRange(CondBegin, CondEnd),
406                             (CondValue ? PPCallbacks::CVK_True : PPCallbacks::CVK_False), CondInfo.IfLoc);
407           }
408           // If this condition is true, enter it!
409           if (CondValue) {
410             CondInfo.FoundNonSkip = true;
411             break;
412           }
413         }
414       }
415     }
416 
417     CurPPLexer->ParsingPreprocessorDirective = false;
418     // Restore comment saving mode.
419     if (CurLexer) CurLexer->resetExtendedTokenMode();
420   }
421 
422   // Finally, if we are out of the conditional (saw an #endif or ran off the end
423   // of the file, just stop skipping and return to lexing whatever came after
424   // the #if block.
425   CurPPLexer->LexingRawMode = false;
426 
427   if (Callbacks) {
428     SourceLocation BeginLoc = ElseLoc.isValid() ? ElseLoc : IfTokenLoc;
429     Callbacks->SourceRangeSkipped(SourceRange(BeginLoc, Tok.getLocation()));
430   }
431 }
432 
433 void Preprocessor::PTHSkipExcludedConditionalBlock() {
434 
435   while (1) {
436     assert(CurPTHLexer);
437     assert(CurPTHLexer->LexingRawMode == false);
438 
439     // Skip to the next '#else', '#elif', or #endif.
440     if (CurPTHLexer->SkipBlock()) {
441       // We have reached an #endif.  Both the '#' and 'endif' tokens
442       // have been consumed by the PTHLexer.  Just pop off the condition level.
443       PPConditionalInfo CondInfo;
444       bool InCond = CurPTHLexer->popConditionalLevel(CondInfo);
445       (void)InCond;  // Silence warning in no-asserts mode.
446       assert(!InCond && "Can't be skipping if not in a conditional!");
447       break;
448     }
449 
450     // We have reached a '#else' or '#elif'.  Lex the next token to get
451     // the directive flavor.
452     Token Tok;
453     LexUnexpandedToken(Tok);
454 
455     // We can actually look up the IdentifierInfo here since we aren't in
456     // raw mode.
457     tok::PPKeywordKind K = Tok.getIdentifierInfo()->getPPKeywordID();
458 
459     if (K == tok::pp_else) {
460       // #else: Enter the else condition.  We aren't in a nested condition
461       //  since we skip those. We're always in the one matching the last
462       //  blocked we skipped.
463       PPConditionalInfo &CondInfo = CurPTHLexer->peekConditionalLevel();
464       // Note that we've seen a #else in this conditional.
465       CondInfo.FoundElse = true;
466 
467       // If the #if block wasn't entered then enter the #else block now.
468       if (!CondInfo.FoundNonSkip) {
469         CondInfo.FoundNonSkip = true;
470 
471         // Scan until the eod token.
472         CurPTHLexer->ParsingPreprocessorDirective = true;
473         DiscardUntilEndOfDirective();
474         CurPTHLexer->ParsingPreprocessorDirective = false;
475 
476         break;
477       }
478 
479       // Otherwise skip this block.
480       continue;
481     }
482 
483     assert(K == tok::pp_elif);
484     PPConditionalInfo &CondInfo = CurPTHLexer->peekConditionalLevel();
485 
486     // If this is a #elif with a #else before it, report the error.
487     if (CondInfo.FoundElse)
488       Diag(Tok, diag::pp_err_elif_after_else);
489 
490     // If this is in a skipping block or if we're already handled this #if
491     // block, don't bother parsing the condition.  We just skip this block.
492     if (CondInfo.FoundNonSkip)
493       continue;
494 
495     // Evaluate the condition of the #elif.
496     IdentifierInfo *IfNDefMacro = nullptr;
497     CurPTHLexer->ParsingPreprocessorDirective = true;
498     bool ShouldEnter = EvaluateDirectiveExpression(IfNDefMacro);
499     CurPTHLexer->ParsingPreprocessorDirective = false;
500 
501     // If this condition is true, enter it!
502     if (ShouldEnter) {
503       CondInfo.FoundNonSkip = true;
504       break;
505     }
506 
507     // Otherwise, skip this block and go to the next one.
508     continue;
509   }
510 }
511 
512 Module *Preprocessor::getModuleForLocation(SourceLocation FilenameLoc) {
513   ModuleMap &ModMap = HeaderInfo.getModuleMap();
514   if (SourceMgr.isInMainFile(FilenameLoc)) {
515     if (Module *CurMod = getCurrentModule())
516       return CurMod;                               // Compiling a module.
517     return HeaderInfo.getModuleMap().SourceModule; // Compiling a source.
518   }
519   // Try to determine the module of the include directive.
520   // FIXME: Look into directly passing the FileEntry from LookupFile instead.
521   FileID IDOfIncl = SourceMgr.getFileID(SourceMgr.getExpansionLoc(FilenameLoc));
522   if (const FileEntry *EntryOfIncl = SourceMgr.getFileEntryForID(IDOfIncl)) {
523     // The include comes from a file.
524     return ModMap.findModuleForHeader(EntryOfIncl).getModule();
525   } else {
526     // The include does not come from a file,
527     // so it is probably a module compilation.
528     return getCurrentModule();
529   }
530 }
531 
532 const FileEntry *Preprocessor::LookupFile(
533     SourceLocation FilenameLoc,
534     StringRef Filename,
535     bool isAngled,
536     const DirectoryLookup *FromDir,
537     const DirectoryLookup *&CurDir,
538     SmallVectorImpl<char> *SearchPath,
539     SmallVectorImpl<char> *RelativePath,
540     ModuleMap::KnownHeader *SuggestedModule,
541     bool SkipCache) {
542   // If the header lookup mechanism may be relative to the current inclusion
543   // stack, record the parent #includes.
544   SmallVector<std::pair<const FileEntry *, const DirectoryEntry *>, 16>
545       Includers;
546   if (!FromDir) {
547     FileID FID = getCurrentFileLexer()->getFileID();
548     const FileEntry *FileEnt = SourceMgr.getFileEntryForID(FID);
549 
550     // If there is no file entry associated with this file, it must be the
551     // predefines buffer.  Any other file is not lexed with a normal lexer, so
552     // it won't be scanned for preprocessor directives.   If we have the
553     // predefines buffer, resolve #include references (which come from the
554     // -include command line argument) from the current working directory
555     // instead of relative to the main file.
556     if (!FileEnt) {
557       FileEnt = SourceMgr.getFileEntryForID(SourceMgr.getMainFileID());
558       if (FileEnt)
559         Includers.push_back(std::make_pair(FileEnt, FileMgr.getDirectory(".")));
560     } else {
561       Includers.push_back(std::make_pair(FileEnt, FileEnt->getDir()));
562     }
563 
564     // MSVC searches the current include stack from top to bottom for
565     // headers included by quoted include directives.
566     // See: http://msdn.microsoft.com/en-us/library/36k2cdd4.aspx
567     if (LangOpts.MSVCCompat && !isAngled) {
568       for (unsigned i = 0, e = IncludeMacroStack.size(); i != e; ++i) {
569         IncludeStackInfo &ISEntry = IncludeMacroStack[e - i - 1];
570         if (IsFileLexer(ISEntry))
571           if ((FileEnt = SourceMgr.getFileEntryForID(
572                    ISEntry.ThePPLexer->getFileID())))
573             Includers.push_back(std::make_pair(FileEnt, FileEnt->getDir()));
574       }
575     }
576   }
577 
578   // Do a standard file entry lookup.
579   CurDir = CurDirLookup;
580   const FileEntry *FE = HeaderInfo.LookupFile(
581       Filename, FilenameLoc, isAngled, FromDir, CurDir, Includers, SearchPath,
582       RelativePath, SuggestedModule, SkipCache);
583   if (FE) {
584     if (SuggestedModule && !LangOpts.AsmPreprocessor)
585       HeaderInfo.getModuleMap().diagnoseHeaderInclusion(
586           getModuleForLocation(FilenameLoc), FilenameLoc, Filename, FE);
587     return FE;
588   }
589 
590   const FileEntry *CurFileEnt;
591   // Otherwise, see if this is a subframework header.  If so, this is relative
592   // to one of the headers on the #include stack.  Walk the list of the current
593   // headers on the #include stack and pass them to HeaderInfo.
594   if (IsFileLexer()) {
595     if ((CurFileEnt = SourceMgr.getFileEntryForID(CurPPLexer->getFileID()))) {
596       if ((FE = HeaderInfo.LookupSubframeworkHeader(Filename, CurFileEnt,
597                                                     SearchPath, RelativePath,
598                                                     SuggestedModule))) {
599         if (SuggestedModule && !LangOpts.AsmPreprocessor)
600           HeaderInfo.getModuleMap().diagnoseHeaderInclusion(
601               getModuleForLocation(FilenameLoc), FilenameLoc, Filename, FE);
602         return FE;
603       }
604     }
605   }
606 
607   for (unsigned i = 0, e = IncludeMacroStack.size(); i != e; ++i) {
608     IncludeStackInfo &ISEntry = IncludeMacroStack[e-i-1];
609     if (IsFileLexer(ISEntry)) {
610       if ((CurFileEnt =
611            SourceMgr.getFileEntryForID(ISEntry.ThePPLexer->getFileID()))) {
612         if ((FE = HeaderInfo.LookupSubframeworkHeader(
613                 Filename, CurFileEnt, SearchPath, RelativePath,
614                 SuggestedModule))) {
615           if (SuggestedModule && !LangOpts.AsmPreprocessor)
616             HeaderInfo.getModuleMap().diagnoseHeaderInclusion(
617                 getModuleForLocation(FilenameLoc), FilenameLoc, Filename, FE);
618           return FE;
619         }
620       }
621     }
622   }
623 
624   // Otherwise, we really couldn't find the file.
625   return nullptr;
626 }
627 
628 
629 //===----------------------------------------------------------------------===//
630 // Preprocessor Directive Handling.
631 //===----------------------------------------------------------------------===//
632 
633 class Preprocessor::ResetMacroExpansionHelper {
634 public:
635   ResetMacroExpansionHelper(Preprocessor *pp)
636     : PP(pp), save(pp->DisableMacroExpansion) {
637     if (pp->MacroExpansionInDirectivesOverride)
638       pp->DisableMacroExpansion = false;
639   }
640   ~ResetMacroExpansionHelper() {
641     PP->DisableMacroExpansion = save;
642   }
643 private:
644   Preprocessor *PP;
645   bool save;
646 };
647 
648 /// HandleDirective - This callback is invoked when the lexer sees a # token
649 /// at the start of a line.  This consumes the directive, modifies the
650 /// lexer/preprocessor state, and advances the lexer(s) so that the next token
651 /// read is the correct one.
652 void Preprocessor::HandleDirective(Token &Result) {
653   // FIXME: Traditional: # with whitespace before it not recognized by K&R?
654 
655   // We just parsed a # character at the start of a line, so we're in directive
656   // mode.  Tell the lexer this so any newlines we see will be converted into an
657   // EOD token (which terminates the directive).
658   CurPPLexer->ParsingPreprocessorDirective = true;
659   if (CurLexer) CurLexer->SetKeepWhitespaceMode(false);
660 
661   bool ImmediatelyAfterTopLevelIfndef =
662       CurPPLexer->MIOpt.getImmediatelyAfterTopLevelIfndef();
663   CurPPLexer->MIOpt.resetImmediatelyAfterTopLevelIfndef();
664 
665   ++NumDirectives;
666 
667   // We are about to read a token.  For the multiple-include optimization FA to
668   // work, we have to remember if we had read any tokens *before* this
669   // pp-directive.
670   bool ReadAnyTokensBeforeDirective =CurPPLexer->MIOpt.getHasReadAnyTokensVal();
671 
672   // Save the '#' token in case we need to return it later.
673   Token SavedHash = Result;
674 
675   // Read the next token, the directive flavor.  This isn't expanded due to
676   // C99 6.10.3p8.
677   LexUnexpandedToken(Result);
678 
679   // C99 6.10.3p11: Is this preprocessor directive in macro invocation?  e.g.:
680   //   #define A(x) #x
681   //   A(abc
682   //     #warning blah
683   //   def)
684   // If so, the user is relying on undefined behavior, emit a diagnostic. Do
685   // not support this for #include-like directives, since that can result in
686   // terrible diagnostics, and does not work in GCC.
687   if (InMacroArgs) {
688     if (IdentifierInfo *II = Result.getIdentifierInfo()) {
689       switch (II->getPPKeywordID()) {
690       case tok::pp_include:
691       case tok::pp_import:
692       case tok::pp_include_next:
693       case tok::pp___include_macros:
694         Diag(Result, diag::err_embedded_include) << II->getName();
695         DiscardUntilEndOfDirective();
696         return;
697       default:
698         break;
699       }
700     }
701     Diag(Result, diag::ext_embedded_directive);
702   }
703 
704   // Temporarily enable macro expansion if set so
705   // and reset to previous state when returning from this function.
706   ResetMacroExpansionHelper helper(this);
707 
708   switch (Result.getKind()) {
709   case tok::eod:
710     return;   // null directive.
711   case tok::code_completion:
712     if (CodeComplete)
713       CodeComplete->CodeCompleteDirective(
714                                     CurPPLexer->getConditionalStackDepth() > 0);
715     setCodeCompletionReached();
716     return;
717   case tok::numeric_constant:  // # 7  GNU line marker directive.
718     if (getLangOpts().AsmPreprocessor)
719       break;  // # 4 is not a preprocessor directive in .S files.
720     return HandleDigitDirective(Result);
721   default:
722     IdentifierInfo *II = Result.getIdentifierInfo();
723     if (!II) break; // Not an identifier.
724 
725     // Ask what the preprocessor keyword ID is.
726     switch (II->getPPKeywordID()) {
727     default: break;
728     // C99 6.10.1 - Conditional Inclusion.
729     case tok::pp_if:
730       return HandleIfDirective(Result, ReadAnyTokensBeforeDirective);
731     case tok::pp_ifdef:
732       return HandleIfdefDirective(Result, false, true/*not valid for miopt*/);
733     case tok::pp_ifndef:
734       return HandleIfdefDirective(Result, true, ReadAnyTokensBeforeDirective);
735     case tok::pp_elif:
736       return HandleElifDirective(Result);
737     case tok::pp_else:
738       return HandleElseDirective(Result);
739     case tok::pp_endif:
740       return HandleEndifDirective(Result);
741 
742     // C99 6.10.2 - Source File Inclusion.
743     case tok::pp_include:
744       // Handle #include.
745       return HandleIncludeDirective(SavedHash.getLocation(), Result);
746     case tok::pp___include_macros:
747       // Handle -imacros.
748       return HandleIncludeMacrosDirective(SavedHash.getLocation(), Result);
749 
750     // C99 6.10.3 - Macro Replacement.
751     case tok::pp_define:
752       return HandleDefineDirective(Result, ImmediatelyAfterTopLevelIfndef);
753     case tok::pp_undef:
754       return HandleUndefDirective(Result);
755 
756     // C99 6.10.4 - Line Control.
757     case tok::pp_line:
758       return HandleLineDirective(Result);
759 
760     // C99 6.10.5 - Error Directive.
761     case tok::pp_error:
762       return HandleUserDiagnosticDirective(Result, false);
763 
764     // C99 6.10.6 - Pragma Directive.
765     case tok::pp_pragma:
766       return HandlePragmaDirective(SavedHash.getLocation(), PIK_HashPragma);
767 
768     // GNU Extensions.
769     case tok::pp_import:
770       return HandleImportDirective(SavedHash.getLocation(), Result);
771     case tok::pp_include_next:
772       return HandleIncludeNextDirective(SavedHash.getLocation(), Result);
773 
774     case tok::pp_warning:
775       Diag(Result, diag::ext_pp_warning_directive);
776       return HandleUserDiagnosticDirective(Result, true);
777     case tok::pp_ident:
778       return HandleIdentSCCSDirective(Result);
779     case tok::pp_sccs:
780       return HandleIdentSCCSDirective(Result);
781     case tok::pp_assert:
782       //isExtension = true;  // FIXME: implement #assert
783       break;
784     case tok::pp_unassert:
785       //isExtension = true;  // FIXME: implement #unassert
786       break;
787 
788     case tok::pp___public_macro:
789       if (getLangOpts().Modules)
790         return HandleMacroPublicDirective(Result);
791       break;
792 
793     case tok::pp___private_macro:
794       if (getLangOpts().Modules)
795         return HandleMacroPrivateDirective(Result);
796       break;
797     }
798     break;
799   }
800 
801   // If this is a .S file, treat unknown # directives as non-preprocessor
802   // directives.  This is important because # may be a comment or introduce
803   // various pseudo-ops.  Just return the # token and push back the following
804   // token to be lexed next time.
805   if (getLangOpts().AsmPreprocessor) {
806     Token *Toks = new Token[2];
807     // Return the # and the token after it.
808     Toks[0] = SavedHash;
809     Toks[1] = Result;
810 
811     // If the second token is a hashhash token, then we need to translate it to
812     // unknown so the token lexer doesn't try to perform token pasting.
813     if (Result.is(tok::hashhash))
814       Toks[1].setKind(tok::unknown);
815 
816     // Enter this token stream so that we re-lex the tokens.  Make sure to
817     // enable macro expansion, in case the token after the # is an identifier
818     // that is expanded.
819     EnterTokenStream(Toks, 2, false, true);
820     return;
821   }
822 
823   // If we reached here, the preprocessing token is not valid!
824   Diag(Result, diag::err_pp_invalid_directive);
825 
826   // Read the rest of the PP line.
827   DiscardUntilEndOfDirective();
828 
829   // Okay, we're done parsing the directive.
830 }
831 
832 /// GetLineValue - Convert a numeric token into an unsigned value, emitting
833 /// Diagnostic DiagID if it is invalid, and returning the value in Val.
834 static bool GetLineValue(Token &DigitTok, unsigned &Val,
835                          unsigned DiagID, Preprocessor &PP,
836                          bool IsGNULineDirective=false) {
837   if (DigitTok.isNot(tok::numeric_constant)) {
838     PP.Diag(DigitTok, DiagID);
839 
840     if (DigitTok.isNot(tok::eod))
841       PP.DiscardUntilEndOfDirective();
842     return true;
843   }
844 
845   SmallString<64> IntegerBuffer;
846   IntegerBuffer.resize(DigitTok.getLength());
847   const char *DigitTokBegin = &IntegerBuffer[0];
848   bool Invalid = false;
849   unsigned ActualLength = PP.getSpelling(DigitTok, DigitTokBegin, &Invalid);
850   if (Invalid)
851     return true;
852 
853   // Verify that we have a simple digit-sequence, and compute the value.  This
854   // is always a simple digit string computed in decimal, so we do this manually
855   // here.
856   Val = 0;
857   for (unsigned i = 0; i != ActualLength; ++i) {
858     // C++1y [lex.fcon]p1:
859     //   Optional separating single quotes in a digit-sequence are ignored
860     if (DigitTokBegin[i] == '\'')
861       continue;
862 
863     if (!isDigit(DigitTokBegin[i])) {
864       PP.Diag(PP.AdvanceToTokenCharacter(DigitTok.getLocation(), i),
865               diag::err_pp_line_digit_sequence) << IsGNULineDirective;
866       PP.DiscardUntilEndOfDirective();
867       return true;
868     }
869 
870     unsigned NextVal = Val*10+(DigitTokBegin[i]-'0');
871     if (NextVal < Val) { // overflow.
872       PP.Diag(DigitTok, DiagID);
873       PP.DiscardUntilEndOfDirective();
874       return true;
875     }
876     Val = NextVal;
877   }
878 
879   if (DigitTokBegin[0] == '0' && Val)
880     PP.Diag(DigitTok.getLocation(), diag::warn_pp_line_decimal)
881       << IsGNULineDirective;
882 
883   return false;
884 }
885 
886 /// \brief Handle a \#line directive: C99 6.10.4.
887 ///
888 /// The two acceptable forms are:
889 /// \verbatim
890 ///   # line digit-sequence
891 ///   # line digit-sequence "s-char-sequence"
892 /// \endverbatim
893 void Preprocessor::HandleLineDirective(Token &Tok) {
894   // Read the line # and string argument.  Per C99 6.10.4p5, these tokens are
895   // expanded.
896   Token DigitTok;
897   Lex(DigitTok);
898 
899   // Validate the number and convert it to an unsigned.
900   unsigned LineNo;
901   if (GetLineValue(DigitTok, LineNo, diag::err_pp_line_requires_integer,*this))
902     return;
903 
904   if (LineNo == 0)
905     Diag(DigitTok, diag::ext_pp_line_zero);
906 
907   // Enforce C99 6.10.4p3: "The digit sequence shall not specify ... a
908   // number greater than 2147483647".  C90 requires that the line # be <= 32767.
909   unsigned LineLimit = 32768U;
910   if (LangOpts.C99 || LangOpts.CPlusPlus11)
911     LineLimit = 2147483648U;
912   if (LineNo >= LineLimit)
913     Diag(DigitTok, diag::ext_pp_line_too_big) << LineLimit;
914   else if (LangOpts.CPlusPlus11 && LineNo >= 32768U)
915     Diag(DigitTok, diag::warn_cxx98_compat_pp_line_too_big);
916 
917   int FilenameID = -1;
918   Token StrTok;
919   Lex(StrTok);
920 
921   // If the StrTok is "eod", then it wasn't present.  Otherwise, it must be a
922   // string followed by eod.
923   if (StrTok.is(tok::eod))
924     ; // ok
925   else if (StrTok.isNot(tok::string_literal)) {
926     Diag(StrTok, diag::err_pp_line_invalid_filename);
927     return DiscardUntilEndOfDirective();
928   } else if (StrTok.hasUDSuffix()) {
929     Diag(StrTok, diag::err_invalid_string_udl);
930     return DiscardUntilEndOfDirective();
931   } else {
932     // Parse and validate the string, converting it into a unique ID.
933     StringLiteralParser Literal(StrTok, *this);
934     assert(Literal.isAscii() && "Didn't allow wide strings in");
935     if (Literal.hadError)
936       return DiscardUntilEndOfDirective();
937     if (Literal.Pascal) {
938       Diag(StrTok, diag::err_pp_linemarker_invalid_filename);
939       return DiscardUntilEndOfDirective();
940     }
941     FilenameID = SourceMgr.getLineTableFilenameID(Literal.GetString());
942 
943     // Verify that there is nothing after the string, other than EOD.  Because
944     // of C99 6.10.4p5, macros that expand to empty tokens are ok.
945     CheckEndOfDirective("line", true);
946   }
947 
948   SourceMgr.AddLineNote(DigitTok.getLocation(), LineNo, FilenameID);
949 
950   if (Callbacks)
951     Callbacks->FileChanged(CurPPLexer->getSourceLocation(),
952                            PPCallbacks::RenameFile,
953                            SrcMgr::C_User);
954 }
955 
956 /// ReadLineMarkerFlags - Parse and validate any flags at the end of a GNU line
957 /// marker directive.
958 static bool ReadLineMarkerFlags(bool &IsFileEntry, bool &IsFileExit,
959                                 bool &IsSystemHeader, bool &IsExternCHeader,
960                                 Preprocessor &PP) {
961   unsigned FlagVal;
962   Token FlagTok;
963   PP.Lex(FlagTok);
964   if (FlagTok.is(tok::eod)) return false;
965   if (GetLineValue(FlagTok, FlagVal, diag::err_pp_linemarker_invalid_flag, PP))
966     return true;
967 
968   if (FlagVal == 1) {
969     IsFileEntry = true;
970 
971     PP.Lex(FlagTok);
972     if (FlagTok.is(tok::eod)) return false;
973     if (GetLineValue(FlagTok, FlagVal, diag::err_pp_linemarker_invalid_flag,PP))
974       return true;
975   } else if (FlagVal == 2) {
976     IsFileExit = true;
977 
978     SourceManager &SM = PP.getSourceManager();
979     // If we are leaving the current presumed file, check to make sure the
980     // presumed include stack isn't empty!
981     FileID CurFileID =
982       SM.getDecomposedExpansionLoc(FlagTok.getLocation()).first;
983     PresumedLoc PLoc = SM.getPresumedLoc(FlagTok.getLocation());
984     if (PLoc.isInvalid())
985       return true;
986 
987     // If there is no include loc (main file) or if the include loc is in a
988     // different physical file, then we aren't in a "1" line marker flag region.
989     SourceLocation IncLoc = PLoc.getIncludeLoc();
990     if (IncLoc.isInvalid() ||
991         SM.getDecomposedExpansionLoc(IncLoc).first != CurFileID) {
992       PP.Diag(FlagTok, diag::err_pp_linemarker_invalid_pop);
993       PP.DiscardUntilEndOfDirective();
994       return true;
995     }
996 
997     PP.Lex(FlagTok);
998     if (FlagTok.is(tok::eod)) return false;
999     if (GetLineValue(FlagTok, FlagVal, diag::err_pp_linemarker_invalid_flag,PP))
1000       return true;
1001   }
1002 
1003   // We must have 3 if there are still flags.
1004   if (FlagVal != 3) {
1005     PP.Diag(FlagTok, diag::err_pp_linemarker_invalid_flag);
1006     PP.DiscardUntilEndOfDirective();
1007     return true;
1008   }
1009 
1010   IsSystemHeader = true;
1011 
1012   PP.Lex(FlagTok);
1013   if (FlagTok.is(tok::eod)) return false;
1014   if (GetLineValue(FlagTok, FlagVal, diag::err_pp_linemarker_invalid_flag, PP))
1015     return true;
1016 
1017   // We must have 4 if there is yet another flag.
1018   if (FlagVal != 4) {
1019     PP.Diag(FlagTok, diag::err_pp_linemarker_invalid_flag);
1020     PP.DiscardUntilEndOfDirective();
1021     return true;
1022   }
1023 
1024   IsExternCHeader = true;
1025 
1026   PP.Lex(FlagTok);
1027   if (FlagTok.is(tok::eod)) return false;
1028 
1029   // There are no more valid flags here.
1030   PP.Diag(FlagTok, diag::err_pp_linemarker_invalid_flag);
1031   PP.DiscardUntilEndOfDirective();
1032   return true;
1033 }
1034 
1035 /// HandleDigitDirective - Handle a GNU line marker directive, whose syntax is
1036 /// one of the following forms:
1037 ///
1038 ///     # 42
1039 ///     # 42 "file" ('1' | '2')?
1040 ///     # 42 "file" ('1' | '2')? '3' '4'?
1041 ///
1042 void Preprocessor::HandleDigitDirective(Token &DigitTok) {
1043   // Validate the number and convert it to an unsigned.  GNU does not have a
1044   // line # limit other than it fit in 32-bits.
1045   unsigned LineNo;
1046   if (GetLineValue(DigitTok, LineNo, diag::err_pp_linemarker_requires_integer,
1047                    *this, true))
1048     return;
1049 
1050   Token StrTok;
1051   Lex(StrTok);
1052 
1053   bool IsFileEntry = false, IsFileExit = false;
1054   bool IsSystemHeader = false, IsExternCHeader = false;
1055   int FilenameID = -1;
1056 
1057   // If the StrTok is "eod", then it wasn't present.  Otherwise, it must be a
1058   // string followed by eod.
1059   if (StrTok.is(tok::eod))
1060     ; // ok
1061   else if (StrTok.isNot(tok::string_literal)) {
1062     Diag(StrTok, diag::err_pp_linemarker_invalid_filename);
1063     return DiscardUntilEndOfDirective();
1064   } else if (StrTok.hasUDSuffix()) {
1065     Diag(StrTok, diag::err_invalid_string_udl);
1066     return DiscardUntilEndOfDirective();
1067   } else {
1068     // Parse and validate the string, converting it into a unique ID.
1069     StringLiteralParser Literal(StrTok, *this);
1070     assert(Literal.isAscii() && "Didn't allow wide strings in");
1071     if (Literal.hadError)
1072       return DiscardUntilEndOfDirective();
1073     if (Literal.Pascal) {
1074       Diag(StrTok, diag::err_pp_linemarker_invalid_filename);
1075       return DiscardUntilEndOfDirective();
1076     }
1077     FilenameID = SourceMgr.getLineTableFilenameID(Literal.GetString());
1078 
1079     // If a filename was present, read any flags that are present.
1080     if (ReadLineMarkerFlags(IsFileEntry, IsFileExit,
1081                             IsSystemHeader, IsExternCHeader, *this))
1082       return;
1083   }
1084 
1085   // Create a line note with this information.
1086   SourceMgr.AddLineNote(DigitTok.getLocation(), LineNo, FilenameID,
1087                         IsFileEntry, IsFileExit,
1088                         IsSystemHeader, IsExternCHeader);
1089 
1090   // If the preprocessor has callbacks installed, notify them of the #line
1091   // change.  This is used so that the line marker comes out in -E mode for
1092   // example.
1093   if (Callbacks) {
1094     PPCallbacks::FileChangeReason Reason = PPCallbacks::RenameFile;
1095     if (IsFileEntry)
1096       Reason = PPCallbacks::EnterFile;
1097     else if (IsFileExit)
1098       Reason = PPCallbacks::ExitFile;
1099     SrcMgr::CharacteristicKind FileKind = SrcMgr::C_User;
1100     if (IsExternCHeader)
1101       FileKind = SrcMgr::C_ExternCSystem;
1102     else if (IsSystemHeader)
1103       FileKind = SrcMgr::C_System;
1104 
1105     Callbacks->FileChanged(CurPPLexer->getSourceLocation(), Reason, FileKind);
1106   }
1107 }
1108 
1109 
1110 /// HandleUserDiagnosticDirective - Handle a #warning or #error directive.
1111 ///
1112 void Preprocessor::HandleUserDiagnosticDirective(Token &Tok,
1113                                                  bool isWarning) {
1114   // PTH doesn't emit #warning or #error directives.
1115   if (CurPTHLexer)
1116     return CurPTHLexer->DiscardToEndOfLine();
1117 
1118   // Read the rest of the line raw.  We do this because we don't want macros
1119   // to be expanded and we don't require that the tokens be valid preprocessing
1120   // tokens.  For example, this is allowed: "#warning `   'foo".  GCC does
1121   // collapse multiple consequtive white space between tokens, but this isn't
1122   // specified by the standard.
1123   SmallString<128> Message;
1124   CurLexer->ReadToEndOfLine(&Message);
1125 
1126   // Find the first non-whitespace character, so that we can make the
1127   // diagnostic more succinct.
1128   StringRef Msg = Message.str().ltrim(" ");
1129 
1130   if (isWarning)
1131     Diag(Tok, diag::pp_hash_warning) << Msg;
1132   else
1133     Diag(Tok, diag::err_pp_hash_error) << Msg;
1134 }
1135 
1136 /// HandleIdentSCCSDirective - Handle a #ident/#sccs directive.
1137 ///
1138 void Preprocessor::HandleIdentSCCSDirective(Token &Tok) {
1139   // Yes, this directive is an extension.
1140   Diag(Tok, diag::ext_pp_ident_directive);
1141 
1142   // Read the string argument.
1143   Token StrTok;
1144   Lex(StrTok);
1145 
1146   // If the token kind isn't a string, it's a malformed directive.
1147   if (StrTok.isNot(tok::string_literal) &&
1148       StrTok.isNot(tok::wide_string_literal)) {
1149     Diag(StrTok, diag::err_pp_malformed_ident);
1150     if (StrTok.isNot(tok::eod))
1151       DiscardUntilEndOfDirective();
1152     return;
1153   }
1154 
1155   if (StrTok.hasUDSuffix()) {
1156     Diag(StrTok, diag::err_invalid_string_udl);
1157     return DiscardUntilEndOfDirective();
1158   }
1159 
1160   // Verify that there is nothing after the string, other than EOD.
1161   CheckEndOfDirective("ident");
1162 
1163   if (Callbacks) {
1164     bool Invalid = false;
1165     std::string Str = getSpelling(StrTok, &Invalid);
1166     if (!Invalid)
1167       Callbacks->Ident(Tok.getLocation(), Str);
1168   }
1169 }
1170 
1171 /// \brief Handle a #public directive.
1172 void Preprocessor::HandleMacroPublicDirective(Token &Tok) {
1173   Token MacroNameTok;
1174   ReadMacroName(MacroNameTok, 2);
1175 
1176   // Error reading macro name?  If so, diagnostic already issued.
1177   if (MacroNameTok.is(tok::eod))
1178     return;
1179 
1180   // Check to see if this is the last token on the #__public_macro line.
1181   CheckEndOfDirective("__public_macro");
1182 
1183   IdentifierInfo *II = MacroNameTok.getIdentifierInfo();
1184   // Okay, we finally have a valid identifier to undef.
1185   MacroDirective *MD = getMacroDirective(II);
1186 
1187   // If the macro is not defined, this is an error.
1188   if (!MD) {
1189     Diag(MacroNameTok, diag::err_pp_visibility_non_macro) << II;
1190     return;
1191   }
1192 
1193   // Note that this macro has now been exported.
1194   appendMacroDirective(II, AllocateVisibilityMacroDirective(
1195                                 MacroNameTok.getLocation(), /*IsPublic=*/true));
1196 }
1197 
1198 /// \brief Handle a #private directive.
1199 void Preprocessor::HandleMacroPrivateDirective(Token &Tok) {
1200   Token MacroNameTok;
1201   ReadMacroName(MacroNameTok, 2);
1202 
1203   // Error reading macro name?  If so, diagnostic already issued.
1204   if (MacroNameTok.is(tok::eod))
1205     return;
1206 
1207   // Check to see if this is the last token on the #__private_macro line.
1208   CheckEndOfDirective("__private_macro");
1209 
1210   IdentifierInfo *II = MacroNameTok.getIdentifierInfo();
1211   // Okay, we finally have a valid identifier to undef.
1212   MacroDirective *MD = getMacroDirective(II);
1213 
1214   // If the macro is not defined, this is an error.
1215   if (!MD) {
1216     Diag(MacroNameTok, diag::err_pp_visibility_non_macro) << II;
1217     return;
1218   }
1219 
1220   // Note that this macro has now been marked private.
1221   appendMacroDirective(II, AllocateVisibilityMacroDirective(
1222                                MacroNameTok.getLocation(), /*IsPublic=*/false));
1223 }
1224 
1225 //===----------------------------------------------------------------------===//
1226 // Preprocessor Include Directive Handling.
1227 //===----------------------------------------------------------------------===//
1228 
1229 /// GetIncludeFilenameSpelling - Turn the specified lexer token into a fully
1230 /// checked and spelled filename, e.g. as an operand of \#include. This returns
1231 /// true if the input filename was in <>'s or false if it were in ""'s.  The
1232 /// caller is expected to provide a buffer that is large enough to hold the
1233 /// spelling of the filename, but is also expected to handle the case when
1234 /// this method decides to use a different buffer.
1235 bool Preprocessor::GetIncludeFilenameSpelling(SourceLocation Loc,
1236                                               StringRef &Buffer) {
1237   // Get the text form of the filename.
1238   assert(!Buffer.empty() && "Can't have tokens with empty spellings!");
1239 
1240   // Make sure the filename is <x> or "x".
1241   bool isAngled;
1242   if (Buffer[0] == '<') {
1243     if (Buffer.back() != '>') {
1244       Diag(Loc, diag::err_pp_expects_filename);
1245       Buffer = StringRef();
1246       return true;
1247     }
1248     isAngled = true;
1249   } else if (Buffer[0] == '"') {
1250     if (Buffer.back() != '"') {
1251       Diag(Loc, diag::err_pp_expects_filename);
1252       Buffer = StringRef();
1253       return true;
1254     }
1255     isAngled = false;
1256   } else {
1257     Diag(Loc, diag::err_pp_expects_filename);
1258     Buffer = StringRef();
1259     return true;
1260   }
1261 
1262   // Diagnose #include "" as invalid.
1263   if (Buffer.size() <= 2) {
1264     Diag(Loc, diag::err_pp_empty_filename);
1265     Buffer = StringRef();
1266     return true;
1267   }
1268 
1269   // Skip the brackets.
1270   Buffer = Buffer.substr(1, Buffer.size()-2);
1271   return isAngled;
1272 }
1273 
1274 // \brief Handle cases where the \#include name is expanded from a macro
1275 // as multiple tokens, which need to be glued together.
1276 //
1277 // This occurs for code like:
1278 // \code
1279 //    \#define FOO <a/b.h>
1280 //    \#include FOO
1281 // \endcode
1282 // because in this case, "<a/b.h>" is returned as 7 tokens, not one.
1283 //
1284 // This code concatenates and consumes tokens up to the '>' token.  It returns
1285 // false if the > was found, otherwise it returns true if it finds and consumes
1286 // the EOD marker.
1287 bool Preprocessor::ConcatenateIncludeName(SmallString<128> &FilenameBuffer,
1288                                           SourceLocation &End) {
1289   Token CurTok;
1290 
1291   Lex(CurTok);
1292   while (CurTok.isNot(tok::eod)) {
1293     End = CurTok.getLocation();
1294 
1295     // FIXME: Provide code completion for #includes.
1296     if (CurTok.is(tok::code_completion)) {
1297       setCodeCompletionReached();
1298       Lex(CurTok);
1299       continue;
1300     }
1301 
1302     // Append the spelling of this token to the buffer. If there was a space
1303     // before it, add it now.
1304     if (CurTok.hasLeadingSpace())
1305       FilenameBuffer.push_back(' ');
1306 
1307     // Get the spelling of the token, directly into FilenameBuffer if possible.
1308     unsigned PreAppendSize = FilenameBuffer.size();
1309     FilenameBuffer.resize(PreAppendSize+CurTok.getLength());
1310 
1311     const char *BufPtr = &FilenameBuffer[PreAppendSize];
1312     unsigned ActualLen = getSpelling(CurTok, BufPtr);
1313 
1314     // If the token was spelled somewhere else, copy it into FilenameBuffer.
1315     if (BufPtr != &FilenameBuffer[PreAppendSize])
1316       memcpy(&FilenameBuffer[PreAppendSize], BufPtr, ActualLen);
1317 
1318     // Resize FilenameBuffer to the correct size.
1319     if (CurTok.getLength() != ActualLen)
1320       FilenameBuffer.resize(PreAppendSize+ActualLen);
1321 
1322     // If we found the '>' marker, return success.
1323     if (CurTok.is(tok::greater))
1324       return false;
1325 
1326     Lex(CurTok);
1327   }
1328 
1329   // If we hit the eod marker, emit an error and return true so that the caller
1330   // knows the EOD has been read.
1331   Diag(CurTok.getLocation(), diag::err_pp_expects_filename);
1332   return true;
1333 }
1334 
1335 /// \brief Push a token onto the token stream containing an annotation.
1336 static void EnterAnnotationToken(Preprocessor &PP,
1337                                  SourceLocation Begin, SourceLocation End,
1338                                  tok::TokenKind Kind, void *AnnotationVal) {
1339   Token *Tok = new Token[1];
1340   Tok[0].startToken();
1341   Tok[0].setKind(Kind);
1342   Tok[0].setLocation(Begin);
1343   Tok[0].setAnnotationEndLoc(End);
1344   Tok[0].setAnnotationValue(AnnotationVal);
1345   PP.EnterTokenStream(Tok, 1, true, true);
1346 }
1347 
1348 /// HandleIncludeDirective - The "\#include" tokens have just been read, read
1349 /// the file to be included from the lexer, then include it!  This is a common
1350 /// routine with functionality shared between \#include, \#include_next and
1351 /// \#import.  LookupFrom is set when this is a \#include_next directive, it
1352 /// specifies the file to start searching from.
1353 void Preprocessor::HandleIncludeDirective(SourceLocation HashLoc,
1354                                           Token &IncludeTok,
1355                                           const DirectoryLookup *LookupFrom,
1356                                           bool isImport) {
1357 
1358   Token FilenameTok;
1359   CurPPLexer->LexIncludeFilename(FilenameTok);
1360 
1361   // Reserve a buffer to get the spelling.
1362   SmallString<128> FilenameBuffer;
1363   StringRef Filename;
1364   SourceLocation End;
1365   SourceLocation CharEnd; // the end of this directive, in characters
1366 
1367   switch (FilenameTok.getKind()) {
1368   case tok::eod:
1369     // If the token kind is EOD, the error has already been diagnosed.
1370     return;
1371 
1372   case tok::angle_string_literal:
1373   case tok::string_literal:
1374     Filename = getSpelling(FilenameTok, FilenameBuffer);
1375     End = FilenameTok.getLocation();
1376     CharEnd = End.getLocWithOffset(FilenameTok.getLength());
1377     break;
1378 
1379   case tok::less:
1380     // This could be a <foo/bar.h> file coming from a macro expansion.  In this
1381     // case, glue the tokens together into FilenameBuffer and interpret those.
1382     FilenameBuffer.push_back('<');
1383     if (ConcatenateIncludeName(FilenameBuffer, End))
1384       return;   // Found <eod> but no ">"?  Diagnostic already emitted.
1385     Filename = FilenameBuffer.str();
1386     CharEnd = End.getLocWithOffset(1);
1387     break;
1388   default:
1389     Diag(FilenameTok.getLocation(), diag::err_pp_expects_filename);
1390     DiscardUntilEndOfDirective();
1391     return;
1392   }
1393 
1394   CharSourceRange FilenameRange
1395     = CharSourceRange::getCharRange(FilenameTok.getLocation(), CharEnd);
1396   StringRef OriginalFilename = Filename;
1397   bool isAngled =
1398     GetIncludeFilenameSpelling(FilenameTok.getLocation(), Filename);
1399   // If GetIncludeFilenameSpelling set the start ptr to null, there was an
1400   // error.
1401   if (Filename.empty()) {
1402     DiscardUntilEndOfDirective();
1403     return;
1404   }
1405 
1406   // Verify that there is nothing after the filename, other than EOD.  Note that
1407   // we allow macros that expand to nothing after the filename, because this
1408   // falls into the category of "#include pp-tokens new-line" specified in
1409   // C99 6.10.2p4.
1410   CheckEndOfDirective(IncludeTok.getIdentifierInfo()->getNameStart(), true);
1411 
1412   // Check that we don't have infinite #include recursion.
1413   if (IncludeMacroStack.size() == MaxAllowedIncludeStackDepth-1) {
1414     Diag(FilenameTok, diag::err_pp_include_too_deep);
1415     return;
1416   }
1417 
1418   // Complain about attempts to #include files in an audit pragma.
1419   if (PragmaARCCFCodeAuditedLoc.isValid()) {
1420     Diag(HashLoc, diag::err_pp_include_in_arc_cf_code_audited);
1421     Diag(PragmaARCCFCodeAuditedLoc, diag::note_pragma_entered_here);
1422 
1423     // Immediately leave the pragma.
1424     PragmaARCCFCodeAuditedLoc = SourceLocation();
1425   }
1426 
1427   if (HeaderInfo.HasIncludeAliasMap()) {
1428     // Map the filename with the brackets still attached.  If the name doesn't
1429     // map to anything, fall back on the filename we've already gotten the
1430     // spelling for.
1431     StringRef NewName = HeaderInfo.MapHeaderToIncludeAlias(OriginalFilename);
1432     if (!NewName.empty())
1433       Filename = NewName;
1434   }
1435 
1436   // Search include directories.
1437   const DirectoryLookup *CurDir;
1438   SmallString<1024> SearchPath;
1439   SmallString<1024> RelativePath;
1440   // We get the raw path only if we have 'Callbacks' to which we later pass
1441   // the path.
1442   ModuleMap::KnownHeader SuggestedModule;
1443   SourceLocation FilenameLoc = FilenameTok.getLocation();
1444   SmallString<128> NormalizedPath;
1445   if (LangOpts.MSVCCompat) {
1446     NormalizedPath = Filename.str();
1447 #ifndef LLVM_ON_WIN32
1448     llvm::sys::path::native(NormalizedPath);
1449 #endif
1450   }
1451   const FileEntry *File = LookupFile(
1452       FilenameLoc, LangOpts.MSVCCompat ? NormalizedPath.c_str() : Filename,
1453       isAngled, LookupFrom, CurDir, Callbacks ? &SearchPath : nullptr,
1454       Callbacks ? &RelativePath : nullptr,
1455       HeaderInfo.getHeaderSearchOpts().ModuleMaps ? &SuggestedModule : nullptr);
1456 
1457   if (Callbacks) {
1458     if (!File) {
1459       // Give the clients a chance to recover.
1460       SmallString<128> RecoveryPath;
1461       if (Callbacks->FileNotFound(Filename, RecoveryPath)) {
1462         if (const DirectoryEntry *DE = FileMgr.getDirectory(RecoveryPath)) {
1463           // Add the recovery path to the list of search paths.
1464           DirectoryLookup DL(DE, SrcMgr::C_User, false);
1465           HeaderInfo.AddSearchPath(DL, isAngled);
1466 
1467           // Try the lookup again, skipping the cache.
1468           File = LookupFile(FilenameLoc,
1469                             LangOpts.MSVCCompat ? NormalizedPath.c_str()
1470                                                 : Filename,
1471                             isAngled, LookupFrom, CurDir, nullptr, nullptr,
1472                             HeaderInfo.getHeaderSearchOpts().ModuleMaps
1473                                       ? &SuggestedModule
1474                                       : nullptr,
1475                             /*SkipCache*/ true);
1476         }
1477       }
1478     }
1479 
1480     if (!SuggestedModule || !getLangOpts().Modules) {
1481       // Notify the callback object that we've seen an inclusion directive.
1482       Callbacks->InclusionDirective(HashLoc, IncludeTok,
1483                                     LangOpts.MSVCCompat ? NormalizedPath.c_str()
1484                                                         : Filename,
1485                                     isAngled, FilenameRange, File, SearchPath,
1486                                     RelativePath, /*ImportedModule=*/nullptr);
1487     }
1488   }
1489 
1490   if (!File) {
1491     if (!SuppressIncludeNotFoundError) {
1492       // If the file could not be located and it was included via angle
1493       // brackets, we can attempt a lookup as though it were a quoted path to
1494       // provide the user with a possible fixit.
1495       if (isAngled) {
1496         File = LookupFile(
1497             FilenameLoc, LangOpts.MSVCCompat ? NormalizedPath.c_str() : Filename,
1498             false, LookupFrom, CurDir, Callbacks ? &SearchPath : nullptr,
1499             Callbacks ? &RelativePath : nullptr,
1500             HeaderInfo.getHeaderSearchOpts().ModuleMaps ? &SuggestedModule
1501                                                         : nullptr);
1502         if (File) {
1503           SourceRange Range(FilenameTok.getLocation(), CharEnd);
1504           Diag(FilenameTok, diag::err_pp_file_not_found_not_fatal) <<
1505             Filename <<
1506             FixItHint::CreateReplacement(Range, "\"" + Filename.str() + "\"");
1507         }
1508       }
1509       // If the file is still not found, just go with the vanilla diagnostic
1510       if (!File)
1511         Diag(FilenameTok, diag::err_pp_file_not_found) << Filename;
1512     }
1513     if (!File)
1514       return;
1515   }
1516 
1517   // If we are supposed to import a module rather than including the header,
1518   // do so now.
1519   if (SuggestedModule && getLangOpts().Modules &&
1520       SuggestedModule.getModule()->getTopLevelModuleName() !=
1521       getLangOpts().ImplementationOfModule) {
1522     // Compute the module access path corresponding to this module.
1523     // FIXME: Should we have a second loadModule() overload to avoid this
1524     // extra lookup step?
1525     SmallVector<std::pair<IdentifierInfo *, SourceLocation>, 2> Path;
1526     for (Module *Mod = SuggestedModule.getModule(); Mod; Mod = Mod->Parent)
1527       Path.push_back(std::make_pair(getIdentifierInfo(Mod->Name),
1528                                     FilenameTok.getLocation()));
1529     std::reverse(Path.begin(), Path.end());
1530 
1531     // Warn that we're replacing the include/import with a module import.
1532     SmallString<128> PathString;
1533     for (unsigned I = 0, N = Path.size(); I != N; ++I) {
1534       if (I)
1535         PathString += '.';
1536       PathString += Path[I].first->getName();
1537     }
1538     int IncludeKind = 0;
1539 
1540     switch (IncludeTok.getIdentifierInfo()->getPPKeywordID()) {
1541     case tok::pp_include:
1542       IncludeKind = 0;
1543       break;
1544 
1545     case tok::pp_import:
1546       IncludeKind = 1;
1547       break;
1548 
1549     case tok::pp_include_next:
1550       IncludeKind = 2;
1551       break;
1552 
1553     case tok::pp___include_macros:
1554       IncludeKind = 3;
1555       break;
1556 
1557     default:
1558       llvm_unreachable("unknown include directive kind");
1559     }
1560 
1561     // Determine whether we are actually building the module that this
1562     // include directive maps to.
1563     bool BuildingImportedModule
1564       = Path[0].first->getName() == getLangOpts().CurrentModule;
1565 
1566     if (!BuildingImportedModule && getLangOpts().ObjC2) {
1567       // If we're not building the imported module, warn that we're going
1568       // to automatically turn this inclusion directive into a module import.
1569       // We only do this in Objective-C, where we have a module-import syntax.
1570       CharSourceRange ReplaceRange(SourceRange(HashLoc, CharEnd),
1571                                    /*IsTokenRange=*/false);
1572       Diag(HashLoc, diag::warn_auto_module_import)
1573         << IncludeKind << PathString
1574         << FixItHint::CreateReplacement(ReplaceRange,
1575              "@import " + PathString.str().str() + ";");
1576     }
1577 
1578     // Load the module. Only make macros visible. We'll make the declarations
1579     // visible when the parser gets here.
1580     Module::NameVisibilityKind Visibility = Module::MacrosVisible;
1581     ModuleLoadResult Imported
1582       = TheModuleLoader.loadModule(IncludeTok.getLocation(), Path, Visibility,
1583                                    /*IsIncludeDirective=*/true);
1584     assert((Imported == nullptr || Imported == SuggestedModule.getModule()) &&
1585            "the imported module is different than the suggested one");
1586 
1587     if (!Imported && hadModuleLoaderFatalFailure()) {
1588       // With a fatal failure in the module loader, we abort parsing.
1589       Token &Result = IncludeTok;
1590       if (CurLexer) {
1591         Result.startToken();
1592         CurLexer->FormTokenWithChars(Result, CurLexer->BufferEnd, tok::eof);
1593         CurLexer->cutOffLexing();
1594       } else {
1595         assert(CurPTHLexer && "#include but no current lexer set!");
1596         CurPTHLexer->getEOF(Result);
1597       }
1598       return;
1599     }
1600 
1601     // If this header isn't part of the module we're building, we're done.
1602     if (!BuildingImportedModule && Imported) {
1603       if (Callbacks) {
1604         Callbacks->InclusionDirective(HashLoc, IncludeTok, Filename, isAngled,
1605                                       FilenameRange, File,
1606                                       SearchPath, RelativePath, Imported);
1607       }
1608 
1609       if (IncludeKind != 3) {
1610         // Let the parser know that we hit a module import, and it should
1611         // make the module visible.
1612         // FIXME: Produce this as the current token directly, rather than
1613         // allocating a new token for it.
1614         EnterAnnotationToken(*this, HashLoc, End, tok::annot_module_include,
1615                              Imported);
1616       }
1617       return;
1618     }
1619 
1620     // If we failed to find a submodule that we expected to find, we can
1621     // continue. Otherwise, there's an error in the included file, so we
1622     // don't want to include it.
1623     if (!BuildingImportedModule && !Imported.isMissingExpected()) {
1624       return;
1625     }
1626   }
1627 
1628   if (Callbacks && SuggestedModule) {
1629     // We didn't notify the callback object that we've seen an inclusion
1630     // directive before. Now that we are parsing the include normally and not
1631     // turning it to a module import, notify the callback object.
1632     Callbacks->InclusionDirective(HashLoc, IncludeTok, Filename, isAngled,
1633                                   FilenameRange, File,
1634                                   SearchPath, RelativePath,
1635                                   /*ImportedModule=*/nullptr);
1636   }
1637 
1638   // The #included file will be considered to be a system header if either it is
1639   // in a system include directory, or if the #includer is a system include
1640   // header.
1641   SrcMgr::CharacteristicKind FileCharacter =
1642     std::max(HeaderInfo.getFileDirFlavor(File),
1643              SourceMgr.getFileCharacteristic(FilenameTok.getLocation()));
1644 
1645   // Ask HeaderInfo if we should enter this #include file.  If not, #including
1646   // this file will have no effect.
1647   if (!HeaderInfo.ShouldEnterIncludeFile(File, isImport)) {
1648     if (Callbacks)
1649       Callbacks->FileSkipped(*File, FilenameTok, FileCharacter);
1650     return;
1651   }
1652 
1653   // Look up the file, create a File ID for it.
1654   SourceLocation IncludePos = End;
1655   // If the filename string was the result of macro expansions, set the include
1656   // position on the file where it will be included and after the expansions.
1657   if (IncludePos.isMacroID())
1658     IncludePos = SourceMgr.getExpansionRange(IncludePos).second;
1659   FileID FID = SourceMgr.createFileID(File, IncludePos, FileCharacter);
1660   assert(!FID.isInvalid() && "Expected valid file ID");
1661 
1662   // Determine if we're switching to building a new submodule, and which one.
1663   ModuleMap::KnownHeader BuildingModule;
1664   if (getLangOpts().Modules && !getLangOpts().CurrentModule.empty()) {
1665     Module *RequestingModule = getModuleForLocation(FilenameLoc);
1666     BuildingModule =
1667         HeaderInfo.getModuleMap().findModuleForHeader(File, RequestingModule);
1668   }
1669 
1670   // If all is good, enter the new file!
1671   if (EnterSourceFile(FID, CurDir, FilenameTok.getLocation()))
1672     return;
1673 
1674   // If we're walking into another part of the same module, let the parser
1675   // know that any future declarations are within that other submodule.
1676   if (BuildingModule) {
1677     assert(!CurSubmodule && "should not have marked this as a module yet");
1678     CurSubmodule = BuildingModule.getModule();
1679 
1680     EnterAnnotationToken(*this, HashLoc, End, tok::annot_module_begin,
1681                          CurSubmodule);
1682   }
1683 }
1684 
1685 /// HandleIncludeNextDirective - Implements \#include_next.
1686 ///
1687 void Preprocessor::HandleIncludeNextDirective(SourceLocation HashLoc,
1688                                               Token &IncludeNextTok) {
1689   Diag(IncludeNextTok, diag::ext_pp_include_next_directive);
1690 
1691   // #include_next is like #include, except that we start searching after
1692   // the current found directory.  If we can't do this, issue a
1693   // diagnostic.
1694   const DirectoryLookup *Lookup = CurDirLookup;
1695   if (isInPrimaryFile()) {
1696     Lookup = nullptr;
1697     Diag(IncludeNextTok, diag::pp_include_next_in_primary);
1698   } else if (!Lookup) {
1699     Diag(IncludeNextTok, diag::pp_include_next_absolute_path);
1700   } else {
1701     // Start looking up in the next directory.
1702     ++Lookup;
1703   }
1704 
1705   return HandleIncludeDirective(HashLoc, IncludeNextTok, Lookup);
1706 }
1707 
1708 /// HandleMicrosoftImportDirective - Implements \#import for Microsoft Mode
1709 void Preprocessor::HandleMicrosoftImportDirective(Token &Tok) {
1710   // The Microsoft #import directive takes a type library and generates header
1711   // files from it, and includes those.  This is beyond the scope of what clang
1712   // does, so we ignore it and error out.  However, #import can optionally have
1713   // trailing attributes that span multiple lines.  We're going to eat those
1714   // so we can continue processing from there.
1715   Diag(Tok, diag::err_pp_import_directive_ms );
1716 
1717   // Read tokens until we get to the end of the directive.  Note that the
1718   // directive can be split over multiple lines using the backslash character.
1719   DiscardUntilEndOfDirective();
1720 }
1721 
1722 /// HandleImportDirective - Implements \#import.
1723 ///
1724 void Preprocessor::HandleImportDirective(SourceLocation HashLoc,
1725                                          Token &ImportTok) {
1726   if (!LangOpts.ObjC1) {  // #import is standard for ObjC.
1727     if (LangOpts.MSVCCompat)
1728       return HandleMicrosoftImportDirective(ImportTok);
1729     Diag(ImportTok, diag::ext_pp_import_directive);
1730   }
1731   return HandleIncludeDirective(HashLoc, ImportTok, nullptr, true);
1732 }
1733 
1734 /// HandleIncludeMacrosDirective - The -imacros command line option turns into a
1735 /// pseudo directive in the predefines buffer.  This handles it by sucking all
1736 /// tokens through the preprocessor and discarding them (only keeping the side
1737 /// effects on the preprocessor).
1738 void Preprocessor::HandleIncludeMacrosDirective(SourceLocation HashLoc,
1739                                                 Token &IncludeMacrosTok) {
1740   // This directive should only occur in the predefines buffer.  If not, emit an
1741   // error and reject it.
1742   SourceLocation Loc = IncludeMacrosTok.getLocation();
1743   if (strcmp(SourceMgr.getBufferName(Loc), "<built-in>") != 0) {
1744     Diag(IncludeMacrosTok.getLocation(),
1745          diag::pp_include_macros_out_of_predefines);
1746     DiscardUntilEndOfDirective();
1747     return;
1748   }
1749 
1750   // Treat this as a normal #include for checking purposes.  If this is
1751   // successful, it will push a new lexer onto the include stack.
1752   HandleIncludeDirective(HashLoc, IncludeMacrosTok, nullptr, false);
1753 
1754   Token TmpTok;
1755   do {
1756     Lex(TmpTok);
1757     assert(TmpTok.isNot(tok::eof) && "Didn't find end of -imacros!");
1758   } while (TmpTok.isNot(tok::hashhash));
1759 }
1760 
1761 //===----------------------------------------------------------------------===//
1762 // Preprocessor Macro Directive Handling.
1763 //===----------------------------------------------------------------------===//
1764 
1765 /// ReadMacroDefinitionArgList - The ( starting an argument list of a macro
1766 /// definition has just been read.  Lex the rest of the arguments and the
1767 /// closing ), updating MI with what we learn.  Return true if an error occurs
1768 /// parsing the arg list.
1769 bool Preprocessor::ReadMacroDefinitionArgList(MacroInfo *MI, Token &Tok) {
1770   SmallVector<IdentifierInfo*, 32> Arguments;
1771 
1772   while (1) {
1773     LexUnexpandedToken(Tok);
1774     switch (Tok.getKind()) {
1775     case tok::r_paren:
1776       // Found the end of the argument list.
1777       if (Arguments.empty())  // #define FOO()
1778         return false;
1779       // Otherwise we have #define FOO(A,)
1780       Diag(Tok, diag::err_pp_expected_ident_in_arg_list);
1781       return true;
1782     case tok::ellipsis:  // #define X(... -> C99 varargs
1783       if (!LangOpts.C99)
1784         Diag(Tok, LangOpts.CPlusPlus11 ?
1785              diag::warn_cxx98_compat_variadic_macro :
1786              diag::ext_variadic_macro);
1787 
1788       // OpenCL v1.2 s6.9.e: variadic macros are not supported.
1789       if (LangOpts.OpenCL) {
1790         Diag(Tok, diag::err_pp_opencl_variadic_macros);
1791         return true;
1792       }
1793 
1794       // Lex the token after the identifier.
1795       LexUnexpandedToken(Tok);
1796       if (Tok.isNot(tok::r_paren)) {
1797         Diag(Tok, diag::err_pp_missing_rparen_in_macro_def);
1798         return true;
1799       }
1800       // Add the __VA_ARGS__ identifier as an argument.
1801       Arguments.push_back(Ident__VA_ARGS__);
1802       MI->setIsC99Varargs();
1803       MI->setArgumentList(&Arguments[0], Arguments.size(), BP);
1804       return false;
1805     case tok::eod:  // #define X(
1806       Diag(Tok, diag::err_pp_missing_rparen_in_macro_def);
1807       return true;
1808     default:
1809       // Handle keywords and identifiers here to accept things like
1810       // #define Foo(for) for.
1811       IdentifierInfo *II = Tok.getIdentifierInfo();
1812       if (!II) {
1813         // #define X(1
1814         Diag(Tok, diag::err_pp_invalid_tok_in_arg_list);
1815         return true;
1816       }
1817 
1818       // If this is already used as an argument, it is used multiple times (e.g.
1819       // #define X(A,A.
1820       if (std::find(Arguments.begin(), Arguments.end(), II) !=
1821           Arguments.end()) {  // C99 6.10.3p6
1822         Diag(Tok, diag::err_pp_duplicate_name_in_arg_list) << II;
1823         return true;
1824       }
1825 
1826       // Add the argument to the macro info.
1827       Arguments.push_back(II);
1828 
1829       // Lex the token after the identifier.
1830       LexUnexpandedToken(Tok);
1831 
1832       switch (Tok.getKind()) {
1833       default:          // #define X(A B
1834         Diag(Tok, diag::err_pp_expected_comma_in_arg_list);
1835         return true;
1836       case tok::r_paren: // #define X(A)
1837         MI->setArgumentList(&Arguments[0], Arguments.size(), BP);
1838         return false;
1839       case tok::comma:  // #define X(A,
1840         break;
1841       case tok::ellipsis:  // #define X(A... -> GCC extension
1842         // Diagnose extension.
1843         Diag(Tok, diag::ext_named_variadic_macro);
1844 
1845         // Lex the token after the identifier.
1846         LexUnexpandedToken(Tok);
1847         if (Tok.isNot(tok::r_paren)) {
1848           Diag(Tok, diag::err_pp_missing_rparen_in_macro_def);
1849           return true;
1850         }
1851 
1852         MI->setIsGNUVarargs();
1853         MI->setArgumentList(&Arguments[0], Arguments.size(), BP);
1854         return false;
1855       }
1856     }
1857   }
1858 }
1859 
1860 /// HandleDefineDirective - Implements \#define.  This consumes the entire macro
1861 /// line then lets the caller lex the next real token.
1862 void Preprocessor::HandleDefineDirective(Token &DefineTok,
1863                                          bool ImmediatelyAfterHeaderGuard) {
1864   ++NumDefined;
1865 
1866   Token MacroNameTok;
1867   ReadMacroName(MacroNameTok, 1);
1868 
1869   // Error reading macro name?  If so, diagnostic already issued.
1870   if (MacroNameTok.is(tok::eod))
1871     return;
1872 
1873   Token LastTok = MacroNameTok;
1874 
1875   // If we are supposed to keep comments in #defines, reenable comment saving
1876   // mode.
1877   if (CurLexer) CurLexer->SetCommentRetentionState(KeepMacroComments);
1878 
1879   // Create the new macro.
1880   MacroInfo *MI = AllocateMacroInfo(MacroNameTok.getLocation());
1881 
1882   Token Tok;
1883   LexUnexpandedToken(Tok);
1884 
1885   // If this is a function-like macro definition, parse the argument list,
1886   // marking each of the identifiers as being used as macro arguments.  Also,
1887   // check other constraints on the first token of the macro body.
1888   if (Tok.is(tok::eod)) {
1889     if (ImmediatelyAfterHeaderGuard) {
1890       // Save this macro information since it may part of a header guard.
1891       CurPPLexer->MIOpt.SetDefinedMacro(MacroNameTok.getIdentifierInfo(),
1892                                         MacroNameTok.getLocation());
1893     }
1894     // If there is no body to this macro, we have no special handling here.
1895   } else if (Tok.hasLeadingSpace()) {
1896     // This is a normal token with leading space.  Clear the leading space
1897     // marker on the first token to get proper expansion.
1898     Tok.clearFlag(Token::LeadingSpace);
1899   } else if (Tok.is(tok::l_paren)) {
1900     // This is a function-like macro definition.  Read the argument list.
1901     MI->setIsFunctionLike();
1902     if (ReadMacroDefinitionArgList(MI, LastTok)) {
1903       // Throw away the rest of the line.
1904       if (CurPPLexer->ParsingPreprocessorDirective)
1905         DiscardUntilEndOfDirective();
1906       return;
1907     }
1908 
1909     // If this is a definition of a variadic C99 function-like macro, not using
1910     // the GNU named varargs extension, enabled __VA_ARGS__.
1911 
1912     // "Poison" __VA_ARGS__, which can only appear in the expansion of a macro.
1913     // This gets unpoisoned where it is allowed.
1914     assert(Ident__VA_ARGS__->isPoisoned() && "__VA_ARGS__ should be poisoned!");
1915     if (MI->isC99Varargs())
1916       Ident__VA_ARGS__->setIsPoisoned(false);
1917 
1918     // Read the first token after the arg list for down below.
1919     LexUnexpandedToken(Tok);
1920   } else if (LangOpts.C99 || LangOpts.CPlusPlus11) {
1921     // C99 requires whitespace between the macro definition and the body.  Emit
1922     // a diagnostic for something like "#define X+".
1923     Diag(Tok, diag::ext_c99_whitespace_required_after_macro_name);
1924   } else {
1925     // C90 6.8 TC1 says: "In the definition of an object-like macro, if the
1926     // first character of a replacement list is not a character required by
1927     // subclause 5.2.1, then there shall be white-space separation between the
1928     // identifier and the replacement list.".  5.2.1 lists this set:
1929     //   "A-Za-z0-9!"#%&'()*+,_./:;<=>?[\]^_{|}~" as well as whitespace, which
1930     // is irrelevant here.
1931     bool isInvalid = false;
1932     if (Tok.is(tok::at)) // @ is not in the list above.
1933       isInvalid = true;
1934     else if (Tok.is(tok::unknown)) {
1935       // If we have an unknown token, it is something strange like "`".  Since
1936       // all of valid characters would have lexed into a single character
1937       // token of some sort, we know this is not a valid case.
1938       isInvalid = true;
1939     }
1940     if (isInvalid)
1941       Diag(Tok, diag::ext_missing_whitespace_after_macro_name);
1942     else
1943       Diag(Tok, diag::warn_missing_whitespace_after_macro_name);
1944   }
1945 
1946   if (!Tok.is(tok::eod))
1947     LastTok = Tok;
1948 
1949   // Read the rest of the macro body.
1950   if (MI->isObjectLike()) {
1951     // Object-like macros are very simple, just read their body.
1952     while (Tok.isNot(tok::eod)) {
1953       LastTok = Tok;
1954       MI->AddTokenToBody(Tok);
1955       // Get the next token of the macro.
1956       LexUnexpandedToken(Tok);
1957     }
1958 
1959   } else {
1960     // Otherwise, read the body of a function-like macro.  While we are at it,
1961     // check C99 6.10.3.2p1: ensure that # operators are followed by macro
1962     // parameters in function-like macro expansions.
1963     while (Tok.isNot(tok::eod)) {
1964       LastTok = Tok;
1965 
1966       if (Tok.isNot(tok::hash) && Tok.isNot(tok::hashhash)) {
1967         MI->AddTokenToBody(Tok);
1968 
1969         // Get the next token of the macro.
1970         LexUnexpandedToken(Tok);
1971         continue;
1972       }
1973 
1974       // If we're in -traditional mode, then we should ignore stringification
1975       // and token pasting. Mark the tokens as unknown so as not to confuse
1976       // things.
1977       if (getLangOpts().TraditionalCPP) {
1978         Tok.setKind(tok::unknown);
1979         MI->AddTokenToBody(Tok);
1980 
1981         // Get the next token of the macro.
1982         LexUnexpandedToken(Tok);
1983         continue;
1984       }
1985 
1986       if (Tok.is(tok::hashhash)) {
1987 
1988         // If we see token pasting, check if it looks like the gcc comma
1989         // pasting extension.  We'll use this information to suppress
1990         // diagnostics later on.
1991 
1992         // Get the next token of the macro.
1993         LexUnexpandedToken(Tok);
1994 
1995         if (Tok.is(tok::eod)) {
1996           MI->AddTokenToBody(LastTok);
1997           break;
1998         }
1999 
2000         unsigned NumTokens = MI->getNumTokens();
2001         if (NumTokens && Tok.getIdentifierInfo() == Ident__VA_ARGS__ &&
2002             MI->getReplacementToken(NumTokens-1).is(tok::comma))
2003           MI->setHasCommaPasting();
2004 
2005         // Things look ok, add the '##' token to the macro.
2006         MI->AddTokenToBody(LastTok);
2007         continue;
2008       }
2009 
2010       // Get the next token of the macro.
2011       LexUnexpandedToken(Tok);
2012 
2013       // Check for a valid macro arg identifier.
2014       if (Tok.getIdentifierInfo() == nullptr ||
2015           MI->getArgumentNum(Tok.getIdentifierInfo()) == -1) {
2016 
2017         // If this is assembler-with-cpp mode, we accept random gibberish after
2018         // the '#' because '#' is often a comment character.  However, change
2019         // the kind of the token to tok::unknown so that the preprocessor isn't
2020         // confused.
2021         if (getLangOpts().AsmPreprocessor && Tok.isNot(tok::eod)) {
2022           LastTok.setKind(tok::unknown);
2023           MI->AddTokenToBody(LastTok);
2024           continue;
2025         } else {
2026           Diag(Tok, diag::err_pp_stringize_not_parameter);
2027 
2028           // Disable __VA_ARGS__ again.
2029           Ident__VA_ARGS__->setIsPoisoned(true);
2030           return;
2031         }
2032       }
2033 
2034       // Things look ok, add the '#' and param name tokens to the macro.
2035       MI->AddTokenToBody(LastTok);
2036       MI->AddTokenToBody(Tok);
2037       LastTok = Tok;
2038 
2039       // Get the next token of the macro.
2040       LexUnexpandedToken(Tok);
2041     }
2042   }
2043 
2044 
2045   // Disable __VA_ARGS__ again.
2046   Ident__VA_ARGS__->setIsPoisoned(true);
2047 
2048   // Check that there is no paste (##) operator at the beginning or end of the
2049   // replacement list.
2050   unsigned NumTokens = MI->getNumTokens();
2051   if (NumTokens != 0) {
2052     if (MI->getReplacementToken(0).is(tok::hashhash)) {
2053       Diag(MI->getReplacementToken(0), diag::err_paste_at_start);
2054       return;
2055     }
2056     if (MI->getReplacementToken(NumTokens-1).is(tok::hashhash)) {
2057       Diag(MI->getReplacementToken(NumTokens-1), diag::err_paste_at_end);
2058       return;
2059     }
2060   }
2061 
2062   MI->setDefinitionEndLoc(LastTok.getLocation());
2063 
2064   // Finally, if this identifier already had a macro defined for it, verify that
2065   // the macro bodies are identical, and issue diagnostics if they are not.
2066   if (const MacroInfo *OtherMI=getMacroInfo(MacroNameTok.getIdentifierInfo())) {
2067     // It is very common for system headers to have tons of macro redefinitions
2068     // and for warnings to be disabled in system headers.  If this is the case,
2069     // then don't bother calling MacroInfo::isIdenticalTo.
2070     if (!getDiagnostics().getSuppressSystemWarnings() ||
2071         !SourceMgr.isInSystemHeader(DefineTok.getLocation())) {
2072       if (!OtherMI->isUsed() && OtherMI->isWarnIfUnused())
2073         Diag(OtherMI->getDefinitionLoc(), diag::pp_macro_not_used);
2074 
2075       // Warn if defining "__LINE__" and other builtins, per C99 6.10.8/4 and
2076       // C++ [cpp.predefined]p4, but allow it as an extension.
2077       if (OtherMI->isBuiltinMacro())
2078         Diag(MacroNameTok, diag::ext_pp_redef_builtin_macro);
2079       // Macros must be identical.  This means all tokens and whitespace
2080       // separation must be the same.  C99 6.10.3p2.
2081       else if (!OtherMI->isAllowRedefinitionsWithoutWarning() &&
2082                !MI->isIdenticalTo(*OtherMI, *this, /*Syntactic=*/LangOpts.MicrosoftExt)) {
2083         Diag(MI->getDefinitionLoc(), diag::ext_pp_macro_redef)
2084           << MacroNameTok.getIdentifierInfo();
2085         Diag(OtherMI->getDefinitionLoc(), diag::note_previous_definition);
2086       }
2087     }
2088     if (OtherMI->isWarnIfUnused())
2089       WarnUnusedMacroLocs.erase(OtherMI->getDefinitionLoc());
2090   }
2091 
2092   DefMacroDirective *MD =
2093       appendDefMacroDirective(MacroNameTok.getIdentifierInfo(), MI);
2094 
2095   assert(!MI->isUsed());
2096   // If we need warning for not using the macro, add its location in the
2097   // warn-because-unused-macro set. If it gets used it will be removed from set.
2098   if (getSourceManager().isInMainFile(MI->getDefinitionLoc()) &&
2099       !Diags->isIgnored(diag::pp_macro_not_used, MI->getDefinitionLoc())) {
2100     MI->setIsWarnIfUnused(true);
2101     WarnUnusedMacroLocs.insert(MI->getDefinitionLoc());
2102   }
2103 
2104   // If the callbacks want to know, tell them about the macro definition.
2105   if (Callbacks)
2106     Callbacks->MacroDefined(MacroNameTok, MD);
2107 }
2108 
2109 /// HandleUndefDirective - Implements \#undef.
2110 ///
2111 void Preprocessor::HandleUndefDirective(Token &UndefTok) {
2112   ++NumUndefined;
2113 
2114   Token MacroNameTok;
2115   ReadMacroName(MacroNameTok, 2);
2116 
2117   // Error reading macro name?  If so, diagnostic already issued.
2118   if (MacroNameTok.is(tok::eod))
2119     return;
2120 
2121   // Check to see if this is the last token on the #undef line.
2122   CheckEndOfDirective("undef");
2123 
2124   // Okay, we finally have a valid identifier to undef.
2125   MacroDirective *MD = getMacroDirective(MacroNameTok.getIdentifierInfo());
2126   const MacroInfo *MI = MD ? MD->getMacroInfo() : nullptr;
2127 
2128   // If the callbacks want to know, tell them about the macro #undef.
2129   // Note: no matter if the macro was defined or not.
2130   if (Callbacks)
2131     Callbacks->MacroUndefined(MacroNameTok, MD);
2132 
2133   // If the macro is not defined, this is a noop undef, just return.
2134   if (!MI)
2135     return;
2136 
2137   if (!MI->isUsed() && MI->isWarnIfUnused())
2138     Diag(MI->getDefinitionLoc(), diag::pp_macro_not_used);
2139 
2140   if (MI->isWarnIfUnused())
2141     WarnUnusedMacroLocs.erase(MI->getDefinitionLoc());
2142 
2143   appendMacroDirective(MacroNameTok.getIdentifierInfo(),
2144                        AllocateUndefMacroDirective(MacroNameTok.getLocation()));
2145 }
2146 
2147 
2148 //===----------------------------------------------------------------------===//
2149 // Preprocessor Conditional Directive Handling.
2150 //===----------------------------------------------------------------------===//
2151 
2152 /// HandleIfdefDirective - Implements the \#ifdef/\#ifndef directive.  isIfndef
2153 /// is true when this is a \#ifndef directive.  ReadAnyTokensBeforeDirective is
2154 /// true if any tokens have been returned or pp-directives activated before this
2155 /// \#ifndef has been lexed.
2156 ///
2157 void Preprocessor::HandleIfdefDirective(Token &Result, bool isIfndef,
2158                                         bool ReadAnyTokensBeforeDirective) {
2159   ++NumIf;
2160   Token DirectiveTok = Result;
2161 
2162   Token MacroNameTok;
2163   ReadMacroName(MacroNameTok);
2164 
2165   // Error reading macro name?  If so, diagnostic already issued.
2166   if (MacroNameTok.is(tok::eod)) {
2167     // Skip code until we get to #endif.  This helps with recovery by not
2168     // emitting an error when the #endif is reached.
2169     SkipExcludedConditionalBlock(DirectiveTok.getLocation(),
2170                                  /*Foundnonskip*/false, /*FoundElse*/false);
2171     return;
2172   }
2173 
2174   // Check to see if this is the last token on the #if[n]def line.
2175   CheckEndOfDirective(isIfndef ? "ifndef" : "ifdef");
2176 
2177   IdentifierInfo *MII = MacroNameTok.getIdentifierInfo();
2178   MacroDirective *MD = getMacroDirective(MII);
2179   MacroInfo *MI = MD ? MD->getMacroInfo() : nullptr;
2180 
2181   if (CurPPLexer->getConditionalStackDepth() == 0) {
2182     // If the start of a top-level #ifdef and if the macro is not defined,
2183     // inform MIOpt that this might be the start of a proper include guard.
2184     // Otherwise it is some other form of unknown conditional which we can't
2185     // handle.
2186     if (!ReadAnyTokensBeforeDirective && !MI) {
2187       assert(isIfndef && "#ifdef shouldn't reach here");
2188       CurPPLexer->MIOpt.EnterTopLevelIfndef(MII, MacroNameTok.getLocation());
2189     } else
2190       CurPPLexer->MIOpt.EnterTopLevelConditional();
2191   }
2192 
2193   // If there is a macro, process it.
2194   if (MI)  // Mark it used.
2195     markMacroAsUsed(MI);
2196 
2197   if (Callbacks) {
2198     if (isIfndef)
2199       Callbacks->Ifndef(DirectiveTok.getLocation(), MacroNameTok, MD);
2200     else
2201       Callbacks->Ifdef(DirectiveTok.getLocation(), MacroNameTok, MD);
2202   }
2203 
2204   // Should we include the stuff contained by this directive?
2205   if (!MI == isIfndef) {
2206     // Yes, remember that we are inside a conditional, then lex the next token.
2207     CurPPLexer->pushConditionalLevel(DirectiveTok.getLocation(),
2208                                      /*wasskip*/false, /*foundnonskip*/true,
2209                                      /*foundelse*/false);
2210   } else {
2211     // No, skip the contents of this block.
2212     SkipExcludedConditionalBlock(DirectiveTok.getLocation(),
2213                                  /*Foundnonskip*/false,
2214                                  /*FoundElse*/false);
2215   }
2216 }
2217 
2218 /// HandleIfDirective - Implements the \#if directive.
2219 ///
2220 void Preprocessor::HandleIfDirective(Token &IfToken,
2221                                      bool ReadAnyTokensBeforeDirective) {
2222   ++NumIf;
2223 
2224   // Parse and evaluate the conditional expression.
2225   IdentifierInfo *IfNDefMacro = nullptr;
2226   const SourceLocation ConditionalBegin = CurPPLexer->getSourceLocation();
2227   const bool ConditionalTrue = EvaluateDirectiveExpression(IfNDefMacro);
2228   const SourceLocation ConditionalEnd = CurPPLexer->getSourceLocation();
2229 
2230   // If this condition is equivalent to #ifndef X, and if this is the first
2231   // directive seen, handle it for the multiple-include optimization.
2232   if (CurPPLexer->getConditionalStackDepth() == 0) {
2233     if (!ReadAnyTokensBeforeDirective && IfNDefMacro && ConditionalTrue)
2234       // FIXME: Pass in the location of the macro name, not the 'if' token.
2235       CurPPLexer->MIOpt.EnterTopLevelIfndef(IfNDefMacro, IfToken.getLocation());
2236     else
2237       CurPPLexer->MIOpt.EnterTopLevelConditional();
2238   }
2239 
2240   if (Callbacks)
2241     Callbacks->If(IfToken.getLocation(),
2242                   SourceRange(ConditionalBegin, ConditionalEnd),
2243                   (ConditionalTrue ? PPCallbacks::CVK_True : PPCallbacks::CVK_False));
2244 
2245   // Should we include the stuff contained by this directive?
2246   if (ConditionalTrue) {
2247     // Yes, remember that we are inside a conditional, then lex the next token.
2248     CurPPLexer->pushConditionalLevel(IfToken.getLocation(), /*wasskip*/false,
2249                                    /*foundnonskip*/true, /*foundelse*/false);
2250   } else {
2251     // No, skip the contents of this block.
2252     SkipExcludedConditionalBlock(IfToken.getLocation(), /*Foundnonskip*/false,
2253                                  /*FoundElse*/false);
2254   }
2255 }
2256 
2257 /// HandleEndifDirective - Implements the \#endif directive.
2258 ///
2259 void Preprocessor::HandleEndifDirective(Token &EndifToken) {
2260   ++NumEndif;
2261 
2262   // Check that this is the whole directive.
2263   CheckEndOfDirective("endif");
2264 
2265   PPConditionalInfo CondInfo;
2266   if (CurPPLexer->popConditionalLevel(CondInfo)) {
2267     // No conditionals on the stack: this is an #endif without an #if.
2268     Diag(EndifToken, diag::err_pp_endif_without_if);
2269     return;
2270   }
2271 
2272   // If this the end of a top-level #endif, inform MIOpt.
2273   if (CurPPLexer->getConditionalStackDepth() == 0)
2274     CurPPLexer->MIOpt.ExitTopLevelConditional();
2275 
2276   assert(!CondInfo.WasSkipping && !CurPPLexer->LexingRawMode &&
2277          "This code should only be reachable in the non-skipping case!");
2278 
2279   if (Callbacks)
2280     Callbacks->Endif(EndifToken.getLocation(), CondInfo.IfLoc);
2281 }
2282 
2283 /// HandleElseDirective - Implements the \#else directive.
2284 ///
2285 void Preprocessor::HandleElseDirective(Token &Result) {
2286   ++NumElse;
2287 
2288   // #else directive in a non-skipping conditional... start skipping.
2289   CheckEndOfDirective("else");
2290 
2291   PPConditionalInfo CI;
2292   if (CurPPLexer->popConditionalLevel(CI)) {
2293     Diag(Result, diag::pp_err_else_without_if);
2294     return;
2295   }
2296 
2297   // If this is a top-level #else, inform the MIOpt.
2298   if (CurPPLexer->getConditionalStackDepth() == 0)
2299     CurPPLexer->MIOpt.EnterTopLevelConditional();
2300 
2301   // If this is a #else with a #else before it, report the error.
2302   if (CI.FoundElse) Diag(Result, diag::pp_err_else_after_else);
2303 
2304   if (Callbacks)
2305     Callbacks->Else(Result.getLocation(), CI.IfLoc);
2306 
2307   // Finally, skip the rest of the contents of this block.
2308   SkipExcludedConditionalBlock(CI.IfLoc, /*Foundnonskip*/true,
2309                                /*FoundElse*/true, Result.getLocation());
2310 }
2311 
2312 /// HandleElifDirective - Implements the \#elif directive.
2313 ///
2314 void Preprocessor::HandleElifDirective(Token &ElifToken) {
2315   ++NumElse;
2316 
2317   // #elif directive in a non-skipping conditional... start skipping.
2318   // We don't care what the condition is, because we will always skip it (since
2319   // the block immediately before it was included).
2320   const SourceLocation ConditionalBegin = CurPPLexer->getSourceLocation();
2321   DiscardUntilEndOfDirective();
2322   const SourceLocation ConditionalEnd = CurPPLexer->getSourceLocation();
2323 
2324   PPConditionalInfo CI;
2325   if (CurPPLexer->popConditionalLevel(CI)) {
2326     Diag(ElifToken, diag::pp_err_elif_without_if);
2327     return;
2328   }
2329 
2330   // If this is a top-level #elif, inform the MIOpt.
2331   if (CurPPLexer->getConditionalStackDepth() == 0)
2332     CurPPLexer->MIOpt.EnterTopLevelConditional();
2333 
2334   // If this is a #elif with a #else before it, report the error.
2335   if (CI.FoundElse) Diag(ElifToken, diag::pp_err_elif_after_else);
2336 
2337   if (Callbacks)
2338     Callbacks->Elif(ElifToken.getLocation(),
2339                     SourceRange(ConditionalBegin, ConditionalEnd),
2340                     PPCallbacks::CVK_NotEvaluated, CI.IfLoc);
2341 
2342   // Finally, skip the rest of the contents of this block.
2343   SkipExcludedConditionalBlock(CI.IfLoc, /*Foundnonskip*/true,
2344                                /*FoundElse*/CI.FoundElse,
2345                                ElifToken.getLocation());
2346 }
2347