13af6ab5fSopenharmony_ci/** 23af6ab5fSopenharmony_ci * Copyright (c) 2021-2024 Huawei Device Co., Ltd. 33af6ab5fSopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License"); 43af6ab5fSopenharmony_ci * you may not use this file except in compliance with the License. 53af6ab5fSopenharmony_ci * You may obtain a copy of the License at 63af6ab5fSopenharmony_ci * 73af6ab5fSopenharmony_ci * http://www.apache.org/licenses/LICENSE-2.0 83af6ab5fSopenharmony_ci * 93af6ab5fSopenharmony_ci * Unless required by applicable law or agreed to in writing, software 103af6ab5fSopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS, 113af6ab5fSopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 123af6ab5fSopenharmony_ci * See the License for the specific language governing permissions and 133af6ab5fSopenharmony_ci * limitations under the License. 143af6ab5fSopenharmony_ci */ 153af6ab5fSopenharmony_ci 163af6ab5fSopenharmony_ci#ifndef ES2PANDA_PARSER_CORE_KEYWORDS_UTIL_H 173af6ab5fSopenharmony_ci#define ES2PANDA_PARSER_CORE_KEYWORDS_UTIL_H 183af6ab5fSopenharmony_ci 193af6ab5fSopenharmony_ci#include "lexer/keywordString.h" 203af6ab5fSopenharmony_ci#include "lexer/lexer.h" 213af6ab5fSopenharmony_ci#include "lexer/token/letters.h" 223af6ab5fSopenharmony_ci#include "lexer/token/tokenType.h" 233af6ab5fSopenharmony_ci#include "macros.h" 243af6ab5fSopenharmony_ci#include "util/ustring.h" 253af6ab5fSopenharmony_ci#include "utils/span.h" 263af6ab5fSopenharmony_ci 273af6ab5fSopenharmony_cinamespace ark::es2panda::lexer { 283af6ab5fSopenharmony_ciclass Lexer; 293af6ab5fSopenharmony_ciclass Keywords; 303af6ab5fSopenharmony_ci 313af6ab5fSopenharmony_ciclass KeywordsUtil { 323af6ab5fSopenharmony_cipublic: 333af6ab5fSopenharmony_ci explicit KeywordsUtil(Lexer *lexer, lexer::NextTokenFlags flags) : lexer_(lexer), flags_(flags) {} 343af6ab5fSopenharmony_ci explicit KeywordsUtil(Lexer *lexer, lexer::NextTokenFlags flags, char32_t cp) 353af6ab5fSopenharmony_ci : lexer_(lexer), flags_(flags), cp_(cp) 363af6ab5fSopenharmony_ci { 373af6ab5fSopenharmony_ci } 383af6ab5fSopenharmony_ci NO_COPY_SEMANTIC(KeywordsUtil); 393af6ab5fSopenharmony_ci DEFAULT_MOVE_SEMANTIC(KeywordsUtil); 403af6ab5fSopenharmony_ci ~KeywordsUtil() = default; 413af6ab5fSopenharmony_ci 423af6ab5fSopenharmony_ci inline bool HasEscape() const 433af6ab5fSopenharmony_ci { 443af6ab5fSopenharmony_ci return (lexer_->GetToken().flags_ & lexer::TokenFlags::HAS_ESCAPE) != 0; 453af6ab5fSopenharmony_ci } 463af6ab5fSopenharmony_ci 473af6ab5fSopenharmony_ci const parser::ParserContext *GetParserContext() const 483af6ab5fSopenharmony_ci { 493af6ab5fSopenharmony_ci return lexer_->parserContext_; 503af6ab5fSopenharmony_ci } 513af6ab5fSopenharmony_ci 523af6ab5fSopenharmony_ci [[noreturn]] void ThrowError(std::string_view msg) const 533af6ab5fSopenharmony_ci { 543af6ab5fSopenharmony_ci lexer_->ThrowError(msg); 553af6ab5fSopenharmony_ci } 563af6ab5fSopenharmony_ci 573af6ab5fSopenharmony_ci [[noreturn]] void ThrowUnexpectedStrictModeReservedKeyword() const 583af6ab5fSopenharmony_ci { 593af6ab5fSopenharmony_ci lexer_->ThrowUnexpectedStrictModeReservedKeyword(); 603af6ab5fSopenharmony_ci } 613af6ab5fSopenharmony_ci 623af6ab5fSopenharmony_ci inline NextTokenFlags Flags() const 633af6ab5fSopenharmony_ci { 643af6ab5fSopenharmony_ci return flags_; 653af6ab5fSopenharmony_ci } 663af6ab5fSopenharmony_ci 673af6ab5fSopenharmony_ci inline bool KeywordToIdent() const 683af6ab5fSopenharmony_ci { 693af6ab5fSopenharmony_ci return (flags_ & NextTokenFlags::KEYWORD_TO_IDENT) != 0; 703af6ab5fSopenharmony_ci } 713af6ab5fSopenharmony_ci 723af6ab5fSopenharmony_ci inline void CheckEscapedKeyword() const 733af6ab5fSopenharmony_ci { 743af6ab5fSopenharmony_ci if (HasEscape()) { 753af6ab5fSopenharmony_ci ThrowEscapedKeyword(); 763af6ab5fSopenharmony_ci } 773af6ab5fSopenharmony_ci } 783af6ab5fSopenharmony_ci 793af6ab5fSopenharmony_ci inline void ThrowEscapedKeyword() const 803af6ab5fSopenharmony_ci { 813af6ab5fSopenharmony_ci ThrowError("Escape sequences are not allowed in keywords"); 823af6ab5fSopenharmony_ci } 833af6ab5fSopenharmony_ci 843af6ab5fSopenharmony_ci inline void SetKeyword(KeywordString kws) const 853af6ab5fSopenharmony_ci { 863af6ab5fSopenharmony_ci lexer_->GetToken().src_ = util::StringView(kws.Str()); 873af6ab5fSopenharmony_ci lexer_->GetToken().type_ = kws.GetTokenType(); 883af6ab5fSopenharmony_ci lexer_->GetToken().keywordType_ = kws.GetKeywordType(); 893af6ab5fSopenharmony_ci } 903af6ab5fSopenharmony_ci 913af6ab5fSopenharmony_ci inline util::StringView::Iterator &Iterator() 923af6ab5fSopenharmony_ci { 933af6ab5fSopenharmony_ci return lexer_->Iterator(); 943af6ab5fSopenharmony_ci } 953af6ab5fSopenharmony_ci 963af6ab5fSopenharmony_ci void ScanIdentifierStart(const Keywords *kws, char32_t cp); 973af6ab5fSopenharmony_ci void ScanIdContinue(); 983af6ab5fSopenharmony_ci 993af6ab5fSopenharmony_ci void ScanIdContinueMaybeKeyword(const Keywords *kws, Span<const KeywordString> map); 1003af6ab5fSopenharmony_ci char32_t ScanUnicodeEscapeSequence(); 1013af6ab5fSopenharmony_ci 1023af6ab5fSopenharmony_ci static bool IsIdentifierStart(char32_t cp); 1033af6ab5fSopenharmony_ci static bool IsIdentifierPart(char32_t cp); 1043af6ab5fSopenharmony_ci 1053af6ab5fSopenharmony_ciprivate: 1063af6ab5fSopenharmony_ci Lexer *lexer_; 1073af6ab5fSopenharmony_ci NextTokenFlags flags_ {}; 1083af6ab5fSopenharmony_ci char32_t cp_ {util::StringView::Iterator::INVALID_CP}; 1093af6ab5fSopenharmony_ci}; 1103af6ab5fSopenharmony_ci 1113af6ab5fSopenharmony_ci} // namespace ark::es2panda::lexer 1123af6ab5fSopenharmony_ci 1133af6ab5fSopenharmony_ci#endif 114