summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLin Jen-Shin <godfat@godfat.org>2019-04-03 13:03:38 +0000
committerLin Jen-Shin <godfat@godfat.org>2019-04-03 13:03:38 +0000
commitf4e8f6c89b88990d88d4ce6fddcb1b95a4cc89cd (patch)
treea88a8099105f20063f6f36d17c4e0463567657fa
parent53bf489a0c4d7bf49054eda0f80781c7a0661d09 (diff)
parentac841c37cb667bee637b53d552ce1e71984d7e0a (diff)
downloadgitlab-ce-f4e8f6c89b88990d88d4ce6fddcb1b95a4cc89cd.tar.gz
Merge branch '10864-fix-undefined-with-fallback' into 'master'
Backport: Bring back Gitlab::UntrustedRegexp.with_fallback See merge request gitlab-org/gitlab-ce!26901
-rw-r--r--lib/gitlab/untrusted_regexp.rb13
1 files changed, 13 insertions, 0 deletions
diff --git a/lib/gitlab/untrusted_regexp.rb b/lib/gitlab/untrusted_regexp.rb
index 14126b6ec06..c237f4a7404 100644
--- a/lib/gitlab/untrusted_regexp.rb
+++ b/lib/gitlab/untrusted_regexp.rb
@@ -47,6 +47,19 @@ module Gitlab
self.source == other.source
end
+ # Handles regular expressions with the preferred RE2 library where possible
+ # via UntustedRegex. Falls back to Ruby's built-in regular expression library
+ # when the syntax would be invalid in RE2.
+ #
+ # One difference between these is `(?m)` multi-line mode. Ruby regex enables
+ # this by default, but also handles `^` and `$` differently.
+ # See: https://www.regular-expressions.info/modifiers.html
+ def self.with_fallback(pattern, multiline: false)
+ UntrustedRegexp.new(pattern, multiline: multiline)
+ rescue RegexpError
+ Regexp.new(pattern)
+ end
+
private
attr_reader :regexp