file_manager: fix inotify symlink handling
When a symbolic link is created there is no completion event, so immediately fire the notification. Signed-off-by: Eric Callahan <arksine.code@gmail.com>
This commit is contained in:
parent
e33962fdd4
commit
de8c0fc871
|
@ -1249,10 +1249,14 @@ class INotifyHandler:
|
||||||
ext: str = os.path.splitext(evt.name)[-1].lower()
|
ext: str = os.path.splitext(evt.name)[-1].lower()
|
||||||
root = node.get_root()
|
root = node.get_root()
|
||||||
node_path = node.get_path()
|
node_path = node.get_path()
|
||||||
|
file_path = os.path.join(node_path, evt.name)
|
||||||
if evt.mask & iFlags.CREATE:
|
if evt.mask & iFlags.CREATE:
|
||||||
logging.debug(f"Inotify file create: {root}, "
|
logging.debug(f"Inotify file create: {root}, "
|
||||||
f"{node_path}, {evt.name}")
|
f"{node_path}, {evt.name}")
|
||||||
node.schedule_file_event(evt.name, "create_file")
|
node.schedule_file_event(evt.name, "create_file")
|
||||||
|
if os.path.islink(file_path):
|
||||||
|
logging.debug(f"Inotify symlink create: {file_path}")
|
||||||
|
await node.complete_file_write(evt.name)
|
||||||
elif evt.mask & iFlags.DELETE:
|
elif evt.mask & iFlags.DELETE:
|
||||||
logging.debug(f"Inotify file delete: {root}, "
|
logging.debug(f"Inotify file delete: {root}, "
|
||||||
f"{node_path}, {evt.name}")
|
f"{node_path}, {evt.name}")
|
||||||
|
@ -1267,7 +1271,6 @@ class INotifyHandler:
|
||||||
elif evt.mask & iFlags.MOVED_TO:
|
elif evt.mask & iFlags.MOVED_TO:
|
||||||
logging.debug(f"Inotify file move to: {root}, "
|
logging.debug(f"Inotify file move to: {root}, "
|
||||||
f"{node_path}, {evt.name}")
|
f"{node_path}, {evt.name}")
|
||||||
file_path = os.path.join(node_path, evt.name)
|
|
||||||
moved_evt = self.pending_moves.pop(evt.cookie, None)
|
moved_evt = self.pending_moves.pop(evt.cookie, None)
|
||||||
if moved_evt is not None:
|
if moved_evt is not None:
|
||||||
# Moved from a currently watched directory
|
# Moved from a currently watched directory
|
||||||
|
@ -1293,7 +1296,6 @@ class INotifyHandler:
|
||||||
elif evt.mask & iFlags.MODIFY:
|
elif evt.mask & iFlags.MODIFY:
|
||||||
node.schedule_file_event(evt.name, "modify_file")
|
node.schedule_file_event(evt.name, "modify_file")
|
||||||
elif evt.mask & iFlags.CLOSE_WRITE:
|
elif evt.mask & iFlags.CLOSE_WRITE:
|
||||||
file_path = os.path.join(node_path, evt.name)
|
|
||||||
logging.debug(f"Inotify writable file closed: {file_path}")
|
logging.debug(f"Inotify writable file closed: {file_path}")
|
||||||
# Only process files that have been created or modified
|
# Only process files that have been created or modified
|
||||||
await node.complete_file_write(evt.name)
|
await node.complete_file_write(evt.name)
|
||||||
|
|
Loading…
Reference in New Issue