Struct inotify::WatchMask []

pub struct WatchMask { /* fields omitted */ }

Describes a file system watch

Passed to Inotify::add_watch, to describe what file system events to watch for, and how to do that.

Examples

WatchMask constants can be passed to Inotify::add_watch as is. For example, here's how to create a watch that triggers an event when a file is accessed:

inotify.add_watch("/tmp/inotify-rs-test-file", WatchMask::ACCESS)
   .expect("Error adding watch");

You can also combine multiple WatchMask constants. Here we add a watch this is triggered both when files are created or deleted in a directory:

inotify.add_watch("/tmp/", WatchMask::CREATE | WatchMask::DELETE)
   .expect("Error adding watch");

Methods

impl WatchMask

ACCESS: WatchMask = WatchMask{bits: ffi::IN_ACCESS,}

File was accessed

When watching a directory, this event is only triggered for objects inside the directory, not the directory itself.

See inotify_sys::IN_ACCESS.

ATTRIB: WatchMask = WatchMask{bits: ffi::IN_ATTRIB,}

Metadata (permissions, timestamps, ...) changed

When watching a directory, this event can be triggered for the directory itself, as well as objects inside the directory.

See inotify_sys::IN_ATTRIB.

CLOSE_WRITE: WatchMask = WatchMask{bits: ffi::IN_CLOSE_WRITE,}

File opened for writing was closed

When watching a directory, this event is only triggered for objects inside the directory, not the directory itself.

See inotify_sys::IN_CLOSE_WRITE.

CLOSE_NOWRITE: WatchMask = WatchMask{bits: ffi::IN_CLOSE_NOWRITE,}

File or directory not opened for writing was closed

When watching a directory, this event can be triggered for the directory itself, as well as objects inside the directory.

See inotify_sys::IN_CLOSE_NOWRITE.

CREATE: WatchMask = WatchMask{bits: ffi::IN_CREATE,}

File/directory created in watched directory

When watching a directory, this event is only triggered for objects inside the directory, not the directory itself.

See inotify_sys::IN_CREATE.

DELETE: WatchMask = WatchMask{bits: ffi::IN_DELETE,}

File/directory deleted from watched directory

When watching a directory, this event is only triggered for objects inside the directory, not the directory itself.

See inotify_sys::IN_DELETE.

DELETE_SELF: WatchMask = WatchMask{bits: ffi::IN_DELETE_SELF,}

Watched file/directory was deleted

See inotify_sys::IN_DELETE_SELF.

MODIFY: WatchMask = WatchMask{bits: ffi::IN_MODIFY,}

File was modified

When watching a directory, this event is only triggered for objects inside the directory, not the directory itself.

See inotify_sys::IN_MODIFY.

MOVE_SELF: WatchMask = WatchMask{bits: ffi::IN_MOVE_SELF,}

Watched file/directory was moved

See inotify_sys::IN_MOVE_SELF.

MOVED_FROM: WatchMask = WatchMask{bits: ffi::IN_MOVED_FROM,}

File was renamed/moved; watched directory contained old name

When watching a directory, this event is only triggered for objects inside the directory, not the directory itself.

See inotify_sys::IN_MOVED_FROM.

MOVED_TO: WatchMask = WatchMask{bits: ffi::IN_MOVED_TO,}

File was renamed/moved; watched directory contains new name

When watching a directory, this event is only triggered for objects inside the directory, not the directory itself.

See inotify_sys::IN_MOVED_TO.

OPEN: WatchMask = WatchMask{bits: ffi::IN_OPEN,}

File or directory was opened

When watching a directory, this event can be triggered for the directory itself, as well as objects inside the directory.

See inotify_sys::IN_OPEN.

ALL_EVENTS: WatchMask = WatchMask{bits: ffi::IN_ALL_EVENTS,}

Watch for all events

This constant is simply a convenient combination of the following other constants:

See inotify_sys::IN_ALL_EVENTS.

MOVE: WatchMask = WatchMask{bits: ffi::IN_MOVE,}

Watch for all move events

This constant is simply a convenient combination of the following other constants:

See inotify_sys::IN_MOVE.

CLOSE: WatchMask = WatchMask{bits: ffi::IN_CLOSE,}

