require 'logger' require 'listen/logger' require 'listen/listener' require 'listen/internals/thread_pool' # Always set up logging by default first time file is required # # NOTE: If you need to clear the logger completely, do so *after* # requiring this file. If you need to set a custom logger, # require the listen/logger file and set the logger before requiring # this file. Listen.setup_default_logger_if_unset # Won't print anything by default because of level - unless you've set # LISTEN_GEM_DEBUGGING or provided your own logger with a high enough level Listen::Logger.info "Listen loglevel set to: #{Listen.logger.level}" Listen::Logger.info "Listen version: #{Listen::VERSION}" module Listen class << self # Listens to file system modifications on a either single directory or # multiple directories. # # @param (see Listen::Listener#new) # # @yield [modified, added, removed] the changed files # @yieldparam [Array] modified the list of modified files # @yieldparam [Array] added the list of added files # @yieldparam [Array] removed the list of removed files # # @return [Listen::Listener] the listener # def to(*args, &block) @listeners ||= [] Listener.new(*args, &block).tap do |listener| @listeners << listener end end # This is used by the `listen` binary to handle Ctrl-C # def stop Internals::ThreadPool.stop @listeners ||= [] # TODO: should use a mutex for this @listeners.each(&:stop) @listeners = nil end end end