2018-12-23 12:14:25 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2017-09-10 17:25:29 +05:30
|
|
|
module Gitlab
|
|
|
|
module SQL
|
|
|
|
module Glob
|
|
|
|
extend self
|
|
|
|
|
|
|
|
# Convert a simple glob pattern with wildcard (*) to SQL LIKE pattern
|
|
|
|
# with SQL expression
|
|
|
|
def to_like(pattern)
|
|
|
|
<<~SQL
|
|
|
|
REPLACE(REPLACE(REPLACE(#{pattern},
|
|
|
|
#{q('%')}, #{q('\\%')}),
|
|
|
|
#{q('_')}, #{q('\\_')}),
|
|
|
|
#{q('*')}, #{q('%')})
|
|
|
|
SQL
|
|
|
|
end
|
|
|
|
|
|
|
|
def q(string)
|
|
|
|
ActiveRecord::Base.connection.quote(string)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|