Skip to content

Monitoring file system changes in macOS

License

Notifications You must be signed in to change notification settings

mohakapt/FileWatcher

 
 

Repository files navigation

FileWatcher

A simple file watcher in Swift.

Cocoapods platform Lang codebeat badge SwiftLint Sindre mit Status

Installation:

  • CocoaPods pod "FileWatcher"
  • Carthage github "eonist/FileWatcher" "master"
  • Swift Package Manager https://github.com/eonist/FileWatcher.git
  • Manual Open FileWatcherExample.xcodeproj

Example

This will monitor your Desktop for any file changes:

let filewatcher = FileWatcher([NSString(string: "~/Desktop").expandingTildeInPath])

filewatcher.callback = { event in
  print("Something happened here: " + event.path)
}

filewatcher.start() // start monitoring

Running FileWatcher on a background thread

The above example will run FileWatcher (ie. its callback function) from the current thread. However, if your callback needs to run for any significatant amount of time (for example when monitoring a folder for photos and you need to run a lenghty image processing algorithm on them), this is rarely a good idea.

If you'd rather have your callback running on a background thread, you can provide your own queue, and FileWatcher will use that (instead of the default current thread / run loop):

filewatcher.queue = DispatchQueue.global()

Notes and documentation:

wiki

About

Monitoring file system changes in macOS

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Swift 84.6%
  • Ruby 9.9%
  • Objective-C 5.5%