A simple wrapper for kqueue VNODE (for now) functionality to be asyncio compatible.
Vous ne pouvez pas sélectionner plus de 25 sujets Les noms de sujets doivent commencer par une lettre ou un nombre, peuvent contenir des tirets ('-') et peuvent comporter jusqu'à 35 caractères.
John-Mark Gurney 9e082a8487 add sample program testing if a directory can be watched il y a 9 mois
aiokq add a wrapper around kqueue for VNODE that is asyncio friendly. il y a 9 mois
misc add sample program testing if a directory can be watched il y a 9 mois
.gitignore add a wrapper around kqueue for VNODE that is asyncio friendly. il y a 9 mois
LICENSE.txt add a wrapper around kqueue for VNODE that is asyncio friendly. il y a 9 mois
Makefile add a wrapper around kqueue for VNODE that is asyncio friendly. il y a 9 mois
README.md add a wrapper around kqueue for VNODE that is asyncio friendly. il y a 9 mois
requirements.txt add a wrapper around kqueue for VNODE that is asyncio friendly. il y a 9 mois
setup.py add a wrapper around kqueue for VNODE that is asyncio friendly. il y a 9 mois

README.md

aiokq

This is a module to make select.kqueue module compatible with programs that use asyncio.

The core of kqueue is already implemented via the core asyncio, but other parts of kqueue, like EVFILT_VNODE and EVFILT_PROC are not. This module is currently limited to supporting basic EVFILT_VNODE functionality.

Sample Usage

To watch a file for modification:

fp = open(fname)
async with aiokq.watch_file(fp) as wf:
	while True:
		data = fp.read()
		# do some work on data

		# wait for a modification
		await wf()

The with symantics is required in order to address the race where a write is issued between the registration and the time that you do the read. There is the possibility that a wakeup happens and there are no modifications due to this race.