xref: /aosp_15_r20/external/clang/unittests/Basic/SourceManagerTest.cpp (revision 67e74705e28f6214e480b399dd47ea732279e315)
1*67e74705SXin Li //===- unittests/Basic/SourceManagerTest.cpp ------ SourceManager tests ---===//
2*67e74705SXin Li //
3*67e74705SXin Li //                     The LLVM Compiler Infrastructure
4*67e74705SXin Li //
5*67e74705SXin Li // This file is distributed under the University of Illinois Open Source
6*67e74705SXin Li // License. See LICENSE.TXT for details.
7*67e74705SXin Li //
8*67e74705SXin Li //===----------------------------------------------------------------------===//
9*67e74705SXin Li 
10*67e74705SXin Li #include "clang/Basic/SourceManager.h"
11*67e74705SXin Li #include "clang/Basic/Diagnostic.h"
12*67e74705SXin Li #include "clang/Basic/DiagnosticOptions.h"
13*67e74705SXin Li #include "clang/Basic/FileManager.h"
14*67e74705SXin Li #include "clang/Basic/LangOptions.h"
15*67e74705SXin Li #include "clang/Basic/TargetInfo.h"
16*67e74705SXin Li #include "clang/Basic/TargetOptions.h"
17*67e74705SXin Li #include "clang/Lex/HeaderSearch.h"
18*67e74705SXin Li #include "clang/Lex/HeaderSearchOptions.h"
19*67e74705SXin Li #include "clang/Lex/ModuleLoader.h"
20*67e74705SXin Li #include "clang/Lex/Preprocessor.h"
21*67e74705SXin Li #include "clang/Lex/PreprocessorOptions.h"
22*67e74705SXin Li #include "llvm/ADT/SmallString.h"
23*67e74705SXin Li #include "llvm/Config/llvm-config.h"
24*67e74705SXin Li #include "gtest/gtest.h"
25*67e74705SXin Li 
26*67e74705SXin Li using namespace clang;
27*67e74705SXin Li 
28*67e74705SXin Li namespace {
29*67e74705SXin Li 
30*67e74705SXin Li // The test fixture.
31*67e74705SXin Li class SourceManagerTest : public ::testing::Test {
32*67e74705SXin Li protected:
SourceManagerTest()33*67e74705SXin Li   SourceManagerTest()
34*67e74705SXin Li     : FileMgr(FileMgrOpts),
35*67e74705SXin Li       DiagID(new DiagnosticIDs()),
36*67e74705SXin Li       Diags(DiagID, new DiagnosticOptions, new IgnoringDiagConsumer()),
37*67e74705SXin Li       SourceMgr(Diags, FileMgr),
38*67e74705SXin Li       TargetOpts(new TargetOptions) {
39*67e74705SXin Li     TargetOpts->Triple = "x86_64-apple-darwin11.1.0";
40*67e74705SXin Li     Target = TargetInfo::CreateTargetInfo(Diags, TargetOpts);
41*67e74705SXin Li   }
42*67e74705SXin Li 
43*67e74705SXin Li   FileSystemOptions FileMgrOpts;
44*67e74705SXin Li   FileManager FileMgr;
45*67e74705SXin Li   IntrusiveRefCntPtr<DiagnosticIDs> DiagID;
46*67e74705SXin Li   DiagnosticsEngine Diags;
47*67e74705SXin Li   SourceManager SourceMgr;
48*67e74705SXin Li   LangOptions LangOpts;
49*67e74705SXin Li   std::shared_ptr<TargetOptions> TargetOpts;
50*67e74705SXin Li   IntrusiveRefCntPtr<TargetInfo> Target;
51*67e74705SXin Li };
52*67e74705SXin Li 
53*67e74705SXin Li class VoidModuleLoader : public ModuleLoader {
loadModule(SourceLocation ImportLoc,ModuleIdPath Path,Module::NameVisibilityKind Visibility,bool IsInclusionDirective)54*67e74705SXin Li   ModuleLoadResult loadModule(SourceLocation ImportLoc,
55*67e74705SXin Li                               ModuleIdPath Path,
56*67e74705SXin Li                               Module::NameVisibilityKind Visibility,
57*67e74705SXin Li                               bool IsInclusionDirective) override {
58*67e74705SXin Li     return ModuleLoadResult();
59*67e74705SXin Li   }
60*67e74705SXin Li 
makeModuleVisible(Module * Mod,Module::NameVisibilityKind Visibility,SourceLocation ImportLoc)61*67e74705SXin Li   void makeModuleVisible(Module *Mod,
62*67e74705SXin Li                          Module::NameVisibilityKind Visibility,
63*67e74705SXin Li                          SourceLocation ImportLoc) override { }
64*67e74705SXin Li 
loadGlobalModuleIndex(SourceLocation TriggerLoc)65*67e74705SXin Li   GlobalModuleIndex *loadGlobalModuleIndex(SourceLocation TriggerLoc) override
66*67e74705SXin Li     { return nullptr; }
lookupMissingImports(StringRef Name,SourceLocation TriggerLoc)67*67e74705SXin Li   bool lookupMissingImports(StringRef Name, SourceLocation TriggerLoc) override
68*67e74705SXin Li     { return 0; }
69*67e74705SXin Li };
70*67e74705SXin Li 
TEST_F(SourceManagerTest,isBeforeInTranslationUnit)71*67e74705SXin Li TEST_F(SourceManagerTest, isBeforeInTranslationUnit) {
72*67e74705SXin Li   const char *source =
73*67e74705SXin Li     "#define M(x) [x]\n"
74*67e74705SXin Li     "M(foo)";
75*67e74705SXin Li   std::unique_ptr<llvm::MemoryBuffer> Buf =
76*67e74705SXin Li       llvm::MemoryBuffer::getMemBuffer(source);
77*67e74705SXin Li   FileID mainFileID = SourceMgr.createFileID(std::move(Buf));
78*67e74705SXin Li   SourceMgr.setMainFileID(mainFileID);
79*67e74705SXin Li 
80*67e74705SXin Li   VoidModuleLoader ModLoader;
81*67e74705SXin Li   HeaderSearch HeaderInfo(new HeaderSearchOptions, SourceMgr, Diags, LangOpts,
82*67e74705SXin Li                           &*Target);
83*67e74705SXin Li   Preprocessor PP(new PreprocessorOptions(), Diags, LangOpts, SourceMgr,
84*67e74705SXin Li                   HeaderInfo, ModLoader,
85*67e74705SXin Li                   /*IILookup =*/nullptr,
86*67e74705SXin Li                   /*OwnsHeaderSearch =*/false);
87*67e74705SXin Li   PP.Initialize(*Target);
88*67e74705SXin Li   PP.EnterMainSourceFile();
89*67e74705SXin Li 
90*67e74705SXin Li   std::vector<Token> toks;
91*67e74705SXin Li   while (1) {
92*67e74705SXin Li     Token tok;
93*67e74705SXin Li     PP.Lex(tok);
94*67e74705SXin Li     if (tok.is(tok::eof))
95*67e74705SXin Li       break;
96*67e74705SXin Li     toks.push_back(tok);
97*67e74705SXin Li   }
98*67e74705SXin Li 
99*67e74705SXin Li   // Make sure we got the tokens that we expected.
100*67e74705SXin Li   ASSERT_EQ(3U, toks.size());
101*67e74705SXin Li   ASSERT_EQ(tok::l_square, toks[0].getKind());
102*67e74705SXin Li   ASSERT_EQ(tok::identifier, toks[1].getKind());
103*67e74705SXin Li   ASSERT_EQ(tok::r_square, toks[2].getKind());
104*67e74705SXin Li 
105*67e74705SXin Li   SourceLocation lsqrLoc = toks[0].getLocation();
106*67e74705SXin Li   SourceLocation idLoc = toks[1].getLocation();
107*67e74705SXin Li   SourceLocation rsqrLoc = toks[2].getLocation();
108*67e74705SXin Li 
109*67e74705SXin Li   SourceLocation macroExpStartLoc = SourceMgr.translateLineCol(mainFileID, 2, 1);
110*67e74705SXin Li   SourceLocation macroExpEndLoc = SourceMgr.translateLineCol(mainFileID, 2, 6);
111*67e74705SXin Li   ASSERT_TRUE(macroExpStartLoc.isFileID());
112*67e74705SXin Li   ASSERT_TRUE(macroExpEndLoc.isFileID());
113*67e74705SXin Li 
114*67e74705SXin Li   SmallString<32> str;
115*67e74705SXin Li   ASSERT_EQ("M", PP.getSpelling(macroExpStartLoc, str));
116*67e74705SXin Li   ASSERT_EQ(")", PP.getSpelling(macroExpEndLoc, str));
117*67e74705SXin Li 
118*67e74705SXin Li   EXPECT_TRUE(SourceMgr.isBeforeInTranslationUnit(lsqrLoc, idLoc));
119*67e74705SXin Li   EXPECT_TRUE(SourceMgr.isBeforeInTranslationUnit(idLoc, rsqrLoc));
120*67e74705SXin Li   EXPECT_TRUE(SourceMgr.isBeforeInTranslationUnit(macroExpStartLoc, idLoc));
121*67e74705SXin Li   EXPECT_TRUE(SourceMgr.isBeforeInTranslationUnit(idLoc, macroExpEndLoc));
122*67e74705SXin Li }
123*67e74705SXin Li 
TEST_F(SourceManagerTest,getColumnNumber)124*67e74705SXin Li TEST_F(SourceManagerTest, getColumnNumber) {
125*67e74705SXin Li   const char *Source =
126*67e74705SXin Li     "int x;\n"
127*67e74705SXin Li     "int y;";
128*67e74705SXin Li 
129*67e74705SXin Li   std::unique_ptr<llvm::MemoryBuffer> Buf =
130*67e74705SXin Li       llvm::MemoryBuffer::getMemBuffer(Source);
131*67e74705SXin Li   FileID MainFileID = SourceMgr.createFileID(std::move(Buf));
132*67e74705SXin Li   SourceMgr.setMainFileID(MainFileID);
133*67e74705SXin Li 
134*67e74705SXin Li   bool Invalid;
135*67e74705SXin Li 
136*67e74705SXin Li   Invalid = false;
137*67e74705SXin Li   EXPECT_EQ(1U, SourceMgr.getColumnNumber(MainFileID, 0, &Invalid));
138*67e74705SXin Li   EXPECT_TRUE(!Invalid);
139*67e74705SXin Li 
140*67e74705SXin Li   Invalid = false;
141*67e74705SXin Li   EXPECT_EQ(5U, SourceMgr.getColumnNumber(MainFileID, 4, &Invalid));
142*67e74705SXin Li   EXPECT_TRUE(!Invalid);
143*67e74705SXin Li 
144*67e74705SXin Li   Invalid = false;
145*67e74705SXin Li   EXPECT_EQ(1U, SourceMgr.getColumnNumber(MainFileID, 7, &Invalid));
146*67e74705SXin Li   EXPECT_TRUE(!Invalid);
147*67e74705SXin Li 
148*67e74705SXin Li   Invalid = false;
149*67e74705SXin Li   EXPECT_EQ(5U, SourceMgr.getColumnNumber(MainFileID, 11, &Invalid));
150*67e74705SXin Li   EXPECT_TRUE(!Invalid);
151*67e74705SXin Li 
152*67e74705SXin Li   Invalid = false;
153*67e74705SXin Li   EXPECT_EQ(7U, SourceMgr.getColumnNumber(MainFileID, strlen(Source),
154*67e74705SXin Li                                          &Invalid));
155*67e74705SXin Li   EXPECT_TRUE(!Invalid);
156*67e74705SXin Li 
157*67e74705SXin Li   Invalid = false;
158*67e74705SXin Li   SourceMgr.getColumnNumber(MainFileID, strlen(Source)+1, &Invalid);
159*67e74705SXin Li   EXPECT_TRUE(Invalid);
160*67e74705SXin Li 
161*67e74705SXin Li   // Test invalid files
162*67e74705SXin Li   Invalid = false;
163*67e74705SXin Li   SourceMgr.getColumnNumber(FileID(), 0, &Invalid);
164*67e74705SXin Li   EXPECT_TRUE(Invalid);
165*67e74705SXin Li 
166*67e74705SXin Li   Invalid = false;
167*67e74705SXin Li   SourceMgr.getColumnNumber(FileID(), 1, &Invalid);
168*67e74705SXin Li   EXPECT_TRUE(Invalid);
169*67e74705SXin Li 
170*67e74705SXin Li   // Test with no invalid flag.
171*67e74705SXin Li   EXPECT_EQ(1U, SourceMgr.getColumnNumber(MainFileID, 0, nullptr));
172*67e74705SXin Li }
173*67e74705SXin Li 
174*67e74705SXin Li #if defined(LLVM_ON_UNIX)
175*67e74705SXin Li 
TEST_F(SourceManagerTest,getMacroArgExpandedLocation)176*67e74705SXin Li TEST_F(SourceManagerTest, getMacroArgExpandedLocation) {
177*67e74705SXin Li   const char *header =
178*67e74705SXin Li     "#define FM(x,y) x\n";
179*67e74705SXin Li 
180*67e74705SXin Li   const char *main =
181*67e74705SXin Li     "#include \"/test-header.h\"\n"
182*67e74705SXin Li     "#define VAL 0\n"
183*67e74705SXin Li     "FM(VAL,0)\n"
184*67e74705SXin Li     "FM(0,VAL)\n"
185*67e74705SXin Li     "FM(FM(0,VAL),0)\n"
186*67e74705SXin Li     "#define CONCAT(X, Y) X##Y\n"
187*67e74705SXin Li     "CONCAT(1,1)\n";
188*67e74705SXin Li 
189*67e74705SXin Li   std::unique_ptr<llvm::MemoryBuffer> HeaderBuf =
190*67e74705SXin Li       llvm::MemoryBuffer::getMemBuffer(header);
191*67e74705SXin Li   std::unique_ptr<llvm::MemoryBuffer> MainBuf =
192*67e74705SXin Li       llvm::MemoryBuffer::getMemBuffer(main);
193*67e74705SXin Li   FileID mainFileID = SourceMgr.createFileID(std::move(MainBuf));
194*67e74705SXin Li   SourceMgr.setMainFileID(mainFileID);
195*67e74705SXin Li 
196*67e74705SXin Li   const FileEntry *headerFile = FileMgr.getVirtualFile("/test-header.h",
197*67e74705SXin Li                                                  HeaderBuf->getBufferSize(), 0);
198*67e74705SXin Li   SourceMgr.overrideFileContents(headerFile, std::move(HeaderBuf));
199*67e74705SXin Li 
200*67e74705SXin Li   VoidModuleLoader ModLoader;
201*67e74705SXin Li   HeaderSearch HeaderInfo(new HeaderSearchOptions, SourceMgr, Diags, LangOpts,
202*67e74705SXin Li                           &*Target);
203*67e74705SXin Li   Preprocessor PP(new PreprocessorOptions(), Diags, LangOpts, SourceMgr,
204*67e74705SXin Li                   HeaderInfo, ModLoader,
205*67e74705SXin Li                   /*IILookup =*/nullptr,
206*67e74705SXin Li                   /*OwnsHeaderSearch =*/false);
207*67e74705SXin Li   PP.Initialize(*Target);
208*67e74705SXin Li   PP.EnterMainSourceFile();
209*67e74705SXin Li 
210*67e74705SXin Li   std::vector<Token> toks;
211*67e74705SXin Li   while (1) {
212*67e74705SXin Li     Token tok;
213*67e74705SXin Li     PP.Lex(tok);
214*67e74705SXin Li     if (tok.is(tok::eof))
215*67e74705SXin Li       break;
216*67e74705SXin Li     toks.push_back(tok);
217*67e74705SXin Li   }
218*67e74705SXin Li 
219*67e74705SXin Li   // Make sure we got the tokens that we expected.
220*67e74705SXin Li   ASSERT_EQ(4U, toks.size());
221*67e74705SXin Li   ASSERT_EQ(tok::numeric_constant, toks[0].getKind());
222*67e74705SXin Li   ASSERT_EQ(tok::numeric_constant, toks[1].getKind());
223*67e74705SXin Li   ASSERT_EQ(tok::numeric_constant, toks[2].getKind());
224*67e74705SXin Li   ASSERT_EQ(tok::numeric_constant, toks[3].getKind());
225*67e74705SXin Li 
226*67e74705SXin Li   SourceLocation defLoc = SourceMgr.translateLineCol(mainFileID, 2, 13);
227*67e74705SXin Li   SourceLocation loc1 = SourceMgr.translateLineCol(mainFileID, 3, 8);
228*67e74705SXin Li   SourceLocation loc2 = SourceMgr.translateLineCol(mainFileID, 4, 4);
229*67e74705SXin Li   SourceLocation loc3 = SourceMgr.translateLineCol(mainFileID, 5, 7);
230*67e74705SXin Li   SourceLocation defLoc2 = SourceMgr.translateLineCol(mainFileID, 6, 22);
231*67e74705SXin Li   defLoc = SourceMgr.getMacroArgExpandedLocation(defLoc);
232*67e74705SXin Li   loc1 = SourceMgr.getMacroArgExpandedLocation(loc1);
233*67e74705SXin Li   loc2 = SourceMgr.getMacroArgExpandedLocation(loc2);
234*67e74705SXin Li   loc3 = SourceMgr.getMacroArgExpandedLocation(loc3);
235*67e74705SXin Li   defLoc2 = SourceMgr.getMacroArgExpandedLocation(defLoc2);
236*67e74705SXin Li 
237*67e74705SXin Li   EXPECT_TRUE(defLoc.isFileID());
238*67e74705SXin Li   EXPECT_TRUE(loc1.isFileID());
239*67e74705SXin Li   EXPECT_TRUE(SourceMgr.isMacroArgExpansion(loc2));
240*67e74705SXin Li   EXPECT_TRUE(SourceMgr.isMacroArgExpansion(loc3));
241*67e74705SXin Li   EXPECT_EQ(loc2, toks[1].getLocation());
242*67e74705SXin Li   EXPECT_EQ(loc3, toks[2].getLocation());
243*67e74705SXin Li   EXPECT_TRUE(defLoc2.isFileID());
244*67e74705SXin Li }
245*67e74705SXin Li 
246*67e74705SXin Li namespace {
247*67e74705SXin Li 
248*67e74705SXin Li struct MacroAction {
249*67e74705SXin Li   SourceLocation Loc;
250*67e74705SXin Li   std::string Name;
251*67e74705SXin Li   bool isDefinition; // if false, it is expansion.
252*67e74705SXin Li 
MacroAction__anon2b82f34b0111::__anon2b82f34b0211::MacroAction253*67e74705SXin Li   MacroAction(SourceLocation Loc, StringRef Name, bool isDefinition)
254*67e74705SXin Li     : Loc(Loc), Name(Name), isDefinition(isDefinition) { }
255*67e74705SXin Li };
256*67e74705SXin Li 
257*67e74705SXin Li class MacroTracker : public PPCallbacks {
258*67e74705SXin Li   std::vector<MacroAction> &Macros;
259*67e74705SXin Li 
260*67e74705SXin Li public:
MacroTracker(std::vector<MacroAction> & Macros)261*67e74705SXin Li   explicit MacroTracker(std::vector<MacroAction> &Macros) : Macros(Macros) { }
262*67e74705SXin Li 
MacroDefined(const Token & MacroNameTok,const MacroDirective * MD)263*67e74705SXin Li   void MacroDefined(const Token &MacroNameTok,
264*67e74705SXin Li                     const MacroDirective *MD) override {
265*67e74705SXin Li     Macros.push_back(MacroAction(MD->getLocation(),
266*67e74705SXin Li                                  MacroNameTok.getIdentifierInfo()->getName(),
267*67e74705SXin Li                                  true));
268*67e74705SXin Li   }
MacroExpands(const Token & MacroNameTok,const MacroDefinition & MD,SourceRange Range,const MacroArgs * Args)269*67e74705SXin Li   void MacroExpands(const Token &MacroNameTok, const MacroDefinition &MD,
270*67e74705SXin Li                     SourceRange Range, const MacroArgs *Args) override {
271*67e74705SXin Li     Macros.push_back(MacroAction(MacroNameTok.getLocation(),
272*67e74705SXin Li                                  MacroNameTok.getIdentifierInfo()->getName(),
273*67e74705SXin Li                                  false));
274*67e74705SXin Li   }
275*67e74705SXin Li };
276*67e74705SXin Li 
277*67e74705SXin Li }
278*67e74705SXin Li 
TEST_F(SourceManagerTest,isBeforeInTranslationUnitWithMacroInInclude)279*67e74705SXin Li TEST_F(SourceManagerTest, isBeforeInTranslationUnitWithMacroInInclude) {
280*67e74705SXin Li   const char *header =
281*67e74705SXin Li     "#define MACRO_IN_INCLUDE 0\n";
282*67e74705SXin Li 
283*67e74705SXin Li   const char *main =
284*67e74705SXin Li     "#define M(x) x\n"
285*67e74705SXin Li     "#define INC \"/test-header.h\"\n"
286*67e74705SXin Li     "#include M(INC)\n"
287*67e74705SXin Li     "#define INC2 </test-header.h>\n"
288*67e74705SXin Li     "#include M(INC2)\n";
289*67e74705SXin Li 
290*67e74705SXin Li   std::unique_ptr<llvm::MemoryBuffer> HeaderBuf =
291*67e74705SXin Li       llvm::MemoryBuffer::getMemBuffer(header);
292*67e74705SXin Li   std::unique_ptr<llvm::MemoryBuffer> MainBuf =
293*67e74705SXin Li       llvm::MemoryBuffer::getMemBuffer(main);
294*67e74705SXin Li   SourceMgr.setMainFileID(SourceMgr.createFileID(std::move(MainBuf)));
295*67e74705SXin Li 
296*67e74705SXin Li   const FileEntry *headerFile = FileMgr.getVirtualFile("/test-header.h",
297*67e74705SXin Li                                                  HeaderBuf->getBufferSize(), 0);
298*67e74705SXin Li   SourceMgr.overrideFileContents(headerFile, std::move(HeaderBuf));
299*67e74705SXin Li 
300*67e74705SXin Li   VoidModuleLoader ModLoader;
301*67e74705SXin Li   HeaderSearch HeaderInfo(new HeaderSearchOptions, SourceMgr, Diags, LangOpts,
302*67e74705SXin Li                           &*Target);
303*67e74705SXin Li   Preprocessor PP(new PreprocessorOptions(), Diags, LangOpts, SourceMgr,
304*67e74705SXin Li                   HeaderInfo, ModLoader,
305*67e74705SXin Li                   /*IILookup =*/nullptr,
306*67e74705SXin Li                   /*OwnsHeaderSearch =*/false);
307*67e74705SXin Li   PP.Initialize(*Target);
308*67e74705SXin Li 
309*67e74705SXin Li   std::vector<MacroAction> Macros;
310*67e74705SXin Li   PP.addPPCallbacks(llvm::make_unique<MacroTracker>(Macros));
311*67e74705SXin Li 
312*67e74705SXin Li   PP.EnterMainSourceFile();
313*67e74705SXin Li 
314*67e74705SXin Li   std::vector<Token> toks;
315*67e74705SXin Li   while (1) {
316*67e74705SXin Li     Token tok;
317*67e74705SXin Li     PP.Lex(tok);
318*67e74705SXin Li     if (tok.is(tok::eof))
319*67e74705SXin Li       break;
320*67e74705SXin Li     toks.push_back(tok);
321*67e74705SXin Li   }
322*67e74705SXin Li 
323*67e74705SXin Li   // Make sure we got the tokens that we expected.
324*67e74705SXin Li   ASSERT_EQ(0U, toks.size());
325*67e74705SXin Li 
326*67e74705SXin Li   ASSERT_EQ(9U, Macros.size());
327*67e74705SXin Li   // #define M(x) x
328*67e74705SXin Li   ASSERT_TRUE(Macros[0].isDefinition);
329*67e74705SXin Li   ASSERT_EQ("M", Macros[0].Name);
330*67e74705SXin Li   // #define INC "/test-header.h"
331*67e74705SXin Li   ASSERT_TRUE(Macros[1].isDefinition);
332*67e74705SXin Li   ASSERT_EQ("INC", Macros[1].Name);
333*67e74705SXin Li   // M expansion in #include M(INC)
334*67e74705SXin Li   ASSERT_FALSE(Macros[2].isDefinition);
335*67e74705SXin Li   ASSERT_EQ("M", Macros[2].Name);
336*67e74705SXin Li   // INC expansion in #include M(INC)
337*67e74705SXin Li   ASSERT_FALSE(Macros[3].isDefinition);
338*67e74705SXin Li   ASSERT_EQ("INC", Macros[3].Name);
339*67e74705SXin Li   // #define MACRO_IN_INCLUDE 0
340*67e74705SXin Li   ASSERT_TRUE(Macros[4].isDefinition);
341*67e74705SXin Li   ASSERT_EQ("MACRO_IN_INCLUDE", Macros[4].Name);
342*67e74705SXin Li   // #define INC2 </test-header.h>
343*67e74705SXin Li   ASSERT_TRUE(Macros[5].isDefinition);
344*67e74705SXin Li   ASSERT_EQ("INC2", Macros[5].Name);
345*67e74705SXin Li   // M expansion in #include M(INC2)
346*67e74705SXin Li   ASSERT_FALSE(Macros[6].isDefinition);
347*67e74705SXin Li   ASSERT_EQ("M", Macros[6].Name);
348*67e74705SXin Li   // INC2 expansion in #include M(INC2)
349*67e74705SXin Li   ASSERT_FALSE(Macros[7].isDefinition);
350*67e74705SXin Li   ASSERT_EQ("INC2", Macros[7].Name);
351*67e74705SXin Li   // #define MACRO_IN_INCLUDE 0
352*67e74705SXin Li   ASSERT_TRUE(Macros[8].isDefinition);
353*67e74705SXin Li   ASSERT_EQ("MACRO_IN_INCLUDE", Macros[8].Name);
354*67e74705SXin Li 
355*67e74705SXin Li   // The INC expansion in #include M(INC) comes before the first
356*67e74705SXin Li   // MACRO_IN_INCLUDE definition of the included file.
357*67e74705SXin Li   EXPECT_TRUE(SourceMgr.isBeforeInTranslationUnit(Macros[3].Loc, Macros[4].Loc));
358*67e74705SXin Li 
359*67e74705SXin Li   // The INC2 expansion in #include M(INC2) comes before the second
360*67e74705SXin Li   // MACRO_IN_INCLUDE definition of the included file.
361*67e74705SXin Li   EXPECT_TRUE(SourceMgr.isBeforeInTranslationUnit(Macros[7].Loc, Macros[8].Loc));
362*67e74705SXin Li }
363*67e74705SXin Li 
364*67e74705SXin Li #endif
365*67e74705SXin Li 
366*67e74705SXin Li } // anonymous namespace
367