Skip to main content

Recursive inotify watches based on inotify_simple.

Project description

Inotify Recursive - Recursive inotify watches for Python

Inotify Recursive is a Python package that offers a simple way to watch a directory-tree recursively for file changes via the inotify functionality of the Linux kernel. It uses the inotify_simple package to set and remove the inotify watches and also incorporates its whole functionality. The package is written in Python and licensed as open-source under the LGPL version 3.

At the moment the main purpose of Inotify Recursive is to provide the file watching functionality for Synoindex Watcher, a small tool that automatically updates the media index of Synology DiskStations.

This Python package is still an alpha! Its core functionality has been tested and is working, but there could still be undiscovered bugs. Also breaking interface changes are likely to happen, so it is not recommended to use it in production projects, yet.

Features

  • Small About 150 lines of code (including comments)
  • Powerful All features of inotify_simple plus recursive watching
  • Agnostic Python 2 and Python 3 compatible (minimum tested version is 2.7)

Installation

The recommended installation method is via pip:

python -m pip install --upgrade inotifyrecursive

You can use the same command to upgrade Inotify Recursive from an older version.

This will also install its dependency inotify_simple.

Documentation

Please read the docs for inotify_simple first, since the basic usage is the same.

The INotify class of Inotify Recursive provides three additional methods, which are useful, if a directory shall be watched recursively:

inotify.add_watch_recursive(path, mask, filter = None)

  • path The path to watch
  • mask The mask of events to watch for
  • filter A function to ignore certain sub-directories

Returns the descriptor for the newly created watch of the directory where the given path points to. Unlike add_watch() this function also creates watches for all sub-directories below it. The descriptors of the sub-watches are not returned.

The filter function is optional. It takes the name of the file or directory and the descriptor of the watcher of the parent directory. The filter returns a boolean value, which describes whether the directory shall be watched (True) or ignored (False). If no filter is set, all files and sub-directories will be watched.

inotify.rm_watch_recursive(wd)

  • wd The watch descriptor to remove

Removes the watch with the given descriptor and all associated sub-watches. Should be used for any watch that has been created by add_watch_recursive().

inotify.get_path(wd)

  • wd The watch descriptor the path is fetched for

Returns the absolute path of the directory associated to the watch with given descriptor.


Copyright 2019,2020 Torben Haase <https://pixelsvsbytes.com>

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

inotifyrecursive-0.3.5.tar.gz (4.6 kB view details)

Uploaded Source

Built Distribution

inotifyrecursive-0.3.5-py3-none-any.whl (8.0 kB view details)

Uploaded Python 3

File details

Details for the file inotifyrecursive-0.3.5.tar.gz.

File metadata

  • Download URL: inotifyrecursive-0.3.5.tar.gz
  • Upload date:
  • Size: 4.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.6.1 requests/2.24.0 setuptools/50.3.2 requests-toolbelt/0.9.1 tqdm/4.51.0 CPython/3.8.6

File hashes

Hashes for inotifyrecursive-0.3.5.tar.gz
Algorithm Hash digest
SHA256 a2c450b317693e4538416f90eb1d7858506dafe6b8b885037bd2dd9ae2dafa1e
MD5 d6c990e0c22ce3e5c4213094b00ec147
BLAKE2b-256 193a9ed038cb750a3ba8090869cf3ad50f5628077a936d911aee14ca83e40f6a

See more details on using hashes here.

File details

Details for the file inotifyrecursive-0.3.5-py3-none-any.whl.

File metadata

  • Download URL: inotifyrecursive-0.3.5-py3-none-any.whl
  • Upload date:
  • Size: 8.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.6.1 requests/2.24.0 setuptools/50.3.2 requests-toolbelt/0.9.1 tqdm/4.51.0 CPython/3.8.6

File hashes

Hashes for inotifyrecursive-0.3.5-py3-none-any.whl
Algorithm Hash digest
SHA256 7e5f4a2e1dc2bef0efa3b5f6b339c41fb4599055a2b54909d020e9e932cc8d2f
MD5 c9a817259303896aea71461a51d9466f
BLAKE2b-256 c7fc4e5a141c3f7c7bed550ac1f69e599e92b6be449dd4677ec09f325cad0955

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page