// Copyright (C) 2020-2024 Free Software Foundation, Inc. // This file is part of GCC. // GCC is free software; you can redistribute it and/or modify it under // the terms of the GNU General Public License as published by the Free // Software Foundation; either version 3, or (at your option) any later // version. // GCC is distributed in the hope that it will be useful, but WITHOUT ANY // WARRANTY; without even the implied warranty of MERCHANTABILITY or // FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License // for more details. // You should have received a copy of the GNU General Public License // along with GCC; see the file COPYING3. If not see // . #include "rust-macro-invoc-lexer.h" #include "rust-token.h" namespace Rust { const_TokenPtr MacroInvocLexer::peek_token (int n) { if ((offs + n) >= token_stream.size ()) return Token::make (END_OF_FILE, UNDEF_LOCATION); return token_stream.at (offs + n)->get_tok_ptr (); } void MacroInvocLexer::split_current_token (TokenId new_left, TokenId new_right) { auto ¤t_token = token_stream.at (offs); auto current_pos = token_stream.begin () + offs; auto l_tok = Token::make (new_left, current_token->get_locus ()); auto r_tok = Token::make (new_right, current_token->get_locus ()); token_stream.erase (current_pos); // `insert` inserts before the specified position, so we insert the right one // then the left token_stream.insert (current_pos, std::unique_ptr (new AST::Token (r_tok))); token_stream.insert (current_pos, std::unique_ptr (new AST::Token (l_tok))); } void MacroInvocLexer::split_current_token (std::vector new_tokens) { rust_assert (new_tokens.size () > 0); auto current_pos = token_stream.begin () + offs; token_stream.erase (current_pos); for (size_t i = 1; i < new_tokens.size (); i++) { token_stream.insert (current_pos + i, std::unique_ptr ( new AST::Token (new_tokens[i]))); } } std::vector> MacroInvocLexer::get_token_slice (size_t start_idx, size_t end_idx) const { std::vector> slice; rust_assert (end_idx < token_stream.size ()); for (size_t i = start_idx; i < end_idx; i++) slice.emplace_back (token_stream[i]->clone_token ()); return slice; } } // namespace Rust