inotify_init

(PECL inotify >= 0.1.2)

inotify_initInitialise une instance inotify

Description

resource inotify_init ( void )

Initialise une instance inotify pour utiliser avec la fonction inotify_add_watch()

Valeurs de retour

Un flux ou FALSE en cas d'erreur.

Exemples

Exemple #1 Exemple d'utilisatio d'inotify

  1. <?php
  2. // Crée une instance inotify
  3. $fd = inotify_init();
  4.  
  5. // Surveille les modifications des métadonées du fichier __FILE__ (e.g. mtime)
  6. $watch_descriptor = inotify_add_watch($fd, __FILE__, IN_ATTRIB);
  7.  
  8. // Génère un événement
  9. touch(__FILE__);
  10.  
  11. // Lit les événements
  12. $events = inotify_read($fd);
  13. print_r($events);
  14.  
  15. // Les méthodes suivantes permettent d'utiliser les fonctions inotify sans bloquer sur inotify_read():
  16.  
  17. // - Utiliser stream_select() sur $fd:
  18. $read = array($fd);
  19. $write = null;
  20. $except = null;
  21. stream_select($read,$write,$except,0);
  22.  
  23. // - Utiliser stream_set_blocking() sur $fd
  24. stream_set_blocking($fd, 0);
  25. inotify_read($fd); // Does no block, and return false if no events are pending
  26.  
  27. // - Utiliser inotify_queue_len() pour vérifier la taille de la file d'attente
  28. $queue_len = inotify_queue_len($fd); // If > 0, inotify_read() will not block
  29.  
  30. // Arrêt de la surveillance de __FILE__
  31. inotify_rm_watch($fd, $watch_descriptor);
  32.  
  33. // Destruction de l'instance inotify
  34. // Cela aurait arrêté toutes les surveillances si ce n'était pas déjà fait
  35. fclose($fd);
  36.  
  37. ?>

L'exemple ci-dessus va afficher quelque chose de similaire à :

array(
  array(
    'wd' => 1,     // Egale le $watch_descriptor
    'mask' => 4,   // Le bit IN_ATTRIB est activé
    'cookie' => 0, // identifiant uique pour relier des événements (e.g. 
                   // IN_MOVE_FROM et IN_MOVE_TO)
    'name' => '',  // Le nom du fichier (e.g. si un dossier était sous surveillance)
  ),
);

Voir aussi

LoadingChargement en cours