summaryrefslogtreecommitdiffstats
path: root/templates/man7/inotify.7.pot
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--templates/man7/inotify.7.pot2109
1 files changed, 2109 insertions, 0 deletions
diff --git a/templates/man7/inotify.7.pot b/templates/man7/inotify.7.pot
new file mode 100644
index 00000000..9c1a84d5
--- /dev/null
+++ b/templates/man7/inotify.7.pot
@@ -0,0 +1,2109 @@
+# SOME DESCRIPTIVE TITLE
+# Copyright (C) YEAR Free Software Foundation, Inc.
+# This file is distributed under the same license as the PACKAGE package.
+# FIRST AUTHOR <EMAIL@ADDRESS>, YEAR.
+#
+#, fuzzy
+msgid ""
+msgstr ""
+"Project-Id-Version: PACKAGE VERSION\n"
+"POT-Creation-Date: 2024-03-01 16:58+0100\n"
+"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
+"Last-Translator: FULL NAME <EMAIL@ADDRESS>\n"
+"Language-Team: LANGUAGE <LL@li.org>\n"
+"Language: \n"
+"MIME-Version: 1.0\n"
+"Content-Type: text/plain; charset=UTF-8\n"
+"Content-Transfer-Encoding: 8bit\n"
+
+#. type: TH
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "inotify"
+msgstr ""
+
+#. type: TH
+#: archlinux fedora-40 fedora-rawhide mageia-cauldron
+#, no-wrap
+msgid "2023-10-31"
+msgstr ""
+
+#. type: TH
+#: archlinux fedora-40 fedora-rawhide mageia-cauldron
+#, no-wrap
+msgid "Linux man-pages 6.06"
+msgstr ""
+
+#. type: SH
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "NAME"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid "inotify - monitoring filesystem events"
+msgstr ""
+
+#. type: SH
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "DESCRIPTION"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"The I<inotify> API provides a mechanism for monitoring filesystem events. "
+"Inotify can be used to monitor individual files, or to monitor directories. "
+"When a directory is monitored, inotify will return events for the directory "
+"itself, and for files inside the directory."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid "The following system calls are used with this API:"
+msgstr ""
+
+#. type: IP
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "\\[bu]"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"B<inotify_init>(2) creates an inotify instance and returns a file "
+"descriptor referring to the inotify instance. The more recent "
+"B<inotify_init1>(2) is like B<inotify_init>(2), but has a I<flags> argument "
+"that provides access to some extra functionality."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"B<inotify_add_watch>(2) manipulates the \"watch list\" associated with an "
+"inotify instance. Each item (\"watch\") in the watch list specifies the "
+"pathname of a file or directory, along with some set of events that the "
+"kernel should monitor for the file referred to by that pathname. "
+"B<inotify_add_watch>(2) either creates a new watch item, or modifies an "
+"existing watch. Each watch has a unique \"watch descriptor\", an integer "
+"returned by B<inotify_add_watch>(2) when the watch is created."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"When events occur for monitored files and directories, those events are made "
+"available to the application as structured data that can be read from the "
+"inotify file descriptor using B<read>(2) (see below)."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid "B<inotify_rm_watch>(2) removes an item from an inotify watch list."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"When all file descriptors referring to an inotify instance have been closed "
+"(using B<close>(2)), the underlying object and its resources are freed for "
+"reuse by the kernel; all associated watches are automatically freed."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"With careful programming, an application can use inotify to efficiently "
+"monitor and cache the state of a set of filesystem objects. However, robust "
+"applications should allow for the fact that bugs in the monitoring logic or "
+"races of the kind described below may leave the cache inconsistent with the "
+"filesystem state. It is probably wise to do some consistency checking, and "
+"rebuild the cache when inconsistencies are detected."
+msgstr ""
+
+#. type: SS
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "Reading events from an inotify file descriptor"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"To determine what events have occurred, an application B<read>(2)s from the "
+"inotify file descriptor. If no events have so far occurred, then, assuming "
+"a blocking file descriptor, B<read>(2) will block until at least one event "
+"occurs (unless interrupted by a signal, in which case the call fails with "
+"the error B<EINTR>; see B<signal>(7))."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"Each successful B<read>(2) returns a buffer containing one or more of the "
+"following structures:"
+msgstr ""
+
+#. #-#-#-#-# archlinux: inotify.7.pot (PACKAGE VERSION) #-#-#-#-#
+#. FIXME . The type of the 'wd' field should probably be "int32_t".
+#. I submitted a patch to fix this. See the LKML thread
+#. "[patch] Fix type errors in inotify interfaces", 18 Nov 2008
+#. glibc bug filed: https://www.sourceware.org/bugzilla/show_bug.cgi?id=7040
+#. type: Plain text
+#. #-#-#-#-# debian-bookworm: inotify.7.pot (PACKAGE VERSION) #-#-#-#-#
+#. FIXME . The type of the 'wd' field should probably be "int32_t".
+#. I submitted a patch to fix this. See the LKML thread
+#. "[patch] Fix type errors in inotify interfaces", 18 Nov 2008
+#. glibc bug filed: http://sources.redhat.com/bugzilla/show_bug.cgi?id=7040
+#. type: Plain text
+#. #-#-#-#-# debian-unstable: inotify.7.pot (PACKAGE VERSION) #-#-#-#-#
+#. FIXME . The type of the 'wd' field should probably be "int32_t".
+#. I submitted a patch to fix this. See the LKML thread
+#. "[patch] Fix type errors in inotify interfaces", 18 Nov 2008
+#. glibc bug filed: https://www.sourceware.org/bugzilla/show_bug.cgi?id=7040
+#. type: Plain text
+#. #-#-#-#-# fedora-40: inotify.7.pot (PACKAGE VERSION) #-#-#-#-#
+#. FIXME . The type of the 'wd' field should probably be "int32_t".
+#. I submitted a patch to fix this. See the LKML thread
+#. "[patch] Fix type errors in inotify interfaces", 18 Nov 2008
+#. glibc bug filed: https://www.sourceware.org/bugzilla/show_bug.cgi?id=7040
+#. type: Plain text
+#. #-#-#-#-# fedora-rawhide: inotify.7.pot (PACKAGE VERSION) #-#-#-#-#
+#. FIXME . The type of the 'wd' field should probably be "int32_t".
+#. I submitted a patch to fix this. See the LKML thread
+#. "[patch] Fix type errors in inotify interfaces", 18 Nov 2008
+#. glibc bug filed: https://www.sourceware.org/bugzilla/show_bug.cgi?id=7040
+#. type: Plain text
+#. #-#-#-#-# mageia-cauldron: inotify.7.pot (PACKAGE VERSION) #-#-#-#-#
+#. FIXME . The type of the 'wd' field should probably be "int32_t".
+#. I submitted a patch to fix this. See the LKML thread
+#. "[patch] Fix type errors in inotify interfaces", 18 Nov 2008
+#. glibc bug filed: https://www.sourceware.org/bugzilla/show_bug.cgi?id=7040
+#. type: Plain text
+#. #-#-#-#-# opensuse-leap-15-6: inotify.7.pot (PACKAGE VERSION) #-#-#-#-#
+#. FIXME . The type of the 'wd' field should probably be "int32_t".
+#. I submitted a patch to fix this. See the LKML thread
+#. "[patch] Fix type errors in inotify interfaces", 18 Nov 2008
+#. glibc bug filed: https://www.sourceware.org/bugzilla/show_bug.cgi?id=7040
+#. type: Plain text
+#. #-#-#-#-# opensuse-tumbleweed: inotify.7.pot (PACKAGE VERSION) #-#-#-#-#
+#. FIXME . The type of the 'wd' field should probably be "int32_t".
+#. I submitted a patch to fix this. See the LKML thread
+#. "[patch] Fix type errors in inotify interfaces", 18 Nov 2008
+#. glibc bug filed: https://www.sourceware.org/bugzilla/show_bug.cgi?id=7040
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid ""
+"struct inotify_event {\n"
+" int wd; /* Watch descriptor */\n"
+" uint32_t mask; /* Mask describing event */\n"
+" uint32_t cookie; /* Unique cookie associating related\n"
+" events (for rename(2)) */\n"
+" uint32_t len; /* Size of I<name> field */\n"
+" char name[]; /* Optional null-terminated name */\n"
+"};\n"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"I<wd> identifies the watch for which this event occurs. It is one of the "
+"watch descriptors returned by a previous call to B<inotify_add_watch>(2)."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"I<mask> contains bits that describe the event that occurred (see below)."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"I<cookie> is a unique integer that connects related events. Currently, this "
+"is used only for rename events, and allows the resulting pair of "
+"B<IN_MOVED_FROM> and B<IN_MOVED_TO> events to be connected by the "
+"application. For all other event types, I<cookie> is set to 0."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-unstable fedora-40 fedora-rawhide mageia-cauldron
+#: opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"The I<name> field is present only when an event is returned for a file "
+"inside a watched directory; it identifies the filename within the watched "
+"directory. This filename is null-terminated, and may include further null "
+"bytes (\\[aq]\\e0\\[aq]) to align subsequent reads to a suitable address "
+"boundary."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"The I<len> field counts all of the bytes in I<name>, including the null "
+"bytes; the length of each I<inotify_event> structure is thus I<sizeof(struct "
+"inotify_event)+len>."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"The behavior when the buffer given to B<read>(2) is too small to return "
+"information about the next event depends on the kernel version: before Linux "
+"2.6.21, B<read>(2) returns 0; since Linux 2.6.21, B<read>(2) fails with "
+"the error B<EINVAL>. Specifying a buffer of size"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "sizeof(struct inotify_event) + NAME_MAX + 1\n"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid "will be sufficient to read at least one event."
+msgstr ""
+
+#. type: SS
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "inotify events"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"The B<inotify_add_watch>(2) I<mask> argument and the I<mask> field of the "
+"I<inotify_event> structure returned when B<read>(2)ing an inotify file "
+"descriptor are both bit masks identifying inotify events. The following "
+"bits can be specified in I<mask> when calling B<inotify_add_watch>(2) and "
+"may be returned in the I<mask> field returned by B<read>(2):"
+msgstr ""
+
+#. type: TP
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "B<IN_ACCESS> (+)"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid "File was accessed (e.g., B<read>(2), B<execve>(2))."
+msgstr ""
+
+#. type: TP
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "B<IN_ATTRIB> (*)"
+msgstr ""
+
+#. FIXME .
+#. Events do not occur for link count changes on a file inside a monitored
+#. directory. This differs from other metadata changes for files inside
+#. a monitored directory.
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"Metadata changed\\[em]for example, permissions (e.g., B<chmod>(2)), "
+"timestamps (e.g., B<utimensat>(2)), extended attributes (B<setxattr>(2)), "
+"link count (since Linux 2.6.25; e.g., for the target of B<link>(2) and for "
+"B<unlink>(2)), and user/group ID (e.g., B<chown>(2))."
+msgstr ""
+
+#. type: TP
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "B<IN_CLOSE_WRITE> (+)"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid "File opened for writing was closed."
+msgstr ""
+
+#. type: TP
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "B<IN_CLOSE_NOWRITE> (*)"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid "File or directory not opened for writing was closed."
+msgstr ""
+
+#. type: TP
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "B<IN_CREATE> (+)"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"File/directory created in watched directory (e.g., B<open>(2) B<O_CREAT>, "
+"B<mkdir>(2), B<link>(2), B<symlink>(2), B<bind>(2) on a UNIX domain socket)."
+msgstr ""
+
+#. type: TP
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "B<IN_DELETE> (+)"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid "File/directory deleted from watched directory."
+msgstr ""
+
+#. type: TP
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "B<IN_DELETE_SELF>"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"Watched file/directory was itself deleted. (This event also occurs if an "
+"object is moved to another filesystem, since B<mv>(1) in effect copies the "
+"file to the other filesystem and then deletes it from the original "
+"filesystem.) In addition, an B<IN_IGNORED> event will subsequently be "
+"generated for the watch descriptor."
+msgstr ""
+
+#. type: TP
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "B<IN_MODIFY> (+)"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid "File was modified (e.g., B<write>(2), B<truncate>(2))."
+msgstr ""
+
+#. type: TP
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "B<IN_MOVE_SELF>"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid "Watched file/directory was itself moved."
+msgstr ""
+
+#. type: TP
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "B<IN_MOVED_FROM> (+)"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"Generated for the directory containing the old filename when a file is "
+"renamed."
+msgstr ""
+
+#. type: TP
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "B<IN_MOVED_TO> (+)"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"Generated for the directory containing the new filename when a file is "
+"renamed."
+msgstr ""
+
+#. type: TP
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "B<IN_OPEN> (*)"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid "File or directory was opened."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"Inotify monitoring is inode-based: when monitoring a file (but not when "
+"monitoring the directory containing a file), an event can be generated for "
+"activity on any link to the file (in the same or a different directory)."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid "When monitoring a directory:"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"the events marked above with an asterisk (*) can occur both for the "
+"directory itself and for objects inside the directory; and"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"the events marked with a plus sign (+) occur only for objects inside the "
+"directory (not for the directory itself)."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"I<Note>: when monitoring a directory, events are not generated for the files "
+"inside the directory when the events are performed via a pathname (i.e., a "
+"link) that lies outside the monitored directory."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"When events are generated for objects inside a watched directory, the "
+"I<name> field in the returned I<inotify_event> structure identifies the name "
+"of the file within the directory."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"The B<IN_ALL_EVENTS> macro is defined as a bit mask of all of the above "
+"events. This macro can be used as the I<mask> argument when calling "
+"B<inotify_add_watch>(2)."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid "Two additional convenience macros are defined:"
+msgstr ""
+
+#. type: TP
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "B<IN_MOVE>"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid "Equates to B<IN_MOVED_FROM | IN_MOVED_TO>."
+msgstr ""
+
+#. type: TP
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "B<IN_CLOSE>"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid "Equates to B<IN_CLOSE_WRITE | IN_CLOSE_NOWRITE>."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"The following further bits can be specified in I<mask> when calling "
+"B<inotify_add_watch>(2):"
+msgstr ""
+
+#. type: TP
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "B<IN_DONT_FOLLOW> (since Linux 2.6.15)"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid "Don't dereference I<pathname> if it is a symbolic link."
+msgstr ""
+
+#. type: TP
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "B<IN_EXCL_UNLINK> (since Linux 2.6.36)"
+msgstr ""
+
+#. commit 8c1934c8d70b22ca8333b216aec6c7d09fdbd6a6
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"By default, when watching events on the children of a directory, events are "
+"generated for children even after they have been unlinked from the "
+"directory. This can result in large numbers of uninteresting events for "
+"some applications (e.g., if watching I</tmp>, in which many applications "
+"create temporary files whose names are immediately unlinked). Specifying "
+"B<IN_EXCL_UNLINK> changes the default behavior, so that events are not "
+"generated for children after they have been unlinked from the watched "
+"directory."
+msgstr ""
+
+#. type: TP
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "B<IN_MASK_ADD>"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"If a watch instance already exists for the filesystem object corresponding "
+"to I<pathname>, add (OR) the events in I<mask> to the watch mask (instead of "
+"replacing the mask); the error B<EINVAL> results if B<IN_MASK_CREATE> is "
+"also specified."
+msgstr ""
+
+#. type: TP
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "B<IN_ONESHOT>"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"Monitor the filesystem object corresponding to I<pathname> for one event, "
+"then remove from watch list."
+msgstr ""
+
+#. type: TP
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "B<IN_ONLYDIR> (since Linux 2.6.15)"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"Watch I<pathname> only if it is a directory; the error B<ENOTDIR> results if "
+"I<pathname> is not a directory. Using this flag provides an application "
+"with a race-free way of ensuring that the monitored object is a directory."
+msgstr ""
+
+#. type: TP
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "B<IN_MASK_CREATE> (since Linux 4.18)"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"Watch I<pathname> only if it does not already have a watch associated with "
+"it; the error B<EEXIST> results if I<pathname> is already being watched."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"Using this flag provides an application with a way of ensuring that new "
+"watches do not modify existing ones. This is useful because multiple paths "
+"may refer to the same inode, and multiple calls to B<inotify_add_watch>(2) "
+"without this flag may clobber existing watch masks."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"The following bits may be set in the I<mask> field returned by B<read>(2):"
+msgstr ""
+
+#. type: TP
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "B<IN_IGNORED>"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"Watch was removed explicitly (B<inotify_rm_watch>(2)) or automatically "
+"(file was deleted, or filesystem was unmounted). See also BUGS."
+msgstr ""
+
+#. type: TP
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "B<IN_ISDIR>"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid "Subject of this event is a directory."
+msgstr ""
+
+#. type: TP
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "B<IN_Q_OVERFLOW>"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid "Event queue overflowed (I<wd> is -1 for this event)."
+msgstr ""
+
+#. type: TP
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "B<IN_UNMOUNT>"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"Filesystem containing watched object was unmounted. In addition, an "
+"B<IN_IGNORED> event will subsequently be generated for the watch descriptor."
+msgstr ""
+
+#. type: SS
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "Examples"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"Suppose an application is watching the directory I<dir> and the file I<dir/"
+"myfile> for all events. The examples below show some events that will be "
+"generated for these two objects."
+msgstr ""
+
+#. type: TP
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "fd = open(\"dir/myfile\", O_RDWR);"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid "Generates B<IN_OPEN> events for both I<dir> and I<dir/myfile>."
+msgstr ""
+
+#. type: TP
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "read(fd, buf, count);"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid "Generates B<IN_ACCESS> events for both I<dir> and I<dir/myfile>."
+msgstr ""
+
+#. type: TP
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "write(fd, buf, count);"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid "Generates B<IN_MODIFY> events for both I<dir> and I<dir/myfile>."
+msgstr ""
+
+#. type: TP
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "fchmod(fd, mode);"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid "Generates B<IN_ATTRIB> events for both I<dir> and I<dir/myfile>."
+msgstr ""
+
+#. type: TP
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "close(fd);"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid "Generates B<IN_CLOSE_WRITE> events for both I<dir> and I<dir/myfile>."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"Suppose an application is watching the directories I<dir1> and I<dir2>, and "
+"the file I<dir1/myfile>. The following examples show some events that may "
+"be generated."
+msgstr ""
+
+#. type: TP
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "link(\"dir1/myfile\", \"dir2/new\");"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"Generates an B<IN_ATTRIB> event for I<myfile> and an B<IN_CREATE> event for "
+"I<dir2>."
+msgstr ""
+
+#. type: TP
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "rename(\"dir1/myfile\", \"dir2/myfile\");"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"Generates an B<IN_MOVED_FROM> event for I<dir1>, an B<IN_MOVED_TO> event for "
+"I<dir2>, and an B<IN_MOVE_SELF> event for I<myfile>. The B<IN_MOVED_FROM> "
+"and B<IN_MOVED_TO> events will have the same I<cookie> value."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"Suppose that I<dir1/xx> and I<dir2/yy> are (the only) links to the same "
+"file, and an application is watching I<dir1>, I<dir2>, I<dir1/xx>, and "
+"I<dir2/yy>. Executing the following calls in the order given below will "
+"generate the following events:"
+msgstr ""
+
+#. type: TP
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "unlink(\"dir2/yy\");"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"Generates an B<IN_ATTRIB> event for I<xx> (because its link count changes) "
+"and an B<IN_DELETE> event for I<dir2>."
+msgstr ""
+
+#. type: TP
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "unlink(\"dir1/xx\");"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"Generates B<IN_ATTRIB>, B<IN_DELETE_SELF>, and B<IN_IGNORED> events for "
+"I<xx>, and an B<IN_DELETE> event for I<dir1>."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"Suppose an application is watching the directory I<dir> and (the empty) "
+"directory I<dir/subdir>. The following examples show some events that may "
+"be generated."
+msgstr ""
+
+#. type: TP
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "mkdir(\"dir/new\", mode);"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid "Generates an B<IN_CREATE | IN_ISDIR> event for I<dir>."
+msgstr ""
+
+#. type: TP
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "rmdir(\"dir/subdir\");"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"Generates B<IN_DELETE_SELF> and B<IN_IGNORED> events for I<subdir>, and an "
+"B<IN_DELETE | IN_ISDIR> event for I<dir>."
+msgstr ""
+
+#. type: SS
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "/proc interfaces"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"The following interfaces can be used to limit the amount of kernel memory "
+"consumed by inotify:"
+msgstr ""
+
+#. type: TP
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "I</proc/sys/fs/inotify/max_queued_events>"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"The value in this file is used when an application calls B<inotify_init>(2) "
+"to set an upper limit on the number of events that can be queued to the "
+"corresponding inotify instance. Events in excess of this limit are dropped, "
+"but an B<IN_Q_OVERFLOW> event is always generated."
+msgstr ""
+
+#. type: TP
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "I</proc/sys/fs/inotify/max_user_instances>"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"This specifies an upper limit on the number of inotify instances that can be "
+"created per real user ID."
+msgstr ""
+
+#. type: TP
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "I</proc/sys/fs/inotify/max_user_watches>"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"This specifies an upper limit on the number of watches that can be created "
+"per real user ID."
+msgstr ""
+
+#. type: SH
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "STANDARDS"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-unstable fedora-40 fedora-rawhide mageia-cauldron
+#: opensuse-leap-15-6 opensuse-tumbleweed
+msgid "Linux."
+msgstr ""
+
+#. type: SH
+#: archlinux debian-unstable fedora-40 fedora-rawhide mageia-cauldron
+#: opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "HISTORY"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"Inotify was merged into Linux 2.6.13. The required library interfaces were "
+"added in glibc 2.4. (B<IN_DONT_FOLLOW>, B<IN_MASK_ADD>, and B<IN_ONLYDIR> "
+"were added in glibc 2.5.)"
+msgstr ""
+
+#. type: SH
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "NOTES"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"Inotify file descriptors can be monitored using B<select>(2), B<poll>(2), "
+"and B<epoll>(7). When an event is available, the file descriptor indicates "
+"as readable."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"Since Linux 2.6.25, signal-driven I/O notification is available for inotify "
+"file descriptors; see the discussion of B<F_SETFL> (for setting the "
+"B<O_ASYNC> flag), B<F_SETOWN>, and B<F_SETSIG> in B<fcntl>(2). The "
+"I<siginfo_t> structure (described in B<sigaction>(2)) that is passed to the "
+"signal handler has the following fields set: I<si_fd> is set to the inotify "
+"file descriptor number; I<si_signo> is set to the signal number; I<si_code> "
+"is set to B<POLL_IN>; and B<POLLIN> is set in I<si_band>."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"If successive output inotify events produced on the inotify file descriptor "
+"are identical (same I<wd>, I<mask>, I<cookie>, and I<name>), then they are "
+"coalesced into a single event if the older event has not yet been read (but "
+"see BUGS). This reduces the amount of kernel memory required for the event "
+"queue, but also means that an application can't use inotify to reliably "
+"count file events."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"The events returned by reading from an inotify file descriptor form an "
+"ordered queue. Thus, for example, it is guaranteed that when renaming from "
+"one directory to another, events will be produced in the correct order on "
+"the inotify file descriptor."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"The set of watch descriptors that is being monitored via an inotify file "
+"descriptor can be viewed via the entry for the inotify file descriptor in "
+"the process's I</proc/>pidI</fdinfo> directory. See B<proc>(5) for further "
+"details. The B<FIONREAD> B<ioctl>(2) returns the number of bytes available "
+"to read from an inotify file descriptor."
+msgstr ""
+
+#. type: SS
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "Limitations and caveats"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"The inotify API provides no information about the user or process that "
+"triggered the inotify event. In particular, there is no easy way for a "
+"process that is monitoring events via inotify to distinguish events that it "
+"triggers itself from those that are triggered by other processes."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"Inotify reports only events that a user-space program triggers through the "
+"filesystem API. As a result, it does not catch remote events that occur on "
+"network filesystems. (Applications must fall back to polling the filesystem "
+"to catch such events.) Furthermore, various pseudo-filesystems such as I</"
+"proc>, I</sys>, and I</dev/pts> are not monitorable with inotify."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"The inotify API does not report file accesses and modifications that may "
+"occur because of B<mmap>(2), B<msync>(2), and B<munmap>(2)."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"The inotify API identifies affected files by filename. However, by the time "
+"an application processes an inotify event, the filename may already have "
+"been deleted or renamed."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"The inotify API identifies events via watch descriptors. It is the "
+"application's responsibility to cache a mapping (if one is needed) between "
+"watch descriptors and pathnames. Be aware that directory renamings may "
+"affect multiple cached pathnames."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"Inotify monitoring of directories is not recursive: to monitor "
+"subdirectories under a directory, additional watches must be created. This "
+"can take a significant amount time for large directory trees."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"If monitoring an entire directory subtree, and a new subdirectory is created "
+"in that tree or an existing directory is renamed into that tree, be aware "
+"that by the time you create a watch for the new subdirectory, new files (and "
+"subdirectories) may already exist inside the subdirectory. Therefore, you "
+"may want to scan the contents of the subdirectory immediately after adding "
+"the watch (and, if desired, recursively add watches for any subdirectories "
+"that it contains)."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"Note that the event queue can overflow. In this case, events are lost. "
+"Robust applications should handle the possibility of lost events "
+"gracefully. For example, it may be necessary to rebuild part or all of the "
+"application cache. (One simple, but possibly expensive, approach is to "
+"close the inotify file descriptor, empty the cache, create a new inotify "
+"file descriptor, and then re-create watches and cache entries for the "
+"objects to be monitored.)"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"If a filesystem is mounted on top of a monitored directory, no event is "
+"generated, and no events are generated for objects immediately under the new "
+"mount point. If the filesystem is subsequently unmounted, events will "
+"subsequently be generated for the directory and the objects it contains."
+msgstr ""
+
+#. type: SS
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "Dealing with rename() events"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"As noted above, the B<IN_MOVED_FROM> and B<IN_MOVED_TO> event pair that is "
+"generated by B<rename>(2) can be matched up via their shared cookie value. "
+"However, the task of matching has some challenges."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"These two events are usually consecutive in the event stream available when "
+"reading from the inotify file descriptor. However, this is not guaranteed. "
+"If multiple processes are triggering events for monitored objects, then (on "
+"rare occasions) an arbitrary number of other events may appear between the "
+"B<IN_MOVED_FROM> and B<IN_MOVED_TO> events. Furthermore, it is not "
+"guaranteed that the event pair is atomically inserted into the queue: there "
+"may be a brief interval where the B<IN_MOVED_FROM> has appeared, but the "
+"B<IN_MOVED_TO> has not."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"Matching up the B<IN_MOVED_FROM> and B<IN_MOVED_TO> event pair generated by "
+"B<rename>(2) is thus inherently racy. (Don't forget that if an object is "
+"renamed outside of a monitored directory, there may not even be an "
+"B<IN_MOVED_TO> event.) Heuristic approaches (e.g., assume the events are "
+"always consecutive) can be used to ensure a match in most cases, but will "
+"inevitably miss some cases, causing the application to perceive the "
+"B<IN_MOVED_FROM> and B<IN_MOVED_TO> events as being unrelated. If watch "
+"descriptors are destroyed and re-created as a result, then those watch "
+"descriptors will be inconsistent with the watch descriptors in any pending "
+"events. (Re-creating the inotify file descriptor and rebuilding the cache "
+"may be useful to deal with this scenario.)"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"Applications should also allow for the possibility that the B<IN_MOVED_FROM> "
+"event was the last event that could fit in the buffer returned by the "
+"current call to B<read>(2), and the accompanying B<IN_MOVED_TO> event might "
+"be fetched only on the next B<read>(2), which should be done with a (small) "
+"timeout to allow for the fact that insertion of the "
+"B<IN_MOVED_FROM>+B<IN_MOVED_TO> event pair is not atomic, and also the "
+"possibility that there may not be any B<IN_MOVED_TO> event."
+msgstr ""
+
+#. type: SH
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "BUGS"
+msgstr ""
+
+#. commit 820c12d5d6c0890bc93dd63893924a13041fdc35
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"Before Linux 3.19, B<fallocate>(2) did not create any inotify events. "
+"Since Linux 3.19, calls to B<fallocate>(2) generate B<IN_MODIFY> events."
+msgstr ""
+
+#. FIXME . kernel commit 611da04f7a31b2208e838be55a42c7a1310ae321
+#. implies that unmount events were buggy since Linux 2.6.11 to Linux 2.6.36
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid "Before Linux 2.6.16, the B<IN_ONESHOT> I<mask> flag does not work."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"As originally designed and implemented, the B<IN_ONESHOT> flag did not cause "
+"an B<IN_IGNORED> event to be generated when the watch was dropped after one "
+"event. However, as an unintended effect of other changes, since Linux "
+"2.6.36, an B<IN_IGNORED> event is generated in this case."
+msgstr ""
+
+#. commit 1c17d18e3775485bf1e0ce79575eb637a94494a2
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"Before Linux 2.6.25, the kernel code that was intended to coalesce "
+"successive identical events (i.e., the two most recent events could "
+"potentially be coalesced if the older had not yet been read) instead "
+"checked if the most recent event could be coalesced with the I<oldest> "
+"unread event."
+msgstr ""
+
+#. FIXME . https://bugzilla.kernel.org/show_bug.cgi?id=77111
+#. type: Plain text
+#: archlinux debian-unstable fedora-40 fedora-rawhide mageia-cauldron
+#: opensuse-tumbleweed
+msgid ""
+"When a watch descriptor is removed by calling B<inotify_rm_watch>(2) (or "
+"because a watch file is deleted or the filesystem that contains it is "
+"unmounted), any pending unread events for that watch descriptor remain "
+"available to read. As watch descriptors are subsequently allocated with "
+"B<inotify_add_watch>(2), the kernel cycles through the range of possible "
+"watch descriptors (1 to B<INT_MAX>) incrementally. When allocating a free "
+"watch descriptor, no check is made to see whether that watch descriptor "
+"number has any pending unread events in the inotify queue. Thus, it can "
+"happen that a watch descriptor is reallocated even when pending unread "
+"events exist for a previous incarnation of that watch descriptor number, "
+"with the result that the application might then read those events and "
+"interpret them as belonging to the file associated with the newly recycled "
+"watch descriptor. In practice, the likelihood of hitting this bug may be "
+"extremely low, since it requires that an application cycle through "
+"B<INT_MAX> watch descriptors, release a watch descriptor while leaving "
+"unread events for that watch descriptor in the queue, and then recycle that "
+"watch descriptor. For this reason, and because there have been no reports "
+"of the bug occurring in real-world applications, as of Linux 3.15, no kernel "
+"changes have yet been made to eliminate this possible bug."
+msgstr ""
+
+#. type: SH
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "EXAMPLES"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"The following program demonstrates the usage of the inotify API. It marks "
+"the directories passed as a command-line arguments and waits for events of "
+"type B<IN_OPEN>, B<IN_CLOSE_NOWRITE>, and B<IN_CLOSE_WRITE>."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"The following output was recorded while editing the file I</home/user/temp/"
+"foo> and listing directory I</tmp>. Before the file and the directory were "
+"opened, B<IN_OPEN> events occurred. After the file was closed, an "
+"B<IN_CLOSE_WRITE> event occurred. After the directory was closed, an "
+"B<IN_CLOSE_NOWRITE> event occurred. Execution of the program ended when the "
+"user pressed the ENTER key."
+msgstr ""
+
+#. type: SS
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "Example output"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-unstable fedora-40 fedora-rawhide mageia-cauldron
+#: opensuse-tumbleweed
+#, no-wrap
+msgid ""
+"$ B<./a.out /tmp /home/user/temp>\n"
+"Press enter key to terminate.\n"
+"Listening for events.\n"
+"IN_OPEN: /home/user/temp/foo [file]\n"
+"IN_CLOSE_WRITE: /home/user/temp/foo [file]\n"
+"IN_OPEN: /tmp/ [directory]\n"
+"IN_CLOSE_NOWRITE: /tmp/ [directory]\n"
+"\\&\n"
+"Listening for events stopped.\n"
+msgstr ""
+
+#. type: SS
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "Program source"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-unstable fedora-40 fedora-rawhide mageia-cauldron
+#: opensuse-tumbleweed
+#, no-wrap
+msgid ""
+"#include E<lt>errno.hE<gt>\n"
+"#include E<lt>poll.hE<gt>\n"
+"#include E<lt>stdio.hE<gt>\n"
+"#include E<lt>stdlib.hE<gt>\n"
+"#include E<lt>sys/inotify.hE<gt>\n"
+"#include E<lt>unistd.hE<gt>\n"
+"#include E<lt>string.hE<gt>\n"
+"\\&\n"
+"/* Read all available inotify events from the file descriptor \\[aq]fd\\[aq].\n"
+" wd is the table of watch descriptors for the directories in argv.\n"
+" argc is the length of wd and argv.\n"
+" argv is the list of watched directories.\n"
+" Entry 0 of wd and argv is unused. */\n"
+"\\&\n"
+"static void\n"
+"handle_events(int fd, int *wd, int argc, char* argv[])\n"
+"{\n"
+" /* Some systems cannot read integer variables if they are not\n"
+" properly aligned. On other systems, incorrect alignment may\n"
+" decrease performance. Hence, the buffer used for reading from\n"
+" the inotify file descriptor should have the same alignment as\n"
+" struct inotify_event. */\n"
+"\\&\n"
+" char buf[4096]\n"
+" __attribute__ ((aligned(__alignof__(struct inotify_event))));\n"
+" const struct inotify_event *event;\n"
+" ssize_t len;\n"
+"\\&\n"
+" /* Loop while events can be read from inotify file descriptor. */\n"
+"\\&\n"
+" for (;;) {\n"
+"\\&\n"
+" /* Read some events. */\n"
+"\\&\n"
+" len = read(fd, buf, sizeof(buf));\n"
+" if (len == -1 && errno != EAGAIN) {\n"
+" perror(\"read\");\n"
+" exit(EXIT_FAILURE);\n"
+" }\n"
+"\\&\n"
+" /* If the nonblocking read() found no events to read, then\n"
+" it returns -1 with errno set to EAGAIN. In that case,\n"
+" we exit the loop. */\n"
+"\\&\n"
+" if (len E<lt>= 0)\n"
+" break;\n"
+"\\&\n"
+" /* Loop over all events in the buffer. */\n"
+"\\&\n"
+" for (char *ptr = buf; ptr E<lt> buf + len;\n"
+" ptr += sizeof(struct inotify_event) + event-E<gt>len) {\n"
+"\\&\n"
+" event = (const struct inotify_event *) ptr;\n"
+"\\&\n"
+" /* Print event type. */\n"
+"\\&\n"
+" if (event-E<gt>mask & IN_OPEN)\n"
+" printf(\"IN_OPEN: \");\n"
+" if (event-E<gt>mask & IN_CLOSE_NOWRITE)\n"
+" printf(\"IN_CLOSE_NOWRITE: \");\n"
+" if (event-E<gt>mask & IN_CLOSE_WRITE)\n"
+" printf(\"IN_CLOSE_WRITE: \");\n"
+"\\&\n"
+" /* Print the name of the watched directory. */\n"
+"\\&\n"
+" for (size_t i = 1; i E<lt> argc; ++i) {\n"
+" if (wd[i] == event-E<gt>wd) {\n"
+" printf(\"%s/\", argv[i]);\n"
+" break;\n"
+" }\n"
+" }\n"
+"\\&\n"
+" /* Print the name of the file. */\n"
+"\\&\n"
+" if (event-E<gt>len)\n"
+" printf(\"%s\", event-E<gt>name);\n"
+"\\&\n"
+" /* Print type of filesystem object. */\n"
+"\\&\n"
+" if (event-E<gt>mask & IN_ISDIR)\n"
+" printf(\" [directory]\\en\");\n"
+" else\n"
+" printf(\" [file]\\en\");\n"
+" }\n"
+" }\n"
+"}\n"
+"\\&\n"
+"int\n"
+"main(int argc, char* argv[])\n"
+"{\n"
+" char buf;\n"
+" int fd, i, poll_num;\n"
+" int *wd;\n"
+" nfds_t nfds;\n"
+" struct pollfd fds[2];\n"
+"\\&\n"
+" if (argc E<lt> 2) {\n"
+" printf(\"Usage: %s PATH [PATH ...]\\en\", argv[0]);\n"
+" exit(EXIT_FAILURE);\n"
+" }\n"
+"\\&\n"
+" printf(\"Press ENTER key to terminate.\\en\");\n"
+"\\&\n"
+" /* Create the file descriptor for accessing the inotify API. */\n"
+"\\&\n"
+" fd = inotify_init1(IN_NONBLOCK);\n"
+" if (fd == -1) {\n"
+" perror(\"inotify_init1\");\n"
+" exit(EXIT_FAILURE);\n"
+" }\n"
+"\\&\n"
+" /* Allocate memory for watch descriptors. */\n"
+"\\&\n"
+" wd = calloc(argc, sizeof(int));\n"
+" if (wd == NULL) {\n"
+" perror(\"calloc\");\n"
+" exit(EXIT_FAILURE);\n"
+" }\n"
+"\\&\n"
+" /* Mark directories for events\n"
+" - file was opened\n"
+" - file was closed */\n"
+"\\&\n"
+" for (i = 1; i E<lt> argc; i++) {\n"
+" wd[i] = inotify_add_watch(fd, argv[i],\n"
+" IN_OPEN | IN_CLOSE);\n"
+" if (wd[i] == -1) {\n"
+" fprintf(stderr, \"Cannot watch \\[aq]%s\\[aq]: %s\\en\",\n"
+" argv[i], strerror(errno));\n"
+" exit(EXIT_FAILURE);\n"
+" }\n"
+" }\n"
+"\\&\n"
+" /* Prepare for polling. */\n"
+"\\&\n"
+" nfds = 2;\n"
+"\\&\n"
+" fds[0].fd = STDIN_FILENO; /* Console input */\n"
+" fds[0].events = POLLIN;\n"
+"\\&\n"
+" fds[1].fd = fd; /* Inotify input */\n"
+" fds[1].events = POLLIN;\n"
+"\\&\n"
+" /* Wait for events and/or terminal input. */\n"
+"\\&\n"
+" printf(\"Listening for events.\\en\");\n"
+" while (1) {\n"
+" poll_num = poll(fds, nfds, -1);\n"
+" if (poll_num == -1) {\n"
+" if (errno == EINTR)\n"
+" continue;\n"
+" perror(\"poll\");\n"
+" exit(EXIT_FAILURE);\n"
+" }\n"
+"\\&\n"
+" if (poll_num E<gt> 0) {\n"
+"\\&\n"
+" if (fds[0].revents & POLLIN) {\n"
+"\\&\n"
+" /* Console input is available. Empty stdin and quit. */\n"
+"\\&\n"
+" while (read(STDIN_FILENO, &buf, 1) E<gt> 0 && buf != \\[aq]\\en\\[aq])\n"
+" continue;\n"
+" break;\n"
+" }\n"
+"\\&\n"
+" if (fds[1].revents & POLLIN) {\n"
+"\\&\n"
+" /* Inotify events are available. */\n"
+"\\&\n"
+" handle_events(fd, wd, argc, argv);\n"
+" }\n"
+" }\n"
+" }\n"
+"\\&\n"
+" printf(\"Listening for events stopped.\\en\");\n"
+"\\&\n"
+" /* Close inotify file descriptor. */\n"
+"\\&\n"
+" close(fd);\n"
+"\\&\n"
+" free(wd);\n"
+" exit(EXIT_SUCCESS);\n"
+"}\n"
+msgstr ""
+
+#. type: SH
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "SEE ALSO"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"B<inotifywait>(1), B<inotifywatch>(1), B<inotify_add_watch>(2), "
+"B<inotify_init>(2), B<inotify_init1>(2), B<inotify_rm_watch>(2), B<read>(2), "
+"B<stat>(2), B<fanotify>(7)"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"I<Documentation/filesystems/inotify.txt> in the Linux kernel source tree"
+msgstr ""
+
+#. type: TH
+#: debian-bookworm
+#, no-wrap
+msgid "2023-02-05"
+msgstr ""
+
+#. type: TH
+#: debian-bookworm
+#, no-wrap
+msgid "Linux man-pages 6.03"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm
+msgid ""
+"The I<name> field is present only when an event is returned for a file "
+"inside a watched directory; it identifies the filename within the watched "
+"directory. This filename is null-terminated, and may include further null "
+"bytes (\\[aq]\\e0\\[aq]) to align subsequent reads to a suitable address "
+"boundary."
+msgstr ""
+
+#. type: SH
+#: debian-bookworm
+#, no-wrap
+msgid "VERSIONS"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm
+msgid "The inotify API is Linux-specific."
+msgstr ""
+
+#. FIXME . https://bugzilla.kernel.org/show_bug.cgi?id=77111
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+msgid ""
+"When a watch descriptor is removed by calling B<inotify_rm_watch>(2) (or "
+"because a watch file is deleted or the filesystem that contains it is "
+"unmounted), any pending unread events for that watch descriptor remain "
+"available to read. As watch descriptors are subsequently allocated with "
+"B<inotify_add_watch>(2), the kernel cycles through the range of possible "
+"watch descriptors (0 to B<INT_MAX>) incrementally. When allocating a free "
+"watch descriptor, no check is made to see whether that watch descriptor "
+"number has any pending unread events in the inotify queue. Thus, it can "
+"happen that a watch descriptor is reallocated even when pending unread "
+"events exist for a previous incarnation of that watch descriptor number, "
+"with the result that the application might then read those events and "
+"interpret them as belonging to the file associated with the newly recycled "
+"watch descriptor. In practice, the likelihood of hitting this bug may be "
+"extremely low, since it requires that an application cycle through "
+"B<INT_MAX> watch descriptors, release a watch descriptor while leaving "
+"unread events for that watch descriptor in the queue, and then recycle that "
+"watch descriptor. For this reason, and because there have been no reports "
+"of the bug occurring in real-world applications, as of Linux 3.15, no kernel "
+"changes have yet been made to eliminate this possible bug."
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid ""
+"$ B<./a.out /tmp /home/user/temp>\n"
+"Press enter key to terminate.\n"
+"Listening for events.\n"
+"IN_OPEN: /home/user/temp/foo [file]\n"
+"IN_CLOSE_WRITE: /home/user/temp/foo [file]\n"
+"IN_OPEN: /tmp/ [directory]\n"
+"IN_CLOSE_NOWRITE: /tmp/ [directory]\n"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid "Listening for events stopped.\n"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid ""
+"#include E<lt>errno.hE<gt>\n"
+"#include E<lt>poll.hE<gt>\n"
+"#include E<lt>stdio.hE<gt>\n"
+"#include E<lt>stdlib.hE<gt>\n"
+"#include E<lt>sys/inotify.hE<gt>\n"
+"#include E<lt>unistd.hE<gt>\n"
+"#include E<lt>string.hE<gt>\n"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid ""
+"/* Read all available inotify events from the file descriptor \\[aq]fd\\[aq].\n"
+" wd is the table of watch descriptors for the directories in argv.\n"
+" argc is the length of wd and argv.\n"
+" argv is the list of watched directories.\n"
+" Entry 0 of wd and argv is unused. */\n"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid ""
+"static void\n"
+"handle_events(int fd, int *wd, int argc, char* argv[])\n"
+"{\n"
+" /* Some systems cannot read integer variables if they are not\n"
+" properly aligned. On other systems, incorrect alignment may\n"
+" decrease performance. Hence, the buffer used for reading from\n"
+" the inotify file descriptor should have the same alignment as\n"
+" struct inotify_event. */\n"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid ""
+" char buf[4096]\n"
+" __attribute__ ((aligned(__alignof__(struct inotify_event))));\n"
+" const struct inotify_event *event;\n"
+" ssize_t len;\n"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid " /* Loop while events can be read from inotify file descriptor. */\n"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid " for (;;) {\n"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid " /* Read some events. */\n"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid ""
+" len = read(fd, buf, sizeof(buf));\n"
+" if (len == -1 && errno != EAGAIN) {\n"
+" perror(\"read\");\n"
+" exit(EXIT_FAILURE);\n"
+" }\n"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid ""
+" /* If the nonblocking read() found no events to read, then\n"
+" it returns -1 with errno set to EAGAIN. In that case,\n"
+" we exit the loop. */\n"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid ""
+" if (len E<lt>= 0)\n"
+" break;\n"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid " /* Loop over all events in the buffer. */\n"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid ""
+" for (char *ptr = buf; ptr E<lt> buf + len;\n"
+" ptr += sizeof(struct inotify_event) + event-E<gt>len) {\n"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid " event = (const struct inotify_event *) ptr;\n"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid " /* Print event type. */\n"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid ""
+" if (event-E<gt>mask & IN_OPEN)\n"
+" printf(\"IN_OPEN: \");\n"
+" if (event-E<gt>mask & IN_CLOSE_NOWRITE)\n"
+" printf(\"IN_CLOSE_NOWRITE: \");\n"
+" if (event-E<gt>mask & IN_CLOSE_WRITE)\n"
+" printf(\"IN_CLOSE_WRITE: \");\n"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid " /* Print the name of the watched directory. */\n"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid ""
+" for (size_t i = 1; i E<lt> argc; ++i) {\n"
+" if (wd[i] == event-E<gt>wd) {\n"
+" printf(\"%s/\", argv[i]);\n"
+" break;\n"
+" }\n"
+" }\n"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid " /* Print the name of the file. */\n"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid ""
+" if (event-E<gt>len)\n"
+" printf(\"%s\", event-E<gt>name);\n"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid " /* Print type of filesystem object. */\n"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid ""
+" if (event-E<gt>mask & IN_ISDIR)\n"
+" printf(\" [directory]\\en\");\n"
+" else\n"
+" printf(\" [file]\\en\");\n"
+" }\n"
+" }\n"
+"}\n"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid ""
+"int\n"
+"main(int argc, char* argv[])\n"
+"{\n"
+" char buf;\n"
+" int fd, i, poll_num;\n"
+" int *wd;\n"
+" nfds_t nfds;\n"
+" struct pollfd fds[2];\n"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid ""
+" if (argc E<lt> 2) {\n"
+" printf(\"Usage: %s PATH [PATH ...]\\en\", argv[0]);\n"
+" exit(EXIT_FAILURE);\n"
+" }\n"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid " printf(\"Press ENTER key to terminate.\\en\");\n"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid " /* Create the file descriptor for accessing the inotify API. */\n"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid ""
+" fd = inotify_init1(IN_NONBLOCK);\n"
+" if (fd == -1) {\n"
+" perror(\"inotify_init1\");\n"
+" exit(EXIT_FAILURE);\n"
+" }\n"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid " /* Allocate memory for watch descriptors. */\n"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid ""
+" wd = calloc(argc, sizeof(int));\n"
+" if (wd == NULL) {\n"
+" perror(\"calloc\");\n"
+" exit(EXIT_FAILURE);\n"
+" }\n"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid ""
+" /* Mark directories for events\n"
+" - file was opened\n"
+" - file was closed */\n"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid ""
+" for (i = 1; i E<lt> argc; i++) {\n"
+" wd[i] = inotify_add_watch(fd, argv[i],\n"
+" IN_OPEN | IN_CLOSE);\n"
+" if (wd[i] == -1) {\n"
+" fprintf(stderr, \"Cannot watch \\[aq]%s\\[aq]: %s\\en\",\n"
+" argv[i], strerror(errno));\n"
+" exit(EXIT_FAILURE);\n"
+" }\n"
+" }\n"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid " /* Prepare for polling. */\n"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid " nfds = 2;\n"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid ""
+" fds[0].fd = STDIN_FILENO; /* Console input */\n"
+" fds[0].events = POLLIN;\n"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid ""
+" fds[1].fd = fd; /* Inotify input */\n"
+" fds[1].events = POLLIN;\n"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid " /* Wait for events and/or terminal input. */\n"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid ""
+" printf(\"Listening for events.\\en\");\n"
+" while (1) {\n"
+" poll_num = poll(fds, nfds, -1);\n"
+" if (poll_num == -1) {\n"
+" if (errno == EINTR)\n"
+" continue;\n"
+" perror(\"poll\");\n"
+" exit(EXIT_FAILURE);\n"
+" }\n"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid " if (poll_num E<gt> 0) {\n"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid " if (fds[0].revents & POLLIN) {\n"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid " /* Console input is available. Empty stdin and quit. */\n"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid ""
+" while (read(STDIN_FILENO, &buf, 1) E<gt> 0 && buf != \\[aq]\\en\\[aq])\n"
+" continue;\n"
+" break;\n"
+" }\n"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid " if (fds[1].revents & POLLIN) {\n"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid " /* Inotify events are available. */\n"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid ""
+" handle_events(fd, wd, argc, argv);\n"
+" }\n"
+" }\n"
+" }\n"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid " printf(\"Listening for events stopped.\\en\");\n"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid " /* Close inotify file descriptor. */\n"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid " close(fd);\n"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid ""
+" free(wd);\n"
+" exit(EXIT_SUCCESS);\n"
+"}\n"
+msgstr ""
+
+#. type: TH
+#: debian-unstable opensuse-tumbleweed
+#, no-wrap
+msgid "2023-07-08"
+msgstr ""
+
+#. type: TH
+#: debian-unstable opensuse-tumbleweed
+#, no-wrap
+msgid "Linux man-pages 6.05.01"
+msgstr ""
+
+#. type: TH
+#: opensuse-leap-15-6
+#, no-wrap
+msgid "2023-03-30"
+msgstr ""
+
+#. type: TH
+#: opensuse-leap-15-6
+#, no-wrap
+msgid "Linux man-pages 6.04"
+msgstr ""