From: Pierre-Emmanuel Patry Date: Wed, 8 Nov 2023 13:54:51 +0000 (+0100) Subject: gccrs: Change keyword set to a map X-Git-Tag: basepoints/gcc-15~1999 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=e50b0969b8eb69afd5432fc4aee1434974275067;p=thirdparty%2Fgcc.git gccrs: Change keyword set to a map Some part of the code requires the token id behind a given keyword, a map keep the "set" aspect whilst providing this additional feature. gcc/rust/ChangeLog: * lex/rust-lex.cc (RS_TOKEN): Remove local map. (RS_TOKEN_KEYWORD): Likewise. (Lexer::classify_keyword): Change call to utils. * util/rust-keyword-values.cc (get_keywords): Add init function. (RS_TOKEN_KEYWORD): Call to X macro. * util/rust-keyword-values.h: Change from set to a map. Signed-off-by: Pierre-Emmanuel Patry --- diff --git a/gcc/rust/lex/rust-lex.cc b/gcc/rust/lex/rust-lex.cc index 2cfc9cec5d41..cab2abbba5af 100644 --- a/gcc/rust/lex/rust-lex.cc +++ b/gcc/rust/lex/rust-lex.cc @@ -24,6 +24,7 @@ #include "rust-session-manager.h" #include "safe-ctype.h" #include "cpplib.h" +#include "rust-keyword-values.h" namespace Rust { // TODO: move to separate compilation unit? @@ -254,25 +255,12 @@ Lexer::replace_current_token (TokenPtr replacement) rust_debug ("called 'replace_current_token' - this is deprecated"); } -/* shitty anonymous namespace that can only be accessed inside the compilation - * unit - used for classify_keyword binary search in sorted array of keywords - * created with x-macros. */ -namespace { -// TODO: make constexpr when update to c++20 -const std::map keywords = { -#define RS_TOKEN(x, y) -#define RS_TOKEN_KEYWORD(tok, key) {key, tok}, - RS_TOKEN_LIST -#undef RS_TOKEN_KEYWORD -#undef RS_TOKEN -}; -} // namespace - /* Determines whether the string passed in is a keyword or not. If it is, it * returns the keyword name. */ TokenId Lexer::classify_keyword (const std::string &str) { + auto &keywords = Rust::Values::Keywords::keywords; auto keyword = keywords.find (str); if (keyword == keywords.end ()) diff --git a/gcc/rust/util/rust-keyword-values.cc b/gcc/rust/util/rust-keyword-values.cc index 29bc65eba766..58a404dc2aae 100644 --- a/gcc/rust/util/rust-keyword-values.cc +++ b/gcc/rust/util/rust-keyword-values.cc @@ -17,17 +17,26 @@ // . #include "rust-keyword-values.h" +#include "rust-token.h" namespace Rust { namespace Values { -const std::set Keywords::keywords = { +// TODO: Can't we do this inline ? +static std::map +get_keywords () +{ + std::map m = { #define RS_TOKEN(x, y) -#define RS_TOKEN_KEYWORD(tok, key) key, - RS_TOKEN_LIST +#define RS_TOKEN_KEYWORD(tok, key) {key, tok}, + RS_TOKEN_LIST #undef RS_TOKEN_KEYWORD #undef RS_TOKEN -}; + }; + return m; +} + +const std::map Keywords::keywords = get_keywords (); } // namespace Values } // namespace Rust diff --git a/gcc/rust/util/rust-keyword-values.h b/gcc/rust/util/rust-keyword-values.h index cf507909d204..3edae55c76eb 100644 --- a/gcc/rust/util/rust-keyword-values.h +++ b/gcc/rust/util/rust-keyword-values.h @@ -28,7 +28,7 @@ namespace Values { class Keywords { public: - const static std::set keywords; + const static std::map keywords; // Rust keyword values public: