Welcome to mirror list, hosted at ThFree Co, Russian Federation.

gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGitLab Bot <gitlab-bot@gitlab.com>2020-08-17 21:10:01 +0300
committerGitLab Bot <gitlab-bot@gitlab.com>2020-08-17 21:10:01 +0300
commit18da92341dac366b7bcfd13f2d3c443ffa315af0 (patch)
tree5189d9098a95d03d0b2b056f318a3637d9f547a7 /lib/gitlab/search
parent073ebdcae8630bbcc849f7cfb4c27fd81bef99a5 (diff)
Add latest changes from gitlab-org/gitlab@master
Diffstat (limited to 'lib/gitlab/search')
-rw-r--r--lib/gitlab/search/parsed_query.rb45
-rw-r--r--lib/gitlab/search/query.rb8
2 files changed, 45 insertions, 8 deletions
diff --git a/lib/gitlab/search/parsed_query.rb b/lib/gitlab/search/parsed_query.rb
index 1f6e0519b4c..5d5d407c172 100644
--- a/lib/gitlab/search/parsed_query.rb
+++ b/lib/gitlab/search/parsed_query.rb
@@ -3,6 +3,8 @@
module Gitlab
module Search
class ParsedQuery
+ include Gitlab::Utils::StrongMemoize
+
attr_reader :term, :filters
def initialize(term, filters)
@@ -11,13 +13,44 @@ module Gitlab
end
def filter_results(results)
- filters = @filters.reject { |filter| filter[:matcher].nil? }
- return unless filters
+ with_matcher = ->(filter) { filter[:matcher].present? }
+
+ excluding = excluding_filters.select(&with_matcher)
+ including = including_filters.select(&with_matcher)
+
+ return unless excluding.any? || including.any?
+
+ results.select! do |result|
+ including.all? { |filter| filter[:matcher].call(filter, result) }
+ end
+
+ results.reject! do |result|
+ excluding.any? { |filter| filter[:matcher].call(filter, result) }
+ end
+
+ results
+ end
+
+ private
+
+ def including_filters
+ processed_filters(:including)
+ end
+
+ def excluding_filters
+ processed_filters(:excluding)
+ end
+
+ def processed_filters(type)
+ excluding, including = strong_memoize(:processed_filters) do
+ filters.partition { |filter| filter[:negated] }
+ end
- results.select do |result|
- filters.all? do |filter|
- filter[:matcher].call(filter, result)
- end
+ case type
+ when :including then including
+ when :excluding then excluding
+ else
+ raise ArgumentError.new(type)
end
end
end
diff --git a/lib/gitlab/search/query.rb b/lib/gitlab/search/query.rb
index ba0e16607a6..27ea0b7367f 100644
--- a/lib/gitlab/search/query.rb
+++ b/lib/gitlab/search/query.rb
@@ -20,7 +20,10 @@ module Gitlab
private
def filter(name, **attributes)
- filter = { parser: @filter_options[:default_parser], name: name }.merge(attributes)
+ filter = {
+ parser: @filter_options[:default_parser],
+ name: name
+ }.merge(attributes)
@filters << filter
end
@@ -33,12 +36,13 @@ module Gitlab
fragments = []
filters = @filters.each_with_object([]) do |filter, parsed_filters|
- match = @raw_query.split.find { |part| part =~ /\A#{filter[:name]}:/ }
+ match = @raw_query.split.find { |part| part =~ /\A-?#{filter[:name]}:/ }
next unless match
input = match.split(':')[1..-1].join
next if input.empty?
+ filter[:negated] = match.start_with?("-")
filter[:value] = parse_filter(filter, input)
filter[:regex_value] = Regexp.escape(filter[:value]).gsub('\*', '.*?')
fragments << match