From aafee295ebb00356c2b1c5a252092d7f5890176c Mon Sep 17 00:00:00 2001 From: Tan Le Date: Thu, 26 Sep 2024 14:46:46 +1000 Subject: [PATCH] Support private property identifier in JS lexer (#2076) --- lib/rouge/lexers/javascript.rb | 6 +++--- spec/visual/samples/javascript | 18 ++++++++++++++++++ 2 files changed, 21 insertions(+), 3 deletions(-) diff --git a/lib/rouge/lexers/javascript.rb b/lib/rouge/lexers/javascript.rb index ce11ad728f..45a11844a2 100644 --- a/lib/rouge/lexers/javascript.rb +++ b/lib/rouge/lexers/javascript.rb @@ -190,8 +190,8 @@ def self.id_regex rule %r/function(?=(\(.*\)))/, Keyword::Declaration # For anonymous functions - rule %r/(#{id})[ \t]*(?=(\(.*\)))/m do |m| - if self.class.keywords.include? m[1] + rule %r/(#?#{id})[ \t]*(?=(\(.*\)))/m do |m| + if self.class.keywords.include?(m[1]) # "if" in "if (...)" or "switch" in "switch (...)" are recognized as keywords. token Keyword else @@ -201,7 +201,7 @@ def self.id_regex rule %r/[{}]/, Punctuation, :statement - rule id do |m| + rule %r/#?#{id}/ do |m| if self.class.keywords.include? m[0] token Keyword push :expr_start diff --git a/spec/visual/samples/javascript b/spec/visual/samples/javascript index e268af82bc..ae77e18311 100644 --- a/spec/visual/samples/javascript +++ b/spec/visual/samples/javascript @@ -297,3 +297,21 @@ ret += "\n"; let baz; baz ??= 'default'; + +class ClassWithPrivate { + #privateField; + #privateFieldWithInitializer = 42; + + #privateMethod(obj) { + if (#privateField in obj) return obj.#privateField; + + return "invalid obj" + } + + static #privateStaticField; + static #privateStaticFieldWithInitializer = 42; + + static #privateStaticMethod() { + // … + } +}