Add yardoc to the watcher class.
This commit is contained in:
parent
044100b7c3
commit
dddc2ad369
@ -1,7 +1,18 @@
|
|||||||
module Guard
|
module Guard
|
||||||
|
|
||||||
|
# The watcher defines a RegEx that will be matched against file system modifications.
|
||||||
|
# When a watcher matches a change, an optional action block is executed to enable
|
||||||
|
# processing the file system change result.
|
||||||
|
#
|
||||||
class Watcher
|
class Watcher
|
||||||
|
|
||||||
attr_accessor :pattern, :action
|
attr_accessor :pattern, :action
|
||||||
|
|
||||||
|
# Initialize a file watcher.
|
||||||
|
#
|
||||||
|
# @param [String, Regexp] pattern the pattern to be watched by the guard
|
||||||
|
# @param [Block] action the action to execute before passing the result to the Guard
|
||||||
|
#
|
||||||
def initialize(pattern, action = nil)
|
def initialize(pattern, action = nil)
|
||||||
@pattern, @action = pattern, action
|
@pattern, @action = pattern, action
|
||||||
@@warning_printed ||= false
|
@@warning_printed ||= false
|
||||||
@ -10,14 +21,25 @@ module Guard
|
|||||||
if @pattern.is_a?(String) && @pattern =~ /(^(\^))|(>?(\\\.)|(\.\*))|(\(.*\))|(\[.*\])|(\$$)/
|
if @pattern.is_a?(String) && @pattern =~ /(^(\^))|(>?(\\\.)|(\.\*))|(\(.*\))|(\[.*\])|(\$$)/
|
||||||
unless @@warning_printed
|
unless @@warning_printed
|
||||||
UI.info "*"*20 + "\nDEPRECATION WARNING!\n" + "*"*20
|
UI.info "*"*20 + "\nDEPRECATION WARNING!\n" + "*"*20
|
||||||
UI.info "You have strings in your Guardfile's watch patterns that seem to represent regexps.\nGuard matchs String with == and Regexp with Regexp#match.\nYou should either use plain String (without Regexp special characters) or real Regexp.\n"
|
UI.info <<-MSG
|
||||||
|
You have a string in your Guardfile watch patterns that seem to represent a Regexp.
|
||||||
|
Guard matches String with == and Regexp with Regexp#match.
|
||||||
|
You should either use plain String (without Regexp special characters) or real Regexp.
|
||||||
|
MSG
|
||||||
@@warning_printed = true
|
@@warning_printed = true
|
||||||
end
|
end
|
||||||
UI.info "\"#{@pattern}\" has been converted to #{Regexp.new(@pattern).inspect}\n"
|
|
||||||
|
UI.info "\"#{@pattern}\" has been converted to #{ Regexp.new(@pattern).inspect }\n"
|
||||||
@pattern = Regexp.new(@pattern)
|
@pattern = Regexp.new(@pattern)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# Finds the files that matches a Guard.
|
||||||
|
#
|
||||||
|
# @param [Guard::Guard] guard the guard which watchers are used
|
||||||
|
# @param [Array<String>] files the changed files
|
||||||
|
# @return [Array<String>] the matched files
|
||||||
|
#
|
||||||
def self.match_files(guard, files)
|
def self.match_files(guard, files)
|
||||||
guard.watchers.inject([]) do |paths, watcher|
|
guard.watchers.inject([]) do |paths, watcher|
|
||||||
files.each do |file|
|
files.each do |file|
|
||||||
@ -30,10 +52,17 @@ module Guard
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
paths.flatten.map { |p| p.to_s }
|
paths.flatten.map { |p| p.to_s }
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# Test if a file would be matched by any of the Guards watchers.
|
||||||
|
#
|
||||||
|
# @param [Array<Guard::Guard>] guards the guards to use the watchers from
|
||||||
|
# @param [Array<String>] files the files to test
|
||||||
|
# @return [Boolean] Whether a file matches
|
||||||
|
#
|
||||||
def self.match_files?(guards, files)
|
def self.match_files?(guards, files)
|
||||||
guards.any? do |guard|
|
guards.any? do |guard|
|
||||||
guard.watchers.any? do |watcher|
|
guard.watchers.any? do |watcher|
|
||||||
@ -42,6 +71,11 @@ module Guard
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# Test the watchers pattern against a file.
|
||||||
|
#
|
||||||
|
# @param [String] file the file to test
|
||||||
|
# @return [Boolean] whether the given file is matched
|
||||||
|
#
|
||||||
def match_file?(file)
|
def match_file?(file)
|
||||||
if @pattern.is_a?(Regexp)
|
if @pattern.is_a?(Regexp)
|
||||||
file.match(@pattern)
|
file.match(@pattern)
|
||||||
@ -50,15 +84,25 @@ module Guard
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# Test if any of the files is the Guardfile.
|
||||||
|
#
|
||||||
|
# @param [Array<String>] the files to test
|
||||||
|
# @return [Boolean] whether one of these files is the Guardfile
|
||||||
|
#
|
||||||
def self.match_guardfile?(files)
|
def self.match_guardfile?(files)
|
||||||
files.any? { |file| "#{Dir.pwd}/#{file}" == Dsl.guardfile_path }
|
files.any? { |file| "#{ Dir.pwd }/#{ file }" == Dsl.guardfile_path }
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# Executes a watcher action.
|
||||||
|
#
|
||||||
|
# @param [String, MatchData] the matched path or the match from the Regex
|
||||||
|
# @return [String] the final paths
|
||||||
|
#
|
||||||
def call_action(matches)
|
def call_action(matches)
|
||||||
begin
|
begin
|
||||||
@action.arity > 0 ? @action.call(matches) : @action.call
|
@action.arity > 0 ? @action.call(matches) : @action.call
|
||||||
rescue Exception => e
|
rescue Exception => e
|
||||||
UI.error "Problem with watch action!\n#{e.message}\n\n#{e.backtrace.join("\n")}"
|
UI.error "Problem with watch action!\n#{ e.message }\n\n#{ e.backtrace.join("\n") }"
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user