instantiation history in an effort to speed up c99-intconst-1.c.
Now that multiple nested instantiations are allowed, we just
make them and don't pay the cost of lookups. With the other
changes that went in before this, reverting this is actually
a speedup for c99-intconst-1.c, speeding it up from 1.96s to 1.80s,
and preserves much better loc info.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@63036
91177308-0d34-0410-b5e6-
96231b3b80d8
Result.push_back(Token());
Token &Tok = Result.back();
PP.Lex(Tok);
-
- // Eagerly resolve instantiation ID's to their spelling location. This
- // makes it so we only have to get the spelling loc once per macro argument
- // preexpansion instead of once per each time the token is expanded.
- if (!Tok.getLocation().isFileID())
- Tok.setLocation(PP.getSourceManager().getSpellingLoc(Tok.getLocation()));
} while (Result.back().isNot(tok::eof));
// Pop the token stream off the top of the stack. We know that the internal
if (MI->isObjectLike()) {
// Object-like macros are very simple, just read their body.
while (Tok.isNot(tok::eom)) {
- // If this token has a virtual location, resolve it down to its spelling
- // location. This is not strictly needed, but avoids extra resolutions
- // for macros that are expanded frequently.
- if (!Tok.getLocation().isFileID())
- Tok.setLocation(SourceMgr.getSpellingLoc(Tok.getLocation()));
-
MI->AddTokenToBody(Tok);
// Get the next token of the macro.
LexUnexpandedToken(Tok);
// Otherwise, read the body of a function-like macro. This has to validate
// the # (stringize) operator.
while (Tok.isNot(tok::eom)) {
- // If this token has a virtual location, resolve it down to its spelling
- // location. This is not strictly needed, but avoids extra resolutions
- // for macros that are expanded frequently.
- if (!Tok.getLocation().isFileID())
- Tok.setLocation(SourceMgr.getSpellingLoc(Tok.getLocation()));
-
MI->AddTokenToBody(Tok);
// Check C99 6.10.3.2p1: ensure that # operators are followed by macro
if (!MI->isEnabled())
Tok.setFlag(Token::DisableExpand);
}
-
- // If this token has instantiation location, resolve it down to its
- // spelling location. This is not strictly needed, but avoids extra
- // resolutions for macros that are expanded frequently.
- if (!Tok.getLocation().isFileID())
- Tok.setLocation(SourceMgr.getSpellingLoc(Tok.getLocation()));
-
ArgTokens.push_back(Tok);
}
Token EOFTok;
EOFTok.startToken();
EOFTok.setKind(tok::eof);
- EOFTok.setLocation(SourceMgr.getSpellingLoc(Tok.getLocation()));
+ EOFTok.setLocation(Tok.getLocation());
EOFTok.setLength(0);
ArgTokens.push_back(EOFTok);
++NumActuals;
CurToken = 0;
InstantiateLoc = Tok.getLocation();
-
- // If the instantiation loc is not already a FileID, resolve it here. If we
- // don't do this, we end up doing it once per token lexed.
- if (!InstantiateLoc.isFileID())
- InstantiateLoc = PP.getSourceManager().getInstantiationLoc(InstantiateLoc);
-
AtStartOfLine = Tok.isAtStartOfLine();
HasLeadingSpace = Tok.hasLeadingSpace();
Tokens = &*Macro->tokens_begin();