Simplify _notify and improve logging.

Signed-off-by: Daira Hopwood <daira@jacaranda.org>
This commit is contained in:
Daira Hopwood 2015-11-03 02:32:41 +00:00
parent 5938535b87
commit 6b4dc3ac4c

View File

@ -143,16 +143,6 @@ class QueueMixin(HookMixin):
print s print s
#open("events", "ab+").write(msg) #open("events", "ab+").write(msg)
def _append_to_deque(self, relpath_u):
self._log("_append_to_deque(%r)" % (relpath_u,))
if relpath_u in self._pending or magicpath.should_ignore_file(relpath_u):
return
self._deque.append(relpath_u)
self._pending.add(relpath_u)
self._count('objects_queued')
if self.is_ready:
self._clock.callLater(0, self._turn_deque)
def _turn_deque(self): def _turn_deque(self):
self._log("_turn_deque") self._log("_turn_deque")
if self._stopped: if self._stopped:
@ -273,6 +263,7 @@ class Uploader(QueueMixin):
def _notify(self, opaque, path, events_mask): def _notify(self, opaque, path, events_mask):
self._log("inotify event %r, %r, %r\n" % (opaque, path, ', '.join(self._inotify.humanReadableMask(events_mask)))) self._log("inotify event %r, %r, %r\n" % (opaque, path, ', '.join(self._inotify.humanReadableMask(events_mask))))
relpath_u = self._get_relpath(path)
# We filter out IN_CREATE events not associated with a directory. # We filter out IN_CREATE events not associated with a directory.
# Acting on IN_CREATE for files could cause us to read and upload # Acting on IN_CREATE for files could cause us to read and upload
@ -283,11 +274,21 @@ class Uploader(QueueMixin):
if ((events_mask & self._inotify.IN_CREATE) != 0 and if ((events_mask & self._inotify.IN_CREATE) != 0 and
(events_mask & self._inotify.IN_ISDIR) == 0): (events_mask & self._inotify.IN_ISDIR) == 0):
self._log("ignoring inotify event for creation of file %r\n" % (path,)) self._log("ignoring event for %r (creation of non-directory)\n" % (relpath_u,))
return
if relpath_u in self._pending:
self._log("ignoring event for %r (already pending)" % (relpath_u,))
return
if magicpath.should_ignore_file(relpath_u):
self._log("ignoring event for %r (ignorable path)" % (relpath_u,))
return return
relpath_u = self._get_relpath(path) self._log("appending %r to deque" % (relpath_u,))
self._append_to_deque(relpath_u) self._deque.append(relpath_u)
self._pending.add(relpath_u)
self._count('objects_queued')
if self.is_ready:
self._clock.callLater(0, self._turn_deque)
def _when_queue_is_empty(self): def _when_queue_is_empty(self):
return defer.succeed(None) return defer.succeed(None)