13af6ab5fSopenharmony_ci/**
23af6ab5fSopenharmony_ci * Copyright (c) 2021 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 panda::es2panda::lexer {
283af6ab5fSopenharmony_ci
293af6ab5fSopenharmony_ciclass Lexer;
303af6ab5fSopenharmony_ci
313af6ab5fSopenharmony_ciclass KeywordsUtil {
323af6ab5fSopenharmony_cipublic:
333af6ab5fSopenharmony_ci    explicit KeywordsUtil(Lexer *lexer, lexer::LexerNextTokenFlags flags) : lexer_(lexer), flags_(flags) {}
343af6ab5fSopenharmony_ci    explicit KeywordsUtil(Lexer *lexer, lexer::LexerNextTokenFlags 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    template <TokenType keyword_type>
483af6ab5fSopenharmony_ci    inline void SetKeyword(std::string_view str, TokenType type);
493af6ab5fSopenharmony_ci
503af6ab5fSopenharmony_ci    inline util::StringView::Iterator &Iterator()
513af6ab5fSopenharmony_ci    {
523af6ab5fSopenharmony_ci        return lexer_->Iterator();
533af6ab5fSopenharmony_ci    }
543af6ab5fSopenharmony_ci
553af6ab5fSopenharmony_ci    void ScanIdentifierStart(char32_t cp);
563af6ab5fSopenharmony_ci    void ScanIdContinue();
573af6ab5fSopenharmony_ci
583af6ab5fSopenharmony_ci    void ScanIdContinueMaybeKeyword(Span<const KeywordString> map);
593af6ab5fSopenharmony_ci    char32_t ScanUnicodeEscapeSequence();
603af6ab5fSopenharmony_ci
613af6ab5fSopenharmony_ci    static bool IsIdentifierStart(char32_t cp);
623af6ab5fSopenharmony_ci    static bool IsIdentifierPart(char32_t cp);
633af6ab5fSopenharmony_ci
643af6ab5fSopenharmony_ciprivate:
653af6ab5fSopenharmony_ci    Lexer *lexer_;
663af6ab5fSopenharmony_ci    lexer::LexerNextTokenFlags flags_ {};
673af6ab5fSopenharmony_ci    char32_t cp_ {util::StringView::Iterator::INVALID_CP};
683af6ab5fSopenharmony_ci};
693af6ab5fSopenharmony_ci
703af6ab5fSopenharmony_citemplate <TokenType keyword_type>
713af6ab5fSopenharmony_ciinline void KeywordsUtil::SetKeyword(std::string_view str, TokenType type)
723af6ab5fSopenharmony_ci{
733af6ab5fSopenharmony_ci    lexer_->GetToken().src_ = util::StringView(str);
743af6ab5fSopenharmony_ci    // NOLINTNEXTLINE
753af6ab5fSopenharmony_ci    lexer_->GetToken().keywordType_ = keyword_type;
763af6ab5fSopenharmony_ci
773af6ab5fSopenharmony_ci    if (flags_ & lexer::LexerNextTokenFlags::KEYWORD_TO_IDENT) {
783af6ab5fSopenharmony_ci        lexer_->GetToken().type_ = TokenType::LITERAL_IDENT;
793af6ab5fSopenharmony_ci    } else {
803af6ab5fSopenharmony_ci        // NOLINTNEXTLINE
813af6ab5fSopenharmony_ci        lexer_->CheckKeyword<keyword_type>(type, flags_);
823af6ab5fSopenharmony_ci    }
833af6ab5fSopenharmony_ci}
843af6ab5fSopenharmony_ci
853af6ab5fSopenharmony_ci}  // namespace panda::es2panda::lexer
863af6ab5fSopenharmony_ci
873af6ab5fSopenharmony_ci#endif
88