Watch for all close events

This constant is simply a convenient combination of the following other constants:

See inotify_sys::IN_CLOSE.

DONT_FOLLOW: WatchMask = WatchMask{bits: ffi::IN_DONT_FOLLOW,}

Don't dereference the path if it is a symbolic link

See inotify_sys::IN_DONT_FOLLOW.

EXCL_UNLINK: WatchMask = WatchMask{bits: ffi::IN_EXCL_UNLINK,}

Filter events for directory entries that have been unlinked

See inotify_sys::IN_EXCL_UNLINK.

MASK_ADD: WatchMask = WatchMask{bits: ffi::IN_MASK_ADD,}

If a watch for the inode exists, amend it instead of replacing it

See inotify_sys::IN_MASK_ADD.

ONESHOT: WatchMask = WatchMask{bits: ffi::IN_ONESHOT,}

Only receive one event, then remove the watch

See inotify_sys::IN_ONESHOT.

ONLYDIR: WatchMask = WatchMask{bits: ffi::IN_ONLYDIR,}

Only watch path, if it is a directory

See inotify_sys::IN_ONLYDIR.

Returns an empty set of flags.

Returns the set containing all flags.

Returns the raw value of the flags currently stored.

Convert from underlying bit representation, unless that representation contains bits that do not correspond to a flag.

Convert from underlying bit representation, dropping any bits that do not correspond to flags.

Returns true if no flags are currently stored.

Returns true if all flags are currently set.

Returns true if there are flags common to both self and other.

Returns true all of the flags in other are contained within self.

Inserts the specified flags in-place.

Removes the specified flags in-place.

Toggles the specified flags in-place.

Inserts or removes the specified flags depending on the passed value.

Trait Implementations

impl Copy for WatchMask

impl PartialEq for WatchMask

This method tests for self and other values to be equal, and is used by ==. Read more

This method tests for !=.

impl Eq for WatchMask

impl Clone for WatchMask

Returns a copy of the value. Read more

1.0.0
[src]

Performs copy-assignment from source. Read more

impl PartialOrd for WatchMask

This method returns an ordering between self and other values if one exists. Read more

This method tests less than (for self and other) and is used by the < operator. Read more

This method tests less than or equal to (for self and other) and is used by the <= operator. Read more

This method tests greater than (for self and other) and is used by the > operator. Read more

This method tests greater than or equal to (for self and other) and is used by the >= operator. Read more

impl Ord for WatchMask

This method returns an Ordering between self and other. Read more

1.22.0
[src]

Compares and returns the maximum of two values. Read more

1.22.0
[src]

Compares and returns the minimum of two values. Read more

impl Hash for WatchMask

Feeds this value into the given [Hasher]. Read more

1.3.0
[src]

Feeds a slice of this type into the given [Hasher]. Read more

impl Debug for WatchMask

Formats the value using the given formatter.

impl Binary for WatchMask

Formats the value using the given formatter.

impl Octal for WatchMask

Formats the value using the given formatter.

impl LowerHex for WatchMask

Formats the value using the given formatter.

impl UpperHex for WatchMask

Formats the value using the given formatter.

impl BitOr for WatchMask

The resulting type after applying the | operator.

Returns the union of the two sets of flags.

impl BitOrAssign for WatchMask

Adds the set of flags.

impl BitXor for WatchMask

The resulting type after applying the ^ operator.

Returns the left flags, but with all the right flags toggled.

impl BitXorAssign for WatchMask

Toggles the set of flags.

impl BitAnd for WatchMask

The resulting type after applying the & operator.

Returns the intersection between the two sets of flags.

impl BitAndAssign for WatchMask

Disables all flags disabled in the set.

impl Sub for WatchMask

The resulting type after applying the - operator.

Returns the set difference of the two sets of flags.

impl SubAssign for WatchMask

Disables all flags enabled in the set.

impl Not for WatchMask

The resulting type after applying the ! operator.

Returns the complement of this set of flags.

impl Extend<WatchMask> for WatchMask

Extends a collection with the contents of an iterator. Read more

impl FromIterator<WatchMask> for WatchMask

Creates a value from an iterator. Read more