Skip to content

Releases: fsnotify/fsnotify

v1.7.0

22 Oct 06:28
cfc9c4f
Compare
Choose a tag to compare

This version of fsnotify needs Go 1.17.

Additions

  • illumos: add FEN backend to support illumos and Solaris. (#371)

  • all: add NewBufferedWatcher() to use a buffered channel, which can be useful in cases where you can't control the kernel buffer and receive a large number of events in bursts. (#550, #572)

  • all: add AddWith(), which is identical to Add() but allows passing options. (#521)

  • windows: allow setting the ReadDirectoryChangesW() buffer size with fsnotify.WithBufferSize(); the default of 64K is the highest value that works on all platforms and is enough for most purposes, but in some cases a highest buffer is needed. (#521)

Changes and fixes

  • inotify: remove watcher if a watched path is renamed (#518)

    After a rename the reported name wasn't updated, or even an empty string. Inotify doesn't provide any good facilities to update it, so just remove the watcher. This is already how it worked on kqueue and FEN.

    On Windows this does work, and remains working.

  • windows: don't listen for file attribute changes (#520)

    File attribute changes are sent as FILE_ACTION_MODIFIED by the Windows API, with no way to see if they're a file write or attribute change, so would show up as a fsnotify.Write event. This is never useful, and could result in many spurious Write events.

  • windows: return ErrEventOverflow if the buffer is full (#525)

    Before it would merely return "short read", making it hard to detect this error.

  • kqueue: make sure events for all files are delivered properly when removing a watched directory (#526)

    Previously they would get sent with "" (empty string) or "." as the path name.

  • kqueue: don't emit spurious Create events for symbolic links (#524)

    The link would get resolved but kqueue would "forget" it already saw the link itself, resulting on a Create for every Write event for the directory.

  • all: return ErrClosed on Add() when the watcher is closed (#516)

  • other: add Watcher.Errors and Watcher.Events to the no-op Watcher in backend_other.go, making it easier to use on unsupported platforms such as WASM, AIX, etc. (#528)

  • other: use the backend_other.go no-op if the appengine build tag is set; Google AppEngine forbids usage of the unsafe package so the inotify backend won't compile there.

v1.6.0

13 Oct 01:21
5f8c606
Compare
Choose a tag to compare

This version of fsnotify needs Go 1.16 (this was already the case since 1.5.1, but not documented). It also increases the minimum Linux version to 2.6.32.

Additions

  • all: add Event.Has() and Op.Has() (#477)

    This makes checking events a lot easier; for example:

      if event.Op&Write == Write && !(event.Op&Remove == Remove) {
      }
    

    Becomes:

      if event.Has(Write) && !event.Has(Remove) {
      }
    
  • all: add cmd/fsnotify (#463)

    A command-line utility for testing and some examples.

Changes and fixes

  • inotify: don't ignore events for files that don't exist (#260, #470)

    Previously the inotify watcher would call os.Lstat() to check if a file still exists before emitting events.

    This was inconsistent with other platforms and resulted in inconsistent event reporting (e.g. when a file is quickly removed and re-created), and generally a source of confusion. It was added in 2013 to fix a memory leak that no longer exists.

  • all: return ErrNonExistentWatch when Remove() is called on a path that's
    not watched (#460)

  • inotify: replace epoll() with non-blocking inotify (#434)

    Non-blocking inotify was not generally available at the time this library was written in 2014, but now it is. As a result, the minimum Linux version is bumped from 2.6.27 to 2.6.32. This hugely simplifies the code and is faster.

  • kqueue: don't check for events every 100ms (#480)

    The watcher would wake up every 100ms, even when there was nothing to do. Now it waits until there is something to do.

  • macos: retry opening files on EINTR (#475)

  • kqueue: skip unreadable files (#479)

    kqueue requires a file descriptor for every file in a directory; this would fail if a file was unreadable by the current user. Now these files are simply skipped.

  • windows: fix renaming a watched directory if the parent is also watched (#370)

  • windows: increase buffer size from 4K to 64K (#485)

  • windows: close file handle on Remove() (#288)

  • kqueue: put pathname in the error if watching a file fails (#471)

  • inotify, windows: calling Close() more than once could race (#465)

  • kqueue: improve Close() performance (#233)

  • all: various documentation additions and clarifications.

v1.5.4

27 Apr 02:09
0f4b979
Compare
Choose a tag to compare

What's Changed

New Contributors

Full Changelog: v1.5.2...v1.5.4

v1.5.2

27 Apr 02:10
ceba4ef
Compare
Choose a tag to compare

What's Changed

  • Removed dead link by @COil in #337
  • Update issue templates by @nathany in #410
  • Test on Go 1.18 and two most recent versions by @nathany in #411
  • fix go vet warnings: call to (*T).Fatalf from a non-test goroutine by @shogo82148 in #416
  • Run cross-compilation builds on every push by @nshalman in #420
  • Don't set poller.fd twice in newFdPoller by @tklauser in #406
  • Re-enable tests for PRs by @nshalman in #415
  • Enable cross-compilation builds on PRs by @nshalman in #423
  • Integration Tests: change 1ms sleeps to 50ms by @nshalman in #422
  • Add FreeBSD testing in Github Actions (fix #389) by @r-darwish in #419
  • Allow build on unsupported GOOS by @tklauser in #424
  • Fix potential crash on windows if raw.FileNameLength exceeds syscall.MAX_PATH by @hu13 in #361
  • Add a feature to return the directories and files that are being monitored by @NitroCao in #374

New Contributors

Full Changelog: v1.5.1...v1.5.2

Revert Add AddRaw to not follow symlinks

24 Aug 19:37
Compare
Choose a tag to compare

Add AddRaw which does not dereference symlinks

18 Aug 23:05
08848a0
Compare
Choose a tag to compare
  • Go: Increase minimum required version to Go 1.12 #381
  • Feature: Add AddRaw method which does not follow symlinks when adding a watch #289
  • Windows: Follow symlinks by default like on all other systems #289
  • CI: Use GitHub Actions for CI and cover go 1.12-1.17 #378 #381 #385
  • Go 1.14+: Fix unsafe pointer conversion #325

Move example usage to the readme

11 Mar 17:37
Compare
Choose a tag to compare
  • Move example usage to the readme #329. This may resolve #328.

Use close-on-exec

10 Mar 16:41
Compare
Choose a tag to compare

Fewer deadlocks

10 Jan 05:36
Compare
Choose a tag to compare
  • BSD/macOS: Fix possible deadlock on closing the watcher on kqueue (thanks @nhooyr and @glycerine)
  • Tests: Fix missing verb on format string (thanks @rchiossi)
  • Linux: Fix deadlock in Remove (thanks @aarondl)
  • Linux: Watch.Add improvements (avoid race, fix consistency, reduce garbage) (thanks @twpayne)
  • Docs: Moved FAQ into the README (thanks @vahe)
  • Linux: Properly handle inotify's IN_Q_OVERFLOW event (thanks @zeldovich)
  • Docs: replace references to OS X with macOS

Fix for fork/exec on Linux

11 Oct 02:34
Compare
Choose a tag to compare

Linux: use InotifyInit1 with IN_CLOEXEC to stop leaking a file descriptor to a child process when using fork/exec #178 (thanks @pattyshack)