Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ixmatus/fswait
Wait and observe events on the filesystem for a path, with a timeout
https://github.com/ixmatus/fswait
command-line haskell
Last synced: 3 months ago
JSON representation
Wait and observe events on the filesystem for a path, with a timeout
- Host: GitHub
- URL: https://github.com/ixmatus/fswait
- Owner: ixmatus
- License: bsd-3-clause
- Created: 2017-06-17T23:45:23.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2024-08-10T15:38:54.000Z (6 months ago)
- Last Synced: 2024-10-11T20:53:15.717Z (4 months ago)
- Topics: command-line, haskell
- Language: Haskell
- Size: 29.3 KB
- Stars: 5
- Watchers: 4
- Forks: 2
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Welcome!
[![Build Status](https://github.com/ixmatus/fswait/actions/workflows/ci.yml/badge.svg)](https://github.com/ixmatus/fswait/actions/workflows/ci.yml)
`fswait` is a utility for blocking on the observation of a filesystem event for
a path with a timeout.This is useful when you need to block the execution of a separate program on the
creation (or some other filesystem event) of a filepath but you want that block
constrained by a timeout.A common use-case is in systemd services, some daemons may need a socket or some
other file to exist before starting and it is common to write shell code to
implement that check-and-wait-with-timeout.This tool makes that pattern more easily expressed as a command line utility
call that also supports observing _many different_ filesystem events for the
specified path.```bash
$ fswait --path /etc/someconfig.ini --modify --create && echo 'Do something!'
observing Create Modify for /home/parnell/Desktop/test.sh
the window for an observation is 120s
Created {isDirectory = False, filePath = "someconfig.ini"}
Do something!
```When an observation occurs, the utility will return immediately with an exit
code of 0 and print the observed event.If the timeout window is reached without an observation occurring, an exit code
of 1 is returned.```bash
$ fswait --help
Wait and observe events on the filesystem for a path, with a timeoutUsage: fswait [--timeout Seconds] --path FILEPATH [--exists] (--access |
--modify | --attrib | --close | --closeWrite | --closeNoWrite |
--open | --move | --moveIn | --moveOut | --moveSelf | --create |
--delete | --onlyDir | --noSymlink | --maskAdd | --oneShot |
--all) ([--access]... | [--modify]... | [--attrib]... |
[--close]... | [--closeWrite]... | [--closeNoWrite]... |
[--open]... | [--move]... | [--moveIn]... | [--moveOut]... |
[--moveSelf]... | [--create]... | [--delete]... | [--onlyDir]... |
[--noSymlink]... | [--maskAdd]... | [--oneShot]... | [--all]...)Available options:
-h,--help Show this help text
--timeout Seconds Window to observe a filesystem event (default: 120s,
negative values wait indefinitely)
--path FILEPATH Observe filesystem events for path
--exists Return immediately if the filepath already exists
```# Installing
If you have Nix you can install it using:
```shell
$ nix-env --install --file default.nix
```