Listen to file modifications using polling and notifies you about the changes. Pure Crystal implementation, no dependencies.
-
Add the dependency to your
shard.yml
:dependencies: file_watcher: github: stephannv/file_watcher
-
Run
shards install
require "file_watcher"
FileWatcher.watch("/path/to/folder/**/*.txt") do |event|
puts event.path # Path to file, eg. "path/to/folder/file.txt"
end
FileWatcher.watch("/path/to/folder/**/*", "/other/folder/**/*") do |event|
# do something
end
The type
could be FileWatcher::EventType::Added
, FileWatcher::EventType::Changed
or FileWatcher::EventType::Deleted
.
FileWatcher.watch("/path/to/folder/**/*") do |event|
event.type.added?
event.type.changed?
event.type.deleted?
# using case
case event.type
in .added?
# do something
in .changed?
# do something
in .deleted?
# do something
end
end
FileWatcher.watch(Path["~path/to/folder/**/*"].expand(home: true)) do |event|
# do something
end
It allows to listen to hidden files, dot files, etc. The default value is File::MatchOptions.glob_default
. Read more here: [https://crystal-lang.org/api/File/MatchOptions.html].
FileWatcher.watch("/path/to/folder/**/*", match_options: File::MatchOptions::DotFiles) do |event|
puts event.path # eg. "path/to/folder/.file"
end
You can listen to changes in symlinks using follow_symlinks: true
.
FileWatcher.watch("/path/to/folder/**/*", follow_symlinks: true) do |event|
# do something
end
By default the interval between each check is 1 second, you can change it passing interval: your_value
.
FileWatcher.watch("/path/to/folder/**/*", interval: 0.10.seconds) do |event|
# do something
end
crystal spec
to run tests.
- Fork it (https://github.com/stephannv/file_watcher/fork)
- Create your feature branch (
git checkout -b my-new-feature
) - Commit your changes (
git commit -am 'Add some feature'
) - Push to the branch (
git push origin my-new-feature
) - Create a new Pull Request
- stephann - creator and maintainer