From 03e688ea7b57f06f9700e8edb33a59a3f54e3d8a Mon Sep 17 00:00:00 2001 From: Reilly Wood <26268125+rgwood@users.noreply.github.com> Date: Wed, 8 Mar 2023 21:45:58 -0800 Subject: [PATCH] Revert to notify v4 (#8367) This reverts https://github.com/nushell/nushell/pull/8114 which upgraded to `notify` (a file watching crate used by the `watch` command) v5. `notify` v5 has several breaking changes and it's much harder to use. It no longer includes debouncing of file system events, which I think is essential functionality for `watch`. @WindSoilder was going to try writing our own debouncing functionality but I don't think he had time to finish it. @WindSoilder Is it OK if we revert this for the 0.77 release (March 14)? We can try again for 0.78 --- Cargo.lock | 287 +++++++++++++++------- crates/nu-command/Cargo.toml | 2 +- crates/nu-command/src/filesystem/watch.rs | 176 ++++++++----- 3 files changed, 308 insertions(+), 157 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index 01ad3ed99..9e6afdc67 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -35,7 +35,7 @@ version = "0.8.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "464b3811b747f8f7ebc8849c9c728c39f6ac98a055edad93baf9eb330e3f8f9d" dependencies = [ - "cfg-if", + "cfg-if 1.0.0", "const-random", "getrandom 0.2.7", "once_cell", @@ -255,7 +255,7 @@ checksum = "d9b39be18770d11421cdb1b9947a45dd3f37e93092cbf377614828a319d5fee8" dependencies = [ "hermit-abi", "libc", - "winapi", + "winapi 0.3.9", ] [[package]] @@ -506,6 +506,12 @@ dependencies = [ "nom", ] +[[package]] +name = "cfg-if" +version = "0.1.10" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "4785bdd1c96b2a846b2bd7cc02e86b6b3dbf14e7e53446c4f54c92a361040822" + [[package]] name = "cfg-if" version = "1.0.0" @@ -526,7 +532,7 @@ dependencies = [ "serde", "time 0.1.44", "wasm-bindgen", - "winapi", + "winapi 0.3.9", ] [[package]] @@ -636,7 +642,7 @@ checksum = "b3616f750b84d8f0de8a58bda93e08e2a81ad3f523089b05f1dffecab48c6cbd" dependencies = [ "atty", "lazy_static", - "winapi", + "winapi 0.3.9", ] [[package]] @@ -662,7 +668,7 @@ dependencies = [ "libc", "terminal_size 0.1.17", "unicode-width", - "winapi", + "winapi 0.3.9", ] [[package]] @@ -756,7 +762,7 @@ version = "1.3.2" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "b540bd8bc810d3885c6ea91e2018302f68baba2129ab3e88f32389ee9370880d" dependencies = [ - "cfg-if", + "cfg-if 1.0.0", ] [[package]] @@ -802,7 +808,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "95da181745b56d4bd339530ec393508910c909c784e8962d15d722bacf0bcbcd" dependencies = [ "bare-metal 1.0.0", - "cfg-if", + "cfg-if 1.0.0", "cortex-m", "riscv", ] @@ -813,7 +819,7 @@ version = "0.5.6" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "c2dd04ddaf88237dc3b8d8f9a3c1004b506b54b3313403944054d23c0870c521" dependencies = [ - "cfg-if", + "cfg-if 1.0.0", "crossbeam-utils", ] @@ -823,7 +829,7 @@ version = "0.8.2" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "715e8152b692bba2d374b53d4875445368fdf21a94751410af607a5ac677d1fc" dependencies = [ - "cfg-if", + "cfg-if 1.0.0", "crossbeam-epoch", "crossbeam-utils", ] @@ -835,7 +841,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "f916dfc5d356b0ed9dae65f1db9fc9770aa2851d2662b988ccf4fe3516e86348" dependencies = [ "autocfg", - "cfg-if", + "cfg-if 1.0.0", "crossbeam-utils", "memoffset", "scopeguard", @@ -847,7 +853,7 @@ version = "0.8.12" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "edbafec5fa1f196ca66527c1b12c2ec4745ca14b50f1ad8f9f6f720b55d11fac" dependencies = [ - "cfg-if", + "cfg-if 1.0.0", ] [[package]] @@ -859,12 +865,12 @@ dependencies = [ "bitflags", "crossterm_winapi", "libc", - "mio", + "mio 0.8.4", "parking_lot 0.12.1", "serde", "signal-hook", "signal-hook-mio", - "winapi", + "winapi 0.3.9", ] [[package]] @@ -876,11 +882,11 @@ dependencies = [ "bitflags", "crossterm_winapi", "libc", - "mio", + "mio 0.8.4", "parking_lot 0.12.1", "signal-hook", "signal-hook-mio", - "winapi", + "winapi 0.3.9", ] [[package]] @@ -889,7 +895,7 @@ version = "0.9.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "2ae1b35a484aa10e07fe0638d02301c5ad24de82d310ccbd2f3693da5f09bf1c" dependencies = [ - "winapi", + "winapi 0.3.9", ] [[package]] @@ -983,7 +989,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "1d91974fbbe88ec1df0c24a4f00f99583667a7e2e6272b2b92d294d81e462173" dependencies = [ "nix", - "winapi", + "winapi 0.3.9", ] [[package]] @@ -998,7 +1004,7 @@ version = "5.4.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "907076dfda823b0b36d2a1bb5f90c96660a5bbcd7729e10727f07858f22c4edc" dependencies = [ - "cfg-if", + "cfg-if 1.0.0", "hashbrown 0.12.3", "lock_api", "once_cell", @@ -1084,7 +1090,7 @@ version = "2.0.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "b98cf8ebf19c3d1b223e151f99a4f9f0690dca41414773390fc824184ac833e1" dependencies = [ - "cfg-if", + "cfg-if 1.0.0", "dirs-sys-next", ] @@ -1096,7 +1102,7 @@ checksum = "1b1d1d91c932ef41c0f2663aa8b0ca0342d444d842c06914aa0a7e352d0bada6" dependencies = [ "libc", "redox_users", - "winapi", + "winapi 0.3.9", ] [[package]] @@ -1107,7 +1113,7 @@ checksum = "4ebda144c4fe02d1f7ea1a7d9641b6fc6b580adcfa024ae48797ecdeb6825b4d" dependencies = [ "libc", "redox_users", - "winapi", + "winapi 0.3.9", ] [[package]] @@ -1198,7 +1204,7 @@ version = "0.8.31" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "9852635589dc9f9ea1b6fe9f05b50ef208c85c834a562f0c6abb1c475736ec2b" dependencies = [ - "cfg-if", + "cfg-if 1.0.0", ] [[package]] @@ -1240,7 +1246,7 @@ checksum = "f639046355ee4f37944e44f60642c6f3a7efa3cf6b78c78a0d989a8ce6c396a1" dependencies = [ "errno-dragonfly", "libc", - "winapi", + "winapi 0.3.9", ] [[package]] @@ -1307,7 +1313,7 @@ version = "3.0.6" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "e11dcc7e4d79a8c89b9ab4c6f5c30b1fc4a83c420792da3542fd31179ed5f517" dependencies = [ - "cfg-if", + "cfg-if 1.0.0", "rustix 0.35.11", "windows-sys 0.36.1", ] @@ -1318,7 +1324,7 @@ version = "0.2.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "12d741e2415d4e2e5bd1c1d00409d1a8865a57892c2d689b504365655d237d43" dependencies = [ - "winapi", + "winapi 0.3.9", ] [[package]] @@ -1327,7 +1333,7 @@ version = "0.2.17" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "e94a7bbaa59354bc20dd75b67f23e2797b4490e9d6928203fb105c79e448c86c" dependencies = [ - "cfg-if", + "cfg-if 1.0.0", "libc", "redox_syscall", "windows-sys 0.36.1", @@ -1395,14 +1401,40 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "42703706b716c37f96a77aea830392ad231f44c9e9a67872fa5548707e11b11c" [[package]] -name = "fsevent-sys" -version = "4.1.0" +name = "fsevent" +version = "0.4.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "76ee7a02da4d231650c7cea31349b889be2f45ddb3ef3032d2ec8185f6313fd2" +checksum = "5ab7d1bd1bd33cc98b0889831b72da23c0aa4df9cec7e0702f46ecea04b35db6" +dependencies = [ + "bitflags", + "fsevent-sys", +] + +[[package]] +name = "fsevent-sys" +version = "2.0.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f41b048a94555da0f42f1d632e2e19510084fb8e303b0daa2816e733fb3644a0" dependencies = [ "libc", ] +[[package]] +name = "fuchsia-zircon" +version = "0.3.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "2e9763c69ebaae630ba35f74888db465e49e259ba1bc0eda7d06f4a067615d82" +dependencies = [ + "bitflags", + "fuchsia-zircon-sys", +] + +[[package]] +name = "fuchsia-zircon-sys" +version = "0.3.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "3dcaa9ae7725d12cdb85b3ad99a434db70b468c09ded17e012d86b5c1010f7a7" + [[package]] name = "futf" version = "0.1.5" @@ -1536,7 +1568,7 @@ version = "0.1.16" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "8fc3cb4d91f53b50155bdcfd23f6a4c39ae1969c2ae85982b135750cccaf5fce" dependencies = [ - "cfg-if", + "cfg-if 1.0.0", "libc", "wasi 0.9.0+wasi-snapshot-preview1", ] @@ -1547,7 +1579,7 @@ version = "0.2.7" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "4eb1a864a501629691edf6c15a593b7a51eebaa1e8468e9ddc623de7c9b58ec6" dependencies = [ - "cfg-if", + "cfg-if 1.0.0", "js-sys", "libc", "wasi 0.11.0+wasi-snapshot-preview1", @@ -1815,7 +1847,7 @@ dependencies = [ "core-foundation-sys", "js-sys", "wasm-bindgen", - "winapi", + "winapi 0.3.9", ] [[package]] @@ -1868,9 +1900,9 @@ dependencies = [ [[package]] name = "inotify" -version = "0.9.6" +version = "0.7.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f8069d3ec154eb856955c1c0fbffefbf5f3c40a104ec912d4797314c1801abff" +checksum = "4816c66d2c8ae673df83366c18341538f234a26d65a9ecea5c348b453ac1d02f" dependencies = [ "bitflags", "inotify-sys", @@ -1892,7 +1924,7 @@ version = "0.1.12" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "7a5bbe824c507c5da5956355e86a746d82e0e1464f65d862cc5e71da70e94b2c" dependencies = [ - "cfg-if", + "cfg-if 1.0.0", ] [[package]] @@ -1921,6 +1953,15 @@ dependencies = [ "windows-sys 0.45.0", ] +[[package]] +name = "iovec" +version = "0.1.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b2b3ea6ff95e175473f8ffe6a7eb7c00d054240321b84c57051175fe3c1e075e" +dependencies = [ + "libc", +] + [[package]] name = "is-root" version = "0.1.2" @@ -1928,7 +1969,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "04a4202a60e86f1c9702706bb42270dadd333f2db7810157563c86f17af3c873" dependencies = [ "users 0.10.0", - "winapi", + "winapi 0.3.9", ] [[package]] @@ -1949,7 +1990,7 @@ version = "1.0.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "fa9acdc6d67b75e626ad644734e8bc6df893d9cd2a834129065d3dd6158ea9c8" dependencies = [ - "winapi", + "winapi 0.3.9", ] [[package]] @@ -2011,23 +2052,13 @@ dependencies = [ ] [[package]] -name = "kqueue" -version = "1.0.7" +name = "kernel32-sys" +version = "0.2.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "2c8fc60ba15bf51257aa9807a48a61013db043fcf3a78cb0d916e8e396dcad98" +checksum = "7507624b29483431c0ba2d82aece8ca6cdba9382bff4ddd0f7490560c056098d" dependencies = [ - "kqueue-sys", - "libc", -] - -[[package]] -name = "kqueue-sys" -version = "1.0.3" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8367585489f01bc55dd27404dcf56b95e6da061a256a666ab23be9ba96a2e587" -dependencies = [ - "bitflags", - "libc", + "winapi 0.2.8", + "winapi-build", ] [[package]] @@ -2141,8 +2172,8 @@ version = "0.7.3" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "efbc0f03f9a775e9f6aed295c6a1ba2253c5757a9e03d55c6caa46a681abcddd" dependencies = [ - "cfg-if", - "winapi", + "cfg-if 1.0.0", + "winapi 0.3.9", ] [[package]] @@ -2236,7 +2267,7 @@ version = "0.4.17" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "abb12e687cfb44aa40f41fc3978ef76448f9b6038cad6aef4259d3c095a2382e" dependencies = [ - "cfg-if", + "cfg-if 1.0.0", ] [[package]] @@ -2415,6 +2446,25 @@ dependencies = [ "adler", ] +[[package]] +name = "mio" +version = "0.6.23" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "4afd66f5b91bf2a3bc13fad0e21caedac168ca4c707504e75585648ae80e4cc4" +dependencies = [ + "cfg-if 0.1.10", + "fuchsia-zircon", + "fuchsia-zircon-sys", + "iovec", + "kernel32-sys", + "libc", + "log", + "miow", + "net2", + "slab", + "winapi 0.2.8", +] + [[package]] name = "mio" version = "0.8.4" @@ -2427,6 +2477,30 @@ dependencies = [ "windows-sys 0.36.1", ] +[[package]] +name = "mio-extras" +version = "2.0.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "52403fe290012ce777c4626790c8951324a2b9e3316b3143779c72b029742f19" +dependencies = [ + "lazycell", + "log", + "mio 0.6.23", + "slab", +] + +[[package]] +name = "miow" +version = "0.2.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ebd808424166322d4a38da87083bfddd3ac4c131334ed55856112eb06d46944d" +dependencies = [ + "kernel32-sys", + "net2", + "winapi 0.2.8", + "ws2_32-sys", +] + [[package]] name = "mockito" version = "0.32.3" @@ -2502,6 +2576,17 @@ version = "1.0.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "546c37ac5d9e56f55e73b677106873d9d9f5190605e41a856503623648488cae" +[[package]] +name = "net2" +version = "0.2.38" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "74d0df99cfcd2530b2e694f6e17e7f37b8e26bb23983ac530c0c97408837c631" +dependencies = [ + "cfg-if 0.1.10", + "libc", + "winapi 0.3.9", +] + [[package]] name = "new_debug_unreachable" version = "1.0.4" @@ -2516,7 +2601,7 @@ checksum = "e322c04a9e3440c327fca7b6c8a63e6890a32fa2ad689db972425f07e0d22abb" dependencies = [ "autocfg", "bitflags", - "cfg-if", + "cfg-if 1.0.0", "libc", ] @@ -2560,20 +2645,20 @@ dependencies = [ [[package]] name = "notify" -version = "5.1.0" +version = "4.0.17" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "58ea850aa68a06e48fdb069c0ec44d0d64c8dbffa49bf3b6f7f0a901fdea1ba9" +checksum = "ae03c8c853dba7bfd23e571ff0cff7bc9dceb40a4cd684cd1681824183f45257" dependencies = [ "bitflags", - "crossbeam-channel", "filetime", + "fsevent", "fsevent-sys", "inotify", - "kqueue", "libc", - "mio", + "mio 0.6.23", + "mio-extras", "walkdir", - "windows-sys 0.42.0", + "winapi 0.3.9", ] [[package]] @@ -2591,7 +2676,7 @@ version = "0.4.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "bc51db7b362b205941f71232e56c625156eb9a929f8cf74a428fd5bc094a4afc" dependencies = [ - "winapi", + "winapi 0.3.9", ] [[package]] @@ -2948,7 +3033,7 @@ dependencies = [ "ntapi", "once_cell", "procfs", - "winapi", + "winapi 0.3.9", ] [[package]] @@ -3267,7 +3352,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "12fc0523e3bd51a692c8850d075d74dc062ccf251c0110668cbd921917118a13" dependencies = [ "bitflags", - "cfg-if", + "cfg-if 1.0.0", "foreign-types", "libc", "once_cell", @@ -3337,7 +3422,7 @@ version = "0.1.3" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "628223faebab4e3e40667ee0b2336d34a5b960ff60ea743ddfdbcf7770bcfb66" dependencies = [ - "winapi", + "winapi 0.3.9", ] [[package]] @@ -3386,12 +3471,12 @@ version = "0.8.6" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "60a2cfe6f0ad2bfc16aefa463b497d5c7a5ecd44a23efa72aa342d90177356dc" dependencies = [ - "cfg-if", + "cfg-if 1.0.0", "instant", "libc", "redox_syscall", "smallvec", - "winapi", + "winapi 0.3.9", ] [[package]] @@ -3400,7 +3485,7 @@ version = "0.9.3" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "09a279cbf25cb0757810394fbc1e359949b59e348145c643a939a525692e6929" dependencies = [ - "cfg-if", + "cfg-if 1.0.0", "libc", "redox_syscall", "smallvec", @@ -4341,7 +4426,7 @@ version = "0.16.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "7229b505ae0706e64f37ffc54a9c163e11022a6636d58fe1f3f52018257ff9f7" dependencies = [ - "cfg-if", + "cfg-if 1.0.0", "proc-macro2", "quote", "rustc_version 0.4.0", @@ -4403,7 +4488,7 @@ version = "0.18.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "f6d5f2436026b4f6e79dc829837d467cc7e9a55ee40e750d716713540715a2df" dependencies = [ - "cfg-if", + "cfg-if 1.0.0", "ordered-multimap", ] @@ -4706,7 +4791,7 @@ version = "0.10.6" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "82e6b795fe2e3b1e845bafcb27aa35405c4d47cdfc92af5fc8d3002f76cebdc0" dependencies = [ - "cfg-if", + "cfg-if 1.0.0", "cpufeatures", "digest", ] @@ -4751,7 +4836,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "29ad2e15f37ec9a6cc544097b78a1ec90001e9f71b81338ca39f430adaca99af" dependencies = [ "libc", - "mio", + "mio 0.8.4", "signal-hook", ] @@ -4852,7 +4937,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "02e2d2db9033d13a1567121ddd7a095ee144db4e1ca1b1bda3419bc0da294ebd" dependencies = [ "libc", - "winapi", + "winapi 0.3.9", ] [[package]] @@ -5033,7 +5118,7 @@ dependencies = [ "libc", "wasm-bindgen", "web-sys", - "winapi", + "winapi 0.3.9", ] [[package]] @@ -5042,12 +5127,12 @@ version = "0.27.8" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "a902e9050fca0a5d6877550b769abd2bd1ce8c04634b941dbe2809735e1a1e33" dependencies = [ - "cfg-if", + "cfg-if 1.0.0", "core-foundation-sys", "libc", "ntapi", "once_cell", - "winapi", + "winapi 0.3.9", ] [[package]] @@ -5056,13 +5141,13 @@ version = "0.28.2" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "d3e847e2de7a137c8c2cede5095872dbb00f4f9bf34d061347e36b43322acd56" dependencies = [ - "cfg-if", + "cfg-if 1.0.0", "core-foundation-sys", "libc", "ntapi", "once_cell", "rayon", - "winapi", + "winapi 0.3.9", ] [[package]] @@ -5096,7 +5181,7 @@ version = "3.4.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "af18f7ae1acd354b992402e9ec5864359d693cd8a79dcbef59f76891701c1e95" dependencies = [ - "cfg-if", + "cfg-if 1.0.0", "fastrand", "redox_syscall", "rustix 0.36.8", @@ -5130,7 +5215,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "633c1a546cee861a1a6d0dc69ebeca693bf4296661ba7852b9d21d159e0506df" dependencies = [ "libc", - "winapi", + "winapi 0.3.9", ] [[package]] @@ -5203,7 +5288,7 @@ checksum = "6db9e6914ab8b1ae1c260a4ae7a49b6c5611b40328a735b21862567685e73255" dependencies = [ "libc", "wasi 0.10.0+wasi-snapshot-preview1", - "winapi", + "winapi 0.3.9", ] [[package]] @@ -5279,7 +5364,7 @@ dependencies = [ "bytes", "libc", "memchr", - "mio", + "mio 0.8.4", "num_cpus", "parking_lot 0.12.1", "pin-project-lite", @@ -5369,7 +5454,7 @@ version = "0.1.36" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "2fce9567bd60a67d08a16488756721ba392f24f29006402881e43b19aac64307" dependencies = [ - "cfg-if", + "cfg-if 1.0.0", "pin-project-lite", "tracing-core", ] @@ -5687,7 +5772,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "808cf2735cd4b6866113f648b791c6adc5714537bc222d9347bb203386ffda56" dependencies = [ "same-file", - "winapi", + "winapi 0.3.9", "winapi-util", ] @@ -5725,7 +5810,7 @@ version = "0.2.83" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "eaf9f5aceeec8be17c128b2e93e031fb8a4d469bb9c4ae2d7dc1888b26887268" dependencies = [ - "cfg-if", + "cfg-if 1.0.0", "wasm-bindgen-macro", ] @@ -5750,7 +5835,7 @@ version = "0.4.33" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "23639446165ca5a5de86ae1d8896b737ae80319560fbaa4c2887b7da6e7ebd7d" dependencies = [ - "cfg-if", + "cfg-if 1.0.0", "js-sys", "wasm-bindgen", "web-sys", @@ -5839,6 +5924,12 @@ dependencies = [ "once_cell", ] +[[package]] +name = "winapi" +version = "0.2.8" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "167dc9d6949a9b857f3451275e911c3f44255842c1f7a76f33c55103a909087a" + [[package]] name = "winapi" version = "0.3.9" @@ -5849,6 +5940,12 @@ dependencies = [ "winapi-x86_64-pc-windows-gnu", ] +[[package]] +name = "winapi-build" +version = "0.1.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "2d315eee3b34aca4797b2da6b13ed88266e6d612562a0c46390af8299fc699bc" + [[package]] name = "winapi-i686-pc-windows-gnu" version = "0.4.0" @@ -5861,7 +5958,7 @@ version = "0.1.5" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "70ec6ce85bb158151cae5e5c87f95a8e97d2c0c4b001223f33a334e3ce5de178" dependencies = [ - "winapi", + "winapi 0.3.9", ] [[package]] @@ -6009,8 +6106,8 @@ version = "0.11.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "76a1a57ff50e9b408431e8f97d5456f2807f8eb2a2cd79b06068fc87f8ecf189" dependencies = [ - "cfg-if", - "winapi", + "cfg-if 1.0.0", + "winapi 0.3.9", ] [[package]] @@ -6022,6 +6119,16 @@ dependencies = [ "toml 0.5.9", ] +[[package]] +name = "ws2_32-sys" +version = "0.2.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d59cefebd0c892fa2dd6de581e937301d8552cb44489cdff035c6187cb63fa5e" +dependencies = [ + "winapi 0.2.8", + "winapi-build", +] + [[package]] name = "xmlparser" version = "0.13.5" diff --git a/crates/nu-command/Cargo.toml b/crates/nu-command/Cargo.toml index 6a4716af9..5e988d94d 100644 --- a/crates/nu-command/Cargo.toml +++ b/crates/nu-command/Cargo.toml @@ -61,7 +61,7 @@ lscolors = { version = "0.12.0", features = ["crossterm"], default-features = fa md5 = { package = "md-5", version = "0.10.0" } mime = "0.3.16" mime_guess = "2.0.4" -notify = "5.1.0" +notify = "4.0.17" num = { version = "0.4.0", optional = true } num-traits = "0.2.14" once_cell = "1.17" diff --git a/crates/nu-command/src/filesystem/watch.rs b/crates/nu-command/src/filesystem/watch.rs index adc508b6f..70b73cffa 100644 --- a/crates/nu-command/src/filesystem/watch.rs +++ b/crates/nu-command/src/filesystem/watch.rs @@ -2,7 +2,7 @@ use std::path::PathBuf; use std::sync::mpsc::{channel, RecvTimeoutError}; use std::time::Duration; -use notify::{recommended_watcher, EventKind, RecursiveMode, Watcher}; +use notify::{DebouncedEvent, RecommendedWatcher, RecursiveMode, Watcher}; use nu_engine::{current_dir, eval_block, CallExt}; use nu_protocol::ast::Call; use nu_protocol::engine::{Closure, Command, EngineState, Stack, StateWorkingSet}; @@ -13,6 +13,7 @@ use nu_protocol::{ // durations chosen mostly arbitrarily const CHECK_CTRL_C_FREQUENCY: Duration = Duration::from_millis(100); +const DEFAULT_WATCH_DEBOUNCE_DURATION: Duration = Duration::from_millis(100); #[derive(Clone)] pub struct Watch; @@ -37,6 +38,12 @@ impl Command for Watch { .required("closure", SyntaxShape::Closure(Some(vec![SyntaxShape::String, SyntaxShape::String, SyntaxShape::String])), "Some Nu code to run whenever a file changes. The closure will be passed `operation`, `path`, and `new_path` (for renames only) arguments in that order") + .named( + "debounce-ms", + SyntaxShape::Int, + "Debounce changes for this many milliseconds (default: 100). Adjust if you find that single writes are reported as multiple events", + Some('d'), + ) .named( "glob", SyntaxShape::String, // SyntaxShape::GlobPattern gets interpreted relative to cwd, so use String instead @@ -84,6 +91,22 @@ impl Command for Watch { .clone(); let verbose = call.has_flag("verbose"); + + let debounce_duration_flag: Option> = + call.get_flag(engine_state, stack, "debounce-ms")?; + let debounce_duration = match debounce_duration_flag { + Some(val) => match u64::try_from(val.item) { + Ok(val) => Duration::from_millis(val), + Err(_) => { + return Err(ShellError::TypeMismatch { + err_message: "Debounce duration is invalid".to_string(), + span: val.span, + }) + } + }, + None => DEFAULT_WATCH_DEBOUNCE_DURATION, + }; + let glob_flag: Option> = call.get_flag(engine_state, stack, "glob")?; let glob_pattern = match glob_flag { Some(glob) => { @@ -121,7 +144,7 @@ impl Command for Watch { let ctrlc_ref = &engine_state.ctrlc.clone(); let (tx, rx) = channel(); - let mut watcher = match recommended_watcher(tx) { + let mut watcher: RecommendedWatcher = match Watcher::new(tx, debounce_duration) { Ok(w) => w, Err(e) => { return Err(ShellError::IOError(format!( @@ -129,83 +152,104 @@ impl Command for Watch { ))) } }; - if let Err(e) = watcher.watch(&path, recursive_mode) { + + if let Err(e) = watcher.watch(path.clone(), recursive_mode) { return Err(ShellError::IOError(format!("Failed to start watcher: {e}"))); } eprintln!("Now watching files at {path:?}. Press ctrl+c to abort."); - let event_handler = |operation: &str, path: PathBuf| -> Result<(), ShellError> { - let glob_pattern = glob_pattern.clone(); - let matches_glob = match glob_pattern.clone() { - Some(glob) => glob.matches_path(&path), - None => true, + let event_handler = + |operation: &str, path: PathBuf, new_path: Option| -> Result<(), ShellError> { + let glob_pattern = glob_pattern.clone(); + let matches_glob = match glob_pattern.clone() { + Some(glob) => glob.matches_path(&path), + None => true, + }; + if verbose && glob_pattern.is_some() { + eprintln!("Matches glob: {matches_glob}"); + } + + if matches_glob { + let stack = &mut stack.clone(); + + if let Some(position) = block.signature.get_positional(0) { + if let Some(position_id) = &position.var_id { + stack.add_var(*position_id, Value::string(operation, call.span())); + } + } + + if let Some(position) = block.signature.get_positional(1) { + if let Some(position_id) = &position.var_id { + stack.add_var( + *position_id, + Value::string(path.to_string_lossy(), call.span()), + ); + } + } + + if let Some(position) = block.signature.get_positional(2) { + if let Some(position_id) = &position.var_id { + stack.add_var( + *position_id, + Value::string( + new_path.unwrap_or_else(|| "".into()).to_string_lossy(), + call.span(), + ), + ); + } + } + + let eval_result = eval_block( + engine_state, + stack, + &block, + Value::Nothing { span: call.span() }.into_pipeline_data(), + call.redirect_stdout, + call.redirect_stderr, + ); + + match eval_result { + Ok(val) => { + val.print(engine_state, stack, false, false)?; + } + Err(err) => { + let working_set = StateWorkingSet::new(engine_state); + eprintln!("{}", format_error(&working_set, &err)); + } + } + } + + Ok(()) }; - if verbose && glob_pattern.is_some() { - eprintln!("Matches glob: {matches_glob}"); - } - - if matches_glob { - let stack = &mut stack.clone(); - - if let Some(position) = block.signature.get_positional(0) { - if let Some(position_id) = &position.var_id { - stack.add_var(*position_id, Value::string(operation, call.span())); - } - } - - if let Some(position) = block.signature.get_positional(1) { - if let Some(position_id) = &position.var_id { - stack.add_var( - *position_id, - Value::string(path.to_string_lossy(), call.span()), - ); - } - } - - let eval_result = eval_block( - engine_state, - stack, - &block, - Value::Nothing { span: call.span() }.into_pipeline_data(), - call.redirect_stdout, - call.redirect_stderr, - ); - - match eval_result { - Ok(val) => { - val.print(engine_state, stack, false, false)?; - } - Err(err) => { - let working_set = StateWorkingSet::new(engine_state); - eprintln!("{}", format_error(&working_set, &err)); - } - } - } - - Ok(()) - }; loop { match rx.recv_timeout(CHECK_CTRL_C_FREQUENCY) { - Ok(Ok(mut event)) => { + Ok(event) => { if verbose { eprintln!("{event:?}"); } - let path = match event.paths.pop() { - None => continue, - Some(p) => p, - }; - match event.kind { - EventKind::Create(_) => event_handler("Create", path), - EventKind::Modify(notify::event::ModifyKind::Data(_)) => { - event_handler("Write", path) + let handler_result = match event { + DebouncedEvent::Create(path) => event_handler("Create", path, None), + DebouncedEvent::Write(path) => event_handler("Write", path, None), + DebouncedEvent::Remove(path) => event_handler("Remove", path, None), + DebouncedEvent::Rename(path, new_path) => { + event_handler("Rename", path, Some(new_path)) } - EventKind::Remove(_) => event_handler("Remove", path), - _ => Ok(()), - }? + DebouncedEvent::Error(err, path) => match path { + Some(path) => Err(ShellError::IOError(format!( + "Error detected for {path:?}: {err:?}" + ))), + None => Err(ShellError::IOError(format!("Error detected: {err:?}"))), + }, + // These are less likely to be interesting events + DebouncedEvent::Chmod(_) + | DebouncedEvent::NoticeRemove(_) + | DebouncedEvent::NoticeWrite(_) + | DebouncedEvent::Rescan => Ok(()), + }; + handler_result?; } - Ok(Err(e)) => return Err(ShellError::IOError(format!("watch error: {e}"))), Err(RecvTimeoutError::Disconnected) => { return Err(ShellError::IOError( "Unexpected disconnect from file watcher".into(), @@ -230,7 +274,7 @@ impl Command for Watch { }, Example { description: "Watch all changes in the current directory", - example: r#"watch . { |op, path| $"($op) ($path)"}"#, + example: r#"watch . { |op, path, new_path| $"($op) ($path) ($new_path)"}"#, result: None, }, Example {