mirror of
https://github.com/glitch-soc/mastodon.git
synced 2026-03-29 03:00:33 +02:00
Fix hashtags preceded by non-break spaces not being processed as such (#38212)
This commit is contained in:
@@ -41,7 +41,7 @@ class Tag < ApplicationRecord
|
||||
HASHTAG_LAST_SEQUENCE = '([[:word:]_]*[[:alpha:]][[:word:]_]*)'
|
||||
HASHTAG_NAME_PAT = "#{HASHTAG_FIRST_SEQUENCE}|#{HASHTAG_LAST_SEQUENCE}".freeze
|
||||
|
||||
HASHTAG_RE = /(?<=^|\s)[##](#{HASHTAG_NAME_PAT})/
|
||||
HASHTAG_RE = /(?<=^|[[:space:]])[##](#{HASHTAG_NAME_PAT})/
|
||||
HASHTAG_NAME_RE = /\A(#{HASHTAG_NAME_PAT})\z/i
|
||||
HASHTAG_INVALID_CHARS_RE = /[^[:alnum:]\u0E47-\u0E4E#{HASHTAG_SEPARATORS}]/
|
||||
|
||||
|
||||
@@ -103,6 +103,10 @@ RSpec.describe Tag do
|
||||
expect(subject.match('https://en.wikipedia.org/wiki/Google_LLC_v._Oracle_America,_Inc.#Decision')).to be_nil
|
||||
end
|
||||
|
||||
it 'matches a hashtag preceded by a non-break space' do
|
||||
expect(subject.match('test #foo').to_s).to eq '#foo'
|
||||
end
|
||||
|
||||
it 'matches #aesthetic' do
|
||||
expect(subject.match('this is #aesthetic').to_s).to eq '#aesthetic'
|
||||
end
|
||||
|
||||
Reference in New Issue
Block a user