# HG changeset patch # User Shinji KONO # Date 1622805269 -32400 # Node ID 40b1cab184376c812c0a6f41d76d0a11e7693814 # Parent 5784c86f13b3e9cc6dc05ae6a637986e7481f39d swap CurLexer diff -r 5784c86f13b3 -r 40b1cab18437 clang/lib/Lex/PPLexerChange.cpp --- a/clang/lib/Lex/PPLexerChange.cpp Thu Jun 03 00:48:49 2021 +0900 +++ b/clang/lib/Lex/PPLexerChange.cpp Fri Jun 04 20:14:29 2021 +0900 @@ -471,20 +471,20 @@ } #ifndef noCbC - if (SavedTokenFlag && IncludeMacroStack.size() == SavedDepth){ + if (SavedTokenFlag && IncludeMacroStack.size() == SavedDepth){ // dead code? Result = SavedToken; SavedTokenFlag = false; - if (CurLexer->ParsingPreprocessorDirective) { - // Done parsing the "line". - CurLexer->ParsingPreprocessorDirective = false; + if (CurLexer->ParsingPreprocessorDirective) { + // Done parsing the "line". + CurLexer->ParsingPreprocessorDirective = false; - // Restore comment saving mode, in case it was disabled for directive. - CurLexer->resetExtendedTokenMode(); + // Restore comment saving mode, in case it was disabled for directive. + CurLexer->resetExtendedTokenMode(); - // Since we consumed a newline, we are back at the start of a line. - CurLexer->IsAtStartOfLine = true; - CurLexer->IsAtPhysicalStartOfLine = true; - } + // Since we consumed a newline, we are back at the start of a line. + CurLexer->IsAtStartOfLine = true; + CurLexer->IsAtPhysicalStartOfLine = true; + } return true; } #endif diff -r 5784c86f13b3 -r 40b1cab18437 clang/lib/Lex/Preprocessor.cpp --- a/clang/lib/Lex/Preprocessor.cpp Thu Jun 03 00:48:49 2021 +0900 +++ b/clang/lib/Lex/Preprocessor.cpp Fri Jun 04 20:14:29 2021 +0900 @@ -1440,15 +1440,17 @@ 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.ParsingPreprocessorDirective = true ; // to prevent from EOF sucide of CurLexer in PP - lx.Lex(Tok); + std::unique_ptr lx(new Lexer(CurLexer->getFileID(),getSourceManager().getBuffer(CurLexer->getFileID(), Loc, &Invalid),*this)); + lx->InitLexer(src,src,src + strlen(src)); + // lx.ParsingPreprocessorDirective = true ; // to prevent from EOF sucide of CurLexer in PP + lx->Lex(Tok); FirstTok = Tok; + CurLexer.swap(lx); while (Tok.getKind() != tok::TokenKind::eof) { MI->AddTokenToBody(Tok); - lx.Lex(Tok); + Lex(Tok); } + CurLexer = std::move(lx); EnterMacro(Result, Loc, MI , 0 ); // EnterTokenStream(&MI->ReplacementTokens,MI->getNumTokens(),true,true,false); return Result; diff -r 5784c86f13b3 -r 40b1cab18437 clang/lib/Parse/ParseCbC.cpp --- a/clang/lib/Parse/ParseCbC.cpp Thu Jun 03 00:48:49 2021 +0900 +++ b/clang/lib/Parse/ParseCbC.cpp Fri Jun 04 20:14:29 2021 +0900 @@ -241,7 +241,7 @@ CompoundStmts.push_back(innerRes.get()); // jmp_buf env_buf; --> int env_buf[64]; - Tok = PP.ReadFromString("int env_buf[64];;",Loc); + Tok = PP.ReadFromString("int env_buf[64];",Loc); ConsumeAnyToken(); // innerRes = CreateDeclStmt(bufII, false, false, 64, DeclSpec::TST_typename, CreateIdentifierInfo("int", Loc)); StmtVector Stmts;