1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40
|
require "guard/group"
module Guard
# @private api
module Internals
class Groups
DEFAULT_GROUPS = [:common, :default]
def initialize
@groups = DEFAULT_GROUPS.map { |name| Group.new(name) }
end
def all(filter = nil)
return @groups if filter.nil?
matcher = matcher_for(filter)
@groups.select { |group| matcher.call(group) }
end
def add(name, options = {})
all(name).first || Group.new(name, options).tap do |group|
fail if name == :specs && options.empty?
@groups << group
end
end
private
def matcher_for(filter)
case filter
when String, Symbol
->(group) { group.name == filter.to_sym }
when Regexp
->(group) { group.name.to_s =~ filter }
else
fail "Invalid filter: #{filter.inspect}"
end
end
end
end
end
|