The INotify file descriptor, it basically does everything related to INotify, from reading to notifying watch points.
Method | __init__ |
No summary |
Method | connection |
Release the inotify file descriptor and do the necessary cleanup |
Method | do |
Read some data from the observed file descriptors |
Method | fileno |
Get the underlying file descriptor from this inotify observer. Required by abstract.FileDescriptor subclasses. |
Method | ignore |
Remove the watch point monitoring the given path |
Method | watch |
Watch the 'mask' events in given path. Can raise INotifyError when there's a problem while adding a directory. |
Instance Variable | connected |
Undocumented |
Method | _add |
This is a very private method, please don't even think about using it. |
Method | _add |
Private helper that abstracts the use of ctypes. |
Method | _do |
Work on the data just read from the file descriptor. |
Method | _is |
Helper function that checks if the path is already monitored and returns its watchdescriptor if so or None otherwise. |
Method | _rm |
Private helper that abstracts the use of ctypes. |
Instance Variable | _buffer |
a bytes containing the data read from the inotify fd. |
Instance Variable | _fd |
Undocumented |
Instance Variable | _watchpaths |
a dict that maps from watched paths to the inotify watch ids |
Instance Variable | _watchpoints |
a dict that maps from inotify watch ids to watchpoints objects |
Instance Variable | _write |
Undocumented |
Inherited from FileDescriptor
:
Method | do |
Called when data can be written. |
Method | get |
Similar to getPeer, but returns an address describing this side of the connection. |
Method | get |
Get the remote address of this connection. |
Method | lose |
Close the connection at the next available opportunity. |
Method | lose |
Undocumented |
Method | pause |
Pause producing data. |
Method | read |
Indicates read connection was lost. |
Method | resume |
Resume producing data. |
Method | start |
Start waiting for read availability. |
Method | start |
Start waiting for write availability. |
Method | stop |
Stop consuming data. |
Method | stop |
Stop producing data. |
Method | stop |
Stop waiting for read availability. |
Method | stop |
Stop waiting for write availability. |
Method | write |
Reliably write some data. |
Method | write |
Indicates write connection was lost. |
Method | write |
Reliably write a sequence of data. |
Method | write |
Write as much as possible of the given data, immediately. |
Constant | SEND |
Undocumented |
Class Variable | buffer |
Undocumented |
Class Variable | disconnecting |
Undocumented |
Instance Variable | data |
Undocumented |
Instance Variable | disconnected |
Undocumented |
Instance Variable | offset |
Undocumented |
Instance Variable | producer |
Undocumented |
Instance Variable | producer |
Undocumented |
Instance Variable | reactor |
Undocumented |
Method | _close |
Undocumented |
Method | _is |
Determine whether the user-space send buffer for this transport is full or not. |
Method | _maybe |
Possibly pause a producer, if there is one and the send buffer is full. |
Method | _post |
Called after a loseConnection(), when all data has been written. |
Instance Variable | _temp |
Undocumented |
Instance Variable | _temp |
Undocumented |
Instance Variable | _write |
Undocumented |
Inherited from _ConsumerMixin
(via FileDescriptor
):
Method | register |
Register to receive data from a producer. |
Method | unregister |
Stop consuming data from a producer, without disconnecting. |
Instance Variable | streaming |
bool or int |
Inherited from _LogOwner
(via FileDescriptor
, _ConsumerMixin
):
Method | log |
Override this method to insert custom logging behavior. Its return value will be inserted in front of every line. It may be called more times than the number of output lines. |
Method | _get |
Determine the log prefix to use for messages related to applicationObject, which may or may not be an interfaces.ILoggingContext provider. |
Parameters | |
reactor | An IReactorFDSet provider which this descriptor will use to get readable and writeable event notifications. If no value is given, the global reactor will be used. |
Get the underlying file descriptor from this inotify observer. Required by abstract.FileDescriptor
subclasses.
Remove the watch point monitoring the given path
Parameters | |
path:FilePath | The path that should be ignored |
Watch the 'mask' events in given path. Can raise INotifyError when there's a problem while adding a directory.
Parameters | |
path:FilePath | The path needing monitoring |
mask:int | The events that should be watched |
autobool | if True automatically add newly created subdirectories |
callbacks:list of callables | A list of callbacks that should be called when an event happens in the given path. The callback should accept 3 arguments: (ignored, filepath, mask) |
recursive:bool | Also add all the subdirectories in this path |
This is a very private method, please don't even think about using it.
Note that this is a fricking hack... it's because we cannot be fast enough in adding a watch to a directory and so we basically end up getting here too late if some operations have already been going on in the subdir, we basically need to catchup. This eventually ends up meaning that we generate double events, your app must be resistant.
Private helper that abstracts the use of ctypes.
Calls the internal inotify API and checks for any errors after the call. If there's an error INotify._addWatch
can raise an INotifyError. If there's no error it proceeds creating a watchpoint and adding a watchpath for inverse lookup of the file descriptor from the path.
Helper function that checks if the path is already monitored and returns its watchdescriptor if so or None otherwise.
Parameters | |
path:FilePath | The path that should be checked |
Private helper that abstracts the use of ctypes.
Calls the internal inotify API to remove an fd from inotify then removes the corresponding watchpoint from the internal mapping together with the file descriptor from the watchpath.