# HG changeset patch # User Shinji KONO # Date 1622642987 -32400 # Node ID cef006dc7fd5c0eba3ee2f58647eae09b9120c44 # Parent af96f86c1b6d70da9957e11b711a2db670002021 CurLexer vanish after EnterMacro finish diff -r af96f86c1b6d -r cef006dc7fd5 clang/include/clang/Lex/Preprocessor.h --- a/clang/include/clang/Lex/Preprocessor.h Wed Jun 02 11:22:01 2021 +0900 +++ b/clang/include/clang/Lex/Preprocessor.h Wed Jun 02 23:09:47 2021 +0900 @@ -2366,7 +2366,7 @@ #ifndef noCbC bool IncludeHeader(Token Tok, const char* Name); - Token ReadFromString(const char *src ) ; + Token ReadFromString(const char *src , SourceLocation Loc) ; unsigned int SavedDepth; Token SavedToken; bool SavedTokenFlag; diff -r af96f86c1b6d -r cef006dc7fd5 clang/lib/Lex/Preprocessor.cpp --- a/clang/lib/Lex/Preprocessor.cpp Wed Jun 02 11:22:01 2021 +0900 +++ b/clang/lib/Lex/Preprocessor.cpp Wed Jun 02 23:09:47 2021 +0900 @@ -1435,17 +1435,20 @@ #ifndef noCbC -Token Preprocessor::ReadFromString(const char *src ) { +Token Preprocessor::ReadFromString(const char *src , SourceLocation Loc) { // Push the ( "string" ) tokens into the token stream. - Token StrTok,Result ; - std::string str(src); - CreateString(str, StrTok); - auto ToksCopy = std::make_unique(1); - ToksCopy[0] = StrTok; - EnterTokenStream(std::move(ToksCopy), 1, - /*DisableMacroExpansion*/ true, - /*IsReinject*/ true); - Lex(Result); + MacroInfo *MI = AllocateMacroInfo(Loc); + Token Tok,FirstTok,Result; + bool Invalid = false; + Lexer lx(CurLexer->getFileID(),getSourceManager().getBuffer(CurLexer->getFileID(), Loc, &Invalid),*this); + lx.InitLexer(src,src,src + strlen(src)); + lx.Lex(Tok); + FirstTok = Tok; + while (Tok.getKind() != tok::TokenKind::eof) { + MI->AddTokenToBody(Tok); + lx.Lex(Tok); + } + EnterMacro(Result, Loc, MI , 0 ); return Result; } diff -r af96f86c1b6d -r cef006dc7fd5 clang/lib/Parse/ParseCbC.cpp --- a/clang/lib/Parse/ParseCbC.cpp Wed Jun 02 11:22:01 2021 +0900 +++ b/clang/lib/Parse/ParseCbC.cpp Wed Jun 02 23:09:47 2021 +0900 @@ -241,11 +241,11 @@ CompoundStmts.push_back(innerRes.get()); // jmp_buf env_buf; --> int env_buf[64]; - Tok = PP.ReadFromString("int env_buf[64];"); - if (Tok.getKind() == tok::TokenKind::eof) ConsumeToken(); + Tok = PP.ReadFromString("int env_buf[64];",Loc); + ConsumeAnyToken(); // innerRes = CreateDeclStmt(bufII, false, false, 64, DeclSpec::TST_typename, CreateIdentifierInfo("int", Loc)); StmtVector Stmts; - innerRes = ParseStatementOrDeclaration(Stmts,ParsedStmtContext::Compound); + innerRes = ParseStatementOrDeclaration(Stmts,( ParsedStmtContext::Compound | ParsedStmtContext::AllowDeclarationsInC)); if (innerRes.isUsable()) CompoundStmts.push_back(innerRes.get());