-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathREADME.Rmd
96 lines (67 loc) · 2.74 KB
/
README.Rmd
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
---
output: github_document
---
<!-- README.md is generated from README.Rmd. Please edit that file -->
```{r, include = FALSE}
knitr::opts_chunk$set(
collapse = TRUE,
comment = "#>",
fig.path = "man/figures/README-",
out.width = "100%"
)
```
# watcher
<!-- badges: start -->
[](https://CRAN.R-project.org/package=watcher)
[](https://github.com/r-lib/watcher/actions/workflows/R-CMD-check.yaml)
[](https://app.codecov.io/gh/r-lib/watcher)
<!-- badges: end -->
Watch the File System for Changes
R binding for 'libfswatch', a file system monitoring library. This uses an optimal event-driven API for each platform:
- `ReadDirectoryChangesW` on Windows
- `FSEvents` on MacOS
- `inotify` on Linux
- `kqueue` on BSD
- `File Events Notification` on Solaris/Illumos
Watching is done asynchronously in the background, without blocking the session.
- Watch files, or directories recursively.
- Log activity, or run an R function every time a change event occurs.
## Installation
Install watcher from CRAN with:
``` r
install.packages("watcher")
```
#### Installation from Source
watcher requires the 'libfswatch' library.
- On Linux / MacOS, an installed version will be used if found in the standard filesystem locations.
- On Windows, or if not found, the bundled version of 'libfswatch' 1.19.0-dev will be compiled from source.
- Source compilation of the library requires 'cmake'.
## Quick Start
Create a 'Watcher' using `watcher::watcher()`.
By default this will watch the current working directory recursively and write events to `stdout`.
Set the `callback` argument to run an R function, or rlang-style formula, every time a file changes:
- Uses the 'later' package to execute the callback when R is idle at the top level, or whenever `later::run_now()` is called, for instance automatically in Shiny's event loop.
- Function is called back with a character vector of the paths of all files which have changed.
```{r example}
library(watcher)
dir <- file.path(tempdir(), "watcher-example")
dir.create(dir)
w <- watcher(dir, callback = ~print(.x), latency = 0.5)
w
w$start()
file.create(file.path(dir, "newfile"))
file.create(file.path(dir, "anotherfile"))
later::run_now(1)
newfile <- file(file.path(dir, "newfile"), open = "r+")
cat("hello", file = newfile)
close(newfile)
later::run_now(1)
file.remove(file.path(dir, "newfile"))
later::run_now(1)
w$stop()
unlink(dir, recursive = TRUE, force = TRUE)
```
## Acknowledgements
Thanks to the authors of 'libfswatch', upon which this package is based:
- Alan Dipert
- Enrico M. Crisostomo