class Listen::Change

TODO: rename to Snapshot

Attributes

config[R]
record[R]

Public Class Methods

new(config, record) click to toggle source
# File lib/listen/change.rb, line 25
def initialize(config, record)
  @config = config
  @record = record
end

Public Instance Methods

invalidate(type, rel_path, options) click to toggle source

Invalidate some part of the snapshot/record (dir, file, subtree, etc.)

# File lib/listen/change.rb, line 31
def invalidate(type, rel_path, options)
  watched_dir = Pathname.new(record.root)

  change = options[:change]
  cookie = options[:cookie]

  if !cookie && config.silenced?(rel_path, type)
    Listen::Logger.debug { "(silenced): #{rel_path.inspect}" }
    return
  end

  path = watched_dir + rel_path

  Listen::Logger.debug do
    log_details = options[:silence] && 'recording' || change || 'unknown'
    "#{log_details}: #{type}:#{path} (#{options.inspect})"
  end

  if change
    options = cookie ? { cookie: cookie } : {}
    config.queue(type, change, watched_dir, rel_path, options)
  elsif type == :dir
    # NOTE: POSSIBLE RECURSION
    # TODO: fix - use a queue instead
    Directory.scan(self, rel_path, options)
  else
    change = File.change(record, rel_path)
    return if !change || options[:silence]
    config.queue(:file, change, watched_dir, rel_path)
  end
rescue RuntimeError => ex
  msg = format(
    '%s#%s crashed %s:%s',
    self.class,
    __method__,
    exinspect,
    ex.backtrace * "\n")
  Listen::Logger.error(msg)
  raise
end