seregazhuk / reactphp-fswatch
Library for monitoring file changes with fswatch and ReactPHP
Installs: 5 273
Dependents: 0
Suggesters: 0
Security: 0
Stars: 8
Watchers: 2
Forks: 2
Open Issues: 1
Requires
- php: ^7.4
- evenement/evenement: ^3.0
- react/child-process: ^0.6.1
- react/event-loop: ^1.1
Requires (Dev)
- clue/block-react: ^1.3
- phpunit/phpunit: ^8.0
This package is auto-updated.
Last update: 2025-01-15 06:29:04 UTC
README
Table of contents
Installation
Library requires fswatch - a cross-platform file change monitor with multiple environments.
You can install this package like this:
composer global seregazhuk/reactphp-fswatch
Usage
First of all, you create a watcher object providing a loop and fswatch command that
you are going to run. For example if you want to listen to changes inside src
directory:
$loop = \React\EventLoop\Factory::create(); $watcher = new \Seregazhuk\ReactFsWatch\FsWatch('src', $loop,); $watcher->run(); $loop->run();
Once there are changes in the directory the watcher fires change
event that contains an
instance of Change
object. To detect change you can listen to this event and
handle the event object:
$watcher->on( 'change', static function (Change $event) { $type = $event->isFile() ? 'File' : 'Dir'; echo $type . ': ' . $event->file() . ' was changed' . PHP_EOL; } );
Also, you can use a helper method onChange
:
$watcher->onChange($callable);
To stop listening for filesytem use method stop()
:
$watcher->stop();
Filesystem Changes
On every change you receive Change
object that contains different details about
an event that happened in the filesystem. It has the following helper methods to examine the change:
file()
- filename or a directory that has changed.isFile()
- whether a file was changed or not.isDir()
- whether a directory was changed or not.isSymbolicLink
- whether a symbolic link was changed or not.isLink()
- the object link count has changed.noOp()
- no changed were detected.attributeModified()
- the object’s attribute has changed.ownerModified()
- the object’s owner has changed.created()
- the object has been created.removed()
- the object has been removed.renamed()
- the object has been renamed.updated()
- the object has been updated.