2018-10-22 03:00:50 -04:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2016-11-08 10:42:28 -05:00
|
|
|
require 'set'
|
|
|
|
|
|
|
|
module Gitlab
|
|
|
|
# Module that can be used to detect if a path points to a special file such as
|
|
|
|
# a README or a CONTRIBUTING file.
|
|
|
|
module FileDetector
|
|
|
|
PATTERNS = {
|
2017-05-17 12:27:30 -04:00
|
|
|
# Project files
|
2018-11-16 06:09:18 -05:00
|
|
|
readme: /\A(#{Regexp.union(*Gitlab::MarkupHelper::PLAIN_FILENAMES).source})(\.(#{Regexp.union(*Gitlab::MarkupHelper::EXTENSIONS).source}))?\z/i,
|
2018-01-27 00:35:53 -05:00
|
|
|
changelog: %r{\A(changelog|history|changes|news)[^/]*\z}i,
|
2018-09-06 08:36:19 -04:00
|
|
|
license: %r{\A((un)?licen[sc]e|copying)(\.[^/]+)?\z}i,
|
2018-01-27 00:35:53 -05:00
|
|
|
contributing: %r{\Acontributing[^/]*\z}i,
|
2016-11-08 10:42:28 -05:00
|
|
|
version: 'version',
|
2017-05-17 12:27:30 -04:00
|
|
|
avatar: /\Alogo\.(png|jpg|gif)\z/,
|
2018-01-27 00:35:53 -05:00
|
|
|
issue_template: %r{\A\.gitlab/issue_templates/[^/]+\.md\z},
|
|
|
|
merge_request_template: %r{\A\.gitlab/merge_request_templates/[^/]+\.md\z},
|
2019-05-01 06:16:03 -04:00
|
|
|
metrics_dashboard: %r{\A\.gitlab/dashboards/[^/]+\.yml\z},
|
2018-05-18 07:01:27 -04:00
|
|
|
xcode_config: %r{\A[^/]*\.(xcodeproj|xcworkspace)(/.+)?\z},
|
2017-05-17 12:27:30 -04:00
|
|
|
|
|
|
|
# Configuration files
|
2016-11-08 10:42:28 -05:00
|
|
|
gitignore: '.gitignore',
|
|
|
|
gitlab_ci: '.gitlab-ci.yml',
|
2017-10-11 11:47:03 -04:00
|
|
|
route_map: '.gitlab/route-map.yml',
|
2017-05-17 12:27:30 -04:00
|
|
|
|
|
|
|
# Dependency files
|
2018-01-27 00:35:53 -05:00
|
|
|
cartfile: %r{\ACartfile[^/]*\z},
|
2017-05-17 12:27:30 -04:00
|
|
|
composer_json: 'composer.json',
|
|
|
|
gemfile: /\A(Gemfile|gems\.rb)\z/,
|
|
|
|
gemfile_lock: 'Gemfile.lock',
|
2018-01-27 00:35:53 -05:00
|
|
|
gemspec: %r{\A[^/]*\.gemspec\z},
|
2017-05-17 12:27:30 -04:00
|
|
|
godeps_json: 'Godeps.json',
|
|
|
|
package_json: 'package.json',
|
|
|
|
podfile: 'Podfile',
|
2018-01-27 00:35:53 -05:00
|
|
|
podspec_json: %r{\A[^/]*\.podspec\.json\z},
|
|
|
|
podspec: %r{\A[^/]*\.podspec\z},
|
|
|
|
requirements_txt: %r{\A[^/]*requirements\.txt\z},
|
2017-05-17 12:27:30 -04:00
|
|
|
yarn_lock: 'yarn.lock'
|
2017-02-21 18:32:18 -05:00
|
|
|
}.freeze
|
2016-11-08 10:42:28 -05:00
|
|
|
|
|
|
|
# Returns an Array of file types based on the given paths.
|
|
|
|
#
|
|
|
|
# This method can be used to check if a list of file paths (e.g. of changed
|
|
|
|
# files) involve any special files such as a README or a LICENSE file.
|
|
|
|
#
|
|
|
|
# Example:
|
|
|
|
#
|
|
|
|
# types_in_paths(%w{README.md foo/bar.txt}) # => [:readme]
|
|
|
|
def self.types_in_paths(paths)
|
|
|
|
types = Set.new
|
|
|
|
|
|
|
|
paths.each do |path|
|
|
|
|
type = type_of(path)
|
|
|
|
|
|
|
|
types << type if type
|
|
|
|
end
|
|
|
|
|
|
|
|
types.to_a
|
|
|
|
end
|
|
|
|
|
|
|
|
# Returns the type of a file path, or nil if none could be detected.
|
|
|
|
#
|
|
|
|
# Returned types are Symbols such as `:readme`, `:version`, etc.
|
|
|
|
#
|
|
|
|
# Example:
|
|
|
|
#
|
|
|
|
# type_of('README.md') # => :readme
|
|
|
|
# type_of('VERSION') # => :version
|
|
|
|
def self.type_of(path)
|
|
|
|
PATTERNS.each do |type, search|
|
|
|
|
did_match = if search.is_a?(Regexp)
|
2017-10-11 11:47:03 -04:00
|
|
|
path =~ search
|
2016-11-08 10:42:28 -05:00
|
|
|
else
|
2017-10-11 11:47:03 -04:00
|
|
|
path.casecmp(search) == 0
|
2016-11-08 10:42:28 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
return type if did_match
|
|
|
|
end
|
|
|
|
|
|
|
|
nil
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|