SyntaxHighlighter.cpp 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  1. /*
  2. * Copyright (c) 2020-2021, Andreas Kling <kling@serenityos.org>
  3. * Copyright (c) 2022, the SerenityOS developers.
  4. *
  5. * SPDX-License-Identifier: BSD-2-Clause
  6. */
  7. #include "SyntaxHighlighter.h"
  8. #include "Lexer.h"
  9. #include <LibGfx/Palette.h>
  10. namespace GUI::GML {
  11. static Syntax::TextStyle style_for_token_type(Gfx::Palette const& palette, Token::Type type)
  12. {
  13. switch (type) {
  14. case Token::Type::LeftCurly:
  15. case Token::Type::RightCurly:
  16. return { palette.syntax_punctuation() };
  17. case Token::Type::ClassMarker:
  18. return { palette.syntax_keyword() };
  19. case Token::Type::ClassName:
  20. return { palette.syntax_identifier(), true };
  21. case Token::Type::Identifier:
  22. return { palette.syntax_identifier() };
  23. case Token::Type::JsonValue:
  24. return { palette.syntax_string() };
  25. case Token::Type::Comment:
  26. return { palette.syntax_comment() };
  27. default:
  28. return { palette.base_text() };
  29. }
  30. }
  31. bool SyntaxHighlighter::is_identifier(u64 token) const
  32. {
  33. auto ini_token = static_cast<Token::Type>(token);
  34. return ini_token == Token::Type::Identifier;
  35. }
  36. void SyntaxHighlighter::rehighlight(Palette const& palette)
  37. {
  38. auto text = m_client->get_text();
  39. Lexer lexer(text);
  40. auto tokens = lexer.lex();
  41. Vector<GUI::TextDocumentSpan> spans;
  42. for (auto& token : tokens) {
  43. GUI::TextDocumentSpan span;
  44. span.range.set_start({ token.m_start.line, token.m_start.column });
  45. span.range.set_end({ token.m_end.line, token.m_end.column });
  46. auto style = style_for_token_type(palette, token.m_type);
  47. span.attributes.color = style.color;
  48. span.attributes.bold = style.bold;
  49. span.is_skippable = false;
  50. span.data = static_cast<u64>(token.m_type);
  51. spans.append(span);
  52. }
  53. m_client->do_set_spans(move(spans));
  54. m_has_brace_buddies = false;
  55. highlight_matching_token_pair();
  56. m_client->do_update();
  57. }
  58. Vector<SyntaxHighlighter::MatchingTokenPair> SyntaxHighlighter::matching_token_pairs_impl() const
  59. {
  60. static Vector<MatchingTokenPair> pairs;
  61. if (pairs.is_empty()) {
  62. pairs.append({ static_cast<u64>(Token::Type::LeftCurly), static_cast<u64>(Token::Type::RightCurly) });
  63. }
  64. return pairs;
  65. }
  66. bool SyntaxHighlighter::token_types_equal(u64 token1, u64 token2) const
  67. {
  68. return static_cast<Token::Type>(token1) == static_cast<Token::Type>(token2);
  69. }
  70. }