An open API service indexing awesome lists of open source software.

https://github.com/arnaud-lb/php-inotify

Inotify bindings for PHP 5, 7, and next
https://github.com/arnaud-lb/php-inotify

inotify php php-inotify

Last synced: about 1 month ago
JSON representation

Inotify bindings for PHP 5, 7, and next

Awesome Lists containing this project

README

        

# PHP Inotify

Inotify bindings for PHP 5, PHP 7, and PHP 8

This extension exposes the inotify API and some additional functions.

## Install

### Installing with [PIE](https://github.com/php/pie)

pie install arnaud-lb/inotify

### Installing with PECL

pecl install memprof

### Installing manually

Download the source and run the following commands in the source directory:

phpize
./configure
make
make install

## Loading the extension

The extension can be loaded on the command line, just for one script:

php -dextension=inotify.so script.php

Or permanently, in php.ini:

extension=inotify.so

## Documentation

Documentation is available at https://php.net/inotify

## Goal

The goal of this extension is to expose the raw inotify API to PHP, while being memory safe and preventing resource leaks.

## Streams

As the C inotify API returns file descriptors, this extension returns PHP streams.

This is useful for the following reasons:

### I/O Polling

The streams can be used with polling mechanisms such as ``stream_select()`` or event loops such as ReactPHP or AMPHP. It's also possible to make the streams unblocking with ``stream_set_blocking()``.

### Resource management

As the inotify file descriptors are owned by PHP streams, they are managed by PHP. This ensures that the file descriptors are eventually closed, which prevents descriptor leaks.