diff --git a/.github/workflows/cd.yml b/.github/workflows/cd.yml index 8f8a80ce..340733ea 100644 --- a/.github/workflows/cd.yml +++ b/.github/workflows/cd.yml @@ -65,6 +65,9 @@ jobs: run: | sudo apt-get update --fix-missing sudo apt-get install -y --no-install-recommends liblua5.1-0-dev libluajit-5.1-dev gcc pkg-config curl git make ca-certificates + sudo apt-get install -y snapd + sudo snap install snapcraft --classic + sudo snap install multipass --classic --beta - if: matrix.build == 'linux-musl' run: sudo apt-get install -y musl-tools @@ -81,6 +84,13 @@ jobs: - name: Running cargo build run: cargo build --locked --release --target ${{ matrix.target }} + - name: Running snapcraft build + run: | + snapcraft + printf ' [ INFO ] generated files include:\n' + command ls -Al | grep "\.snap" | awk '{ print $9 }' + mv ./*.snap ./xplr.snap + - name: Install gpg secret key run: | cat <(echo -e "${{ secrets.GPG_SECRET }}") | gpg --batch --import @@ -103,6 +113,7 @@ jobs: target/${{ matrix.target }}/release/xplr-${{ matrix.build }}.tar.gz target/${{ matrix.target }}/release/xplr-${{ matrix.build }}.sha256 target/${{ matrix.target }}/release/xplr-${{ matrix.build }}.tar.gz.asc + xplr.snap env: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} @@ -130,6 +141,10 @@ jobs: source.tar.gz.asc env: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + - name: Cleaning snapcraft + run: | + command rm --verbose ./*.snap + snapcraft clean publish-cargo: name: Publishing to Cargo diff --git a/Cargo.lock b/Cargo.lock index 3b3c5991..f573a323 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -4,9 +4,9 @@ version = 3 [[package]] name = "ahash" -version = "0.8.7" +version = "0.8.11" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "77c3a9648d43b9cd48db467b3f87fdd6e146bcc88ab0180006cef2179fe11d01" +checksum = "e89da841a80418a9b391ebaea17f5c112ffaaa96f621d2c285b5174da76b9011" dependencies = [ "cfg-if", "once_cell", @@ -52,26 +52,28 @@ checksum = "4b46cbb362ab8752921c97e041f5e366ee6297bd428a31275b9fcf1e380f7299" [[package]] name = "ansi-to-tui" -version = "3.1.0" +version = "4.0.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0b0e348dcd256ba06d44d5deabc88a7c0e80ee7303158253ca069bcd9e9b7f57" +checksum = "8438af3d7e7dccdb98eff55e5351587d9bec2294daff505fc9a061bd14d22db0" dependencies = [ "nom", "ratatui", + "simdutf8", + "smallvec", "thiserror", ] [[package]] name = "anstyle" -version = "1.0.4" +version = "1.0.6" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7079075b41f533b8c61d2a4d073c4676e1f8b249ff94a393b0595db304e0dd87" +checksum = "8901269c6307e8d93993578286ac0edf7f195079ffff5ebdeea6a59ffb7e36bc" [[package]] name = "anyhow" -version = "1.0.79" +version = "1.0.81" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "080e9890a082662b09c1ad45f567faeeb47f22b5fb23895fbe1e651e718e25ca" +checksum = "0952808a6c2afd1aa8947271f3a60f1a6763c7b912d210184c5149b5cf147247" [[package]] name = "arrayvec" @@ -81,9 +83,9 @@ checksum = "96d30a06541fbafbc7f82ed10c06164cfbd2c401138f6addd8404629c4b16711" [[package]] name = "assert_cmd" -version = "2.0.12" +version = "2.0.14" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "88903cb14723e4d4003335bb7f8a14f27691649105346a0f0957466c096adfe6" +checksum = "ed72493ac66d5804837f480ab3766c72bdfab91a65e565fc54fa9e42db0073a8" dependencies = [ "anstyle", "bstr", @@ -114,18 +116,18 @@ checksum = "bef38d45163c2f1dde094a7dfd33ccf595c92905c8f8f4fdc18d06fb1037718a" [[package]] name = "bitflags" -version = "2.4.1" +version = "2.4.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "327762f6e5a765692301e5bb513e0d9fef63be86bbc14528052b1cd3e6f03e07" +checksum = "ed570934406eb16438a4e976b1b4500774099c13b8cb96eec99f620f05090ddf" dependencies = [ "serde", ] [[package]] name = "bstr" -version = "1.9.0" +version = "1.9.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c48f0051a4b4c5e0b6d365cd04af53aeaa209e3cc15ec2cdb69e73cc87fbd0dc" +checksum = "05efc5cfd9110c8416e471df0e96702d58690178e206e61b7173706673c93706" dependencies = [ "memchr", "regex-automata", @@ -134,9 +136,9 @@ dependencies = [ [[package]] name = "bumpalo" -version = "3.14.0" +version = "3.15.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7f30e7476521f6f8af1a1c4c0b8cc94f0bee37d91763d0ca2665f299b6cd8aec" +checksum = "7ff69b9dd49fd426c69a0db9fc04dd934cdb6645ff000864d98f7e2af8830eaa" [[package]] name = "cassowary" @@ -151,14 +153,20 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "37b2a672a2cb129a2e41c10b1224bb368f9f37a2b16b612598138befd7b37eb5" [[package]] -name = "cc" -version = "1.0.83" +name = "castaway" +version = "0.2.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f1174fb0b6ec23863f8b971027804a42614e347eafb0a95bf0b12cdae21fc4d0" +checksum = "8a17ed5635fc8536268e5d4de1e22e81ac34419e5f052d4d51f4e01dcc263fcc" dependencies = [ - "libc", + "rustversion", ] +[[package]] +name = "cc" +version = "1.0.90" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8cd6604a82acf3039f1144f54b8eb34e91ffba622051189e71b781822d5ee1f5" + [[package]] name = "cfg-if" version = "1.0.0" @@ -167,23 +175,23 @@ checksum = "baf1de4339761588bc0619e3cbc0120ee582ebb74b53b4efbf79117bd2da40fd" [[package]] name = "chrono" -version = "0.4.31" +version = "0.4.35" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7f2c685bad3eb3d45a01354cedb7d5faa66194d1d58ba6e267a8de788f79db38" +checksum = "8eaf5903dcbc0a39312feb77df2ff4c76387d591b9fc7b04a238dcf8bb62639a" dependencies = [ "android-tzdata", "iana-time-zone", "js-sys", "num-traits", "wasm-bindgen", - "windows-targets 0.48.5", + "windows-targets 0.52.4", ] [[package]] name = "ciborium" -version = "0.2.1" +version = "0.2.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "effd91f6c78e5a4ace8a5d3c0b6bfaec9e2baaef55f3efc00e45fb2e477ee926" +checksum = "42e69ffd6f0917f5c029256a24d0161db17cea3997d185db0d35926308770f0e" dependencies = [ "ciborium-io", "ciborium-ll", @@ -192,15 +200,15 @@ dependencies = [ [[package]] name = "ciborium-io" -version = "0.2.1" +version = "0.2.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "cdf919175532b369853f5d5e20b26b43112613fd6fe7aee757e35f7a44642656" +checksum = "05afea1e0a06c9be33d539b876f1ce3692f4afea2cb41f740e7743225ed1c757" [[package]] name = "ciborium-ll" -version = "0.2.1" +version = "0.2.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "defaa24ecc093c77630e6c15e17c51f5e187bf35ee514f4e2d67baaa96dae22b" +checksum = "57663b653d948a338bfb3eeba9bb2fd5fcfaecb9e199e87e1eda4d9e8b240fd9" dependencies = [ "ciborium-io", "half", @@ -208,18 +216,18 @@ dependencies = [ [[package]] name = "clap" -version = "4.4.12" +version = "4.5.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "dcfab8ba68f3668e89f6ff60f5b205cea56aa7b769451a59f34b8682f51c056d" +checksum = "949626d00e063efc93b6dca932419ceb5432f99769911c0b995f7e884c778813" dependencies = [ "clap_builder", ] [[package]] name = "clap_builder" -version = "4.4.12" +version = "4.5.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "fb7fb5e4e979aec3be7791562fcba452f94ad85e954da024396433e0e25a79e9" +checksum = "ae129e2e766ae0ec03484e609954119f123cc1fe650337e155d03b022f24f7b4" dependencies = [ "anstyle", "clap_lex", @@ -227,9 +235,23 @@ dependencies = [ [[package]] name = "clap_lex" -version = "0.6.0" +version = "0.7.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "98cc8fbded0c607b7ba9dd60cd98df59af97e84d24e49c8557331cfc26d301ce" + +[[package]] +name = "compact_str" +version = "0.7.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "702fc72eb24e5a1e48ce58027a675bc24edd52096d5397d4aea7c6dd9eca0bd1" +checksum = "f86b9c4c00838774a6d902ef931eff7470720c51d90c2e32cfe15dc304737b3f" +dependencies = [ + "castaway", + "cfg-if", + "itoa", + "ryu", + "serde", + "static_assertions", +] [[package]] name = "core-foundation-sys" @@ -275,11 +297,10 @@ dependencies = [ [[package]] name = "crossbeam" -version = "0.8.3" +version = "0.8.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "6eb9105919ca8e40d437fc9cbb8f1975d916f1bd28afe795a48aae32a2cc8920" +checksum = "1137cd7e7fc0fb5d3c5a8678be38ec56e819125d8d7907411fe24ccb943faca8" dependencies = [ - "cfg-if", "crossbeam-channel", "crossbeam-deque", "crossbeam-epoch", @@ -289,54 +310,46 @@ dependencies = [ [[package]] name = "crossbeam-channel" -version = "0.5.10" +version = "0.5.12" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "82a9b73a36529d9c47029b9fb3a6f0ea3cc916a261195352ba19e770fc1748b2" +checksum = "ab3db02a9c5b5121e1e42fbdb1aeb65f5e02624cc58c43f2884c6ccac0b82f95" dependencies = [ - "cfg-if", "crossbeam-utils", ] [[package]] name = "crossbeam-deque" -version = "0.8.4" +version = "0.8.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "fca89a0e215bab21874660c67903c5f143333cab1da83d041c7ded6053774751" +checksum = "613f8cc01fe9cf1a3eb3d7f488fd2fa8388403e97039e2f73692932e291a770d" dependencies = [ - "cfg-if", "crossbeam-epoch", "crossbeam-utils", ] [[package]] name = "crossbeam-epoch" -version = "0.9.17" +version = "0.9.18" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0e3681d554572a651dda4186cd47240627c3d0114d45a95f6ad27f2f22e7548d" +checksum = "5b82ac4a3c2ca9c3460964f020e1402edd5753411d7737aa39c3714ad1b5420e" dependencies = [ - "autocfg", - "cfg-if", "crossbeam-utils", ] [[package]] name = "crossbeam-queue" -version = "0.3.10" +version = "0.3.11" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "adc6598521bb5a83d491e8c1fe51db7296019d2ca3cb93cc6c2a20369a4d78a2" +checksum = "df0346b5d5e76ac2fe4e327c5fd1118d6be7c51dfb18f9b7922923f287471e35" dependencies = [ - "cfg-if", "crossbeam-utils", ] [[package]] name = "crossbeam-utils" -version = "0.8.18" +version = "0.8.19" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c3a430a770ebd84726f584a90ee7f020d28db52c6d02138900f22341f866d39c" -dependencies = [ - "cfg-if", -] +checksum = "248e3bacc7dc6baa3b21e405ee045c3047101a49145e7e9eca583ab4c2ca5345" [[package]] name = "crossterm" @@ -344,7 +357,7 @@ version = "0.27.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "f476fe445d41c9e991fd07515a6f463074b782242ccf4a5b7b1d1012e70824df" dependencies = [ - "bitflags 2.4.1", + "bitflags 2.4.2", "crossterm_winapi", "libc", "mio", @@ -363,6 +376,12 @@ dependencies = [ "winapi", ] +[[package]] +name = "crunchy" +version = "0.2.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7a81dae078cea95a014a339291cec439d2f232ebe854a9d672b796c6afafa9b7" + [[package]] name = "darling" version = "0.14.4" @@ -484,9 +503,9 @@ checksum = "fea41bba32d969b513997752735605054bc0dfa92b4c56bf1189f2e174be7a10" [[package]] name = "either" -version = "1.9.0" +version = "1.10.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a26ae43d7bcc3b814de94796a5e736d4029efb0ee900c12e2d54c993ad1a1e07" +checksum = "11157ac094ffbdde99aa67b23417ebdd801842852b500e395a45a9c0aac03e4a" [[package]] name = "equivalent" @@ -496,9 +515,9 @@ checksum = "5443807d6dff69373d433ab9ef5378ad8df50ca6298caf15de6e52e24aaf54d5" [[package]] name = "erased-serde" -version = "0.3.31" +version = "0.4.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "6c138974f9d5e7fe373eb04df7cae98833802ae4b11c24ac7039a21d5af4b26c" +checksum = "2b73807008a3c7f171cc40312f37d95ef0396e048b5848d775f54b1a4dd4a0d3" dependencies = [ "serde", ] @@ -540,9 +559,9 @@ dependencies = [ [[package]] name = "getrandom" -version = "0.2.11" +version = "0.2.12" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "fe9006bed769170c11f845cf00c7c1e9092aeb3f268e007c3e760ac68008070f" +checksum = "190092ea657667030ac6a35e305e62fc4dd69fd98ac98631e5d3a2b1575a12b5" dependencies = [ "cfg-if", "libc", @@ -551,9 +570,13 @@ dependencies = [ [[package]] name = "half" -version = "1.8.2" +version = "2.4.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "eabb4a44450da02c90444cf74558da904edde8fb4e9035a9a6a4e15445af0bd7" +checksum = "b5eceaaeec696539ddaf7b333340f1af35a5aa87ae3e4f3ead0532f72affab2e" +dependencies = [ + "cfg-if", + "crunchy", +] [[package]] name = "hashbrown" @@ -573,9 +596,9 @@ checksum = "95505c38b4572b2d910cecb0281560f54b440a19336cbbcb27bf6ce6adc6f5a8" [[package]] name = "hermit-abi" -version = "0.3.3" +version = "0.3.9" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d77f7ec81a6d05a3abb01ab6eb7590f6083d08449fe5a1c8b1e620283546ccb7" +checksum = "d231dfb89cfffdbc30e7fc41579ed6066ad03abda9e567ccafae602b97ec5024" [[package]] name = "home" @@ -597,9 +620,9 @@ dependencies = [ [[package]] name = "iana-time-zone" -version = "0.1.59" +version = "0.1.60" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b6a67363e2aa4443928ce15e57ebae94fd8949958fd1223c4cfc0cd473ad7539" +checksum = "e7ffbb5a1b541ea2561f8c41c087286cc091e21e556a4f09a8f6cbf17b69b141" dependencies = [ "android_system_properties", "core-foundation-sys", @@ -626,9 +649,9 @@ checksum = "b9e0384b61958566e926dc50660321d12159025e767c18e043daf26b70104c39" [[package]] name = "indexmap" -version = "2.1.0" +version = "2.2.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d530e1a18b1cb4c484e6e34556a0d948706958449fca0cab753d649f2bce3d1f" +checksum = "7b0b929d511467233429c45a44ac1dcaa21ba0f5ba11e4879e6ed28ddb4f9df4" dependencies = [ "equivalent", "hashbrown", @@ -643,12 +666,12 @@ checksum = "1e186cfbae8084e513daff4240b4797e342f988cecda4fb6c939150f96315fd8" [[package]] name = "is-terminal" -version = "0.4.10" +version = "0.4.12" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0bad00257d07be169d870ab665980b06cdb366d792ad690bf2e76876dc503455" +checksum = "f23ff5ef2b80d608d61efee834934d862cd92461afc0560dedf493e4c033738b" dependencies = [ "hermit-abi", - "rustix", + "libc", "windows-sys 0.52.0", ] @@ -663,18 +686,9 @@ dependencies = [ [[package]] name = "itertools" -version = "0.11.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b1c173a5686ce8bfa551b3563d0c2170bf24ca44da99c7ca4bfdab5418c3fe57" -dependencies = [ - "either", -] - -[[package]] -name = "itertools" -version = "0.12.0" +version = "0.12.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "25db6b064527c5d482d0423354fcd07a89a2dfe07b67892e62411946db7f07b0" +checksum = "ba291022dbbd398a455acf126c1e341954079855bc60dfdda641363bd6922569" dependencies = [ "either", ] @@ -697,9 +711,9 @@ dependencies = [ [[package]] name = "js-sys" -version = "0.3.66" +version = "0.3.69" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "cee9c64da59eae3b50095c18d3e74f8b73c0b86d2792824ff01bbce68ba229ca" +checksum = "29c15563dc2726973df627357ce0c9ddddbea194836909d655df6a75d2cf296d" dependencies = [ "wasm-bindgen", ] @@ -712,9 +726,9 @@ checksum = "e2abad23fbc42b3700f2f279844dc832adb2b2eb069b2df918f455c4e18cc646" [[package]] name = "libc" -version = "0.2.151" +version = "0.2.153" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "302d7ab3130588088d277783b1e2d2e10c9e9e4a16dd9050e6ec93fb3e7048f4" +checksum = "9c198f91728a82281a64e1f4f9eeb25d82cb32a5de251c6bd1b5154d63a8e7bd" [[package]] name = "libm" @@ -728,16 +742,16 @@ version = "0.0.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "85c833ca1e66078851dba29046874e38f08b2c883700aa29a03ddd3b23814ee8" dependencies = [ - "bitflags 2.4.1", + "bitflags 2.4.2", "libc", "redox_syscall", ] [[package]] name = "linux-raw-sys" -version = "0.4.12" +version = "0.4.13" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c4cd1a83af159aa67994778be9070f0ae1bd732942279cabb14f86f986a21456" +checksum = "01cda141df6706de531b6c46c3a33ecca755538219bd484262fa09410c13539c" [[package]] name = "lock_api" @@ -751,24 +765,24 @@ dependencies = [ [[package]] name = "log" -version = "0.4.20" +version = "0.4.21" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b5e6163cb8c49088c2c36f57875e58ccd8c87c7427f7fbd50ea6710b2f3f2e8f" +checksum = "90ed8c1e510134f979dbc4f070f87d4313098b704861a105fe34231c70a3901c" [[package]] name = "lru" -version = "0.12.1" +version = "0.12.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "2994eeba8ed550fd9b47a0b38f0242bc3344e496483c6180b69139cc2fa5d1d7" +checksum = "d3262e75e648fce39813cb56ac41f3c3e3f65217ebf3844d818d1f9398cfb0dc" dependencies = [ "hashbrown", ] [[package]] name = "lscolors" -version = "0.16.0" +version = "0.17.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ab0b209ec3976527806024406fe765474b9a1750a0ed4b8f0372364741f50e7b" +checksum = "53304fff6ab1e597661eee37e42ea8c47a146fca280af902bb76bff8a896e523" dependencies = [ "nu-ansi-term", ] @@ -784,9 +798,9 @@ dependencies = [ [[package]] name = "luajit-src" -version = "210.5.3+29b0b28" +version = "210.5.7+d06beb0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0c2bb89013916ce5c949f01a1fbd6d435a58e1d980767a791d755911211d792d" +checksum = "0d251fdacdabbf87704cf48ac1f8b1eb23d6e10855c3ee08e5beb25b4be2e9e4" dependencies = [ "cc", "which", @@ -831,9 +845,9 @@ checksum = "68354c5c6bd36d73ff3feceb05efa59b6acb7626617f4962be322a825e61f79a" [[package]] name = "mio" -version = "0.8.10" +version = "0.8.11" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8f3d0b296e374a4e6f3c7b0a1f5a51d748a0d34c85e7dc48fc3fa9a87657fe09" +checksum = "a4a650543ca06a924e8b371db273b2756685faae30f8487da1b56505a8f78b0c" dependencies = [ "libc", "log", @@ -843,9 +857,9 @@ dependencies = [ [[package]] name = "mlua" -version = "0.9.2" +version = "0.9.6" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7c81f8ac20188feb5461a73eabb22a34dd09d6d58513535eb587e46bff6ba250" +checksum = "868d02cb5eb97761bbf6bd6922c1c7a88b8ea252bbf43bd8350a0bf8497a1fc0" dependencies = [ "bstr", "erased-serde", @@ -859,9 +873,9 @@ dependencies = [ [[package]] name = "mlua-sys" -version = "0.4.0" +version = "0.5.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "fc29228347d6bdc9e613dc95c69df2817f755434ee0f7f3b27b57755fe238b7f" +checksum = "2847b42764435201d8cbee1f517edb79c4cca4181877b90047587c89e1b7bce4" dependencies = [ "cc", "cfg-if", @@ -913,27 +927,33 @@ dependencies = [ [[package]] name = "nu-ansi-term" -version = "0.49.0" +version = "0.50.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c073d3c1930d0751774acf49e66653acecb416c3a54c6ec095a9b11caddb5a68" +checksum = "dd2800e1520bdc966782168a627aa5d1ad92e33b984bf7c7615d31280c83ff14" dependencies = [ "windows-sys 0.48.0", ] +[[package]] +name = "num-conv" +version = "0.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "51d515d32fb182ee37cda2ccdcb92950d6a3c2893aa280e540671c2cd0f3b1d9" + [[package]] name = "num-traits" -version = "0.2.17" +version = "0.2.18" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "39e3200413f237f41ab11ad6d161bc7239c84dcb631773ccd7de3dfe4b5c267c" +checksum = "da0df0e5185db44f69b44f26786fe401b6c293d1907744beaa7fa62b2e5a517a" dependencies = [ "autocfg", ] [[package]] name = "num_threads" -version = "0.1.6" +version = "0.1.7" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "2819ce041d2ee131036f4fc9d6ae7ae125a3a40e97ba64d04fe799ad9dabbb44" +checksum = "5c7398b9c8b70908f6371f47ed36737907c87c52af34c268fed0bf0ceb92ead9" dependencies = [ "libc", ] @@ -1014,9 +1034,9 @@ checksum = "8b870d8c151b6f2fb93e84a13146138f05d02ed11c7e7c54f8826aaaf7c9f184" [[package]] name = "pkg-config" -version = "0.3.28" +version = "0.3.30" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "69d3587f8a9e599cc7ec2c00e331f71c4e69a5f9a4b8a6efd5b07466b9736f9a" +checksum = "d231b230927b5e4ad203db57bbcbee2802f6bce620b1e4a9024a07d94e2907ec" [[package]] name = "plotters" @@ -1054,13 +1074,12 @@ checksum = "439ee305def115ba05938db6eb1644ff94165c5ab5e9420d1c1bcedbba909391" [[package]] name = "predicates" -version = "3.0.4" +version = "3.1.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "6dfc28575c2e3f19cb3c73b93af36460ae898d426eba6fc15b9bd2a5220758a0" +checksum = "68b87bfd4605926cdfefc1c3b5f8fe560e3feca9d5552cf68c466d3d8236c7e8" dependencies = [ "anstyle", "difflib", - "itertools 0.11.0", "predicates-core", ] @@ -1082,9 +1101,9 @@ dependencies = [ [[package]] name = "proc-macro2" -version = "1.0.74" +version = "1.0.79" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "2de98502f212cfcea8d0bb305bd0f49d7ebdd75b64ba0a68f937d888f4e0d6db" +checksum = "e835ff2298f5721608eb1a980ecaee1aef2c132bf95ecc026a11b7bf3c01c02e" dependencies = [ "unicode-ident", ] @@ -1100,15 +1119,16 @@ dependencies = [ [[package]] name = "ratatui" -version = "0.25.0" +version = "0.26.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a5659e52e4ba6e07b2dad9f1158f578ef84a73762625ddb51536019f34d180eb" +checksum = "bcb12f8fbf6c62614b0d56eb352af54f6a22410c3b079eb53ee93c7b97dd31d8" dependencies = [ - "bitflags 2.4.1", + "bitflags 2.4.2", "cassowary", + "compact_str", "crossterm", "indoc", - "itertools 0.12.0", + "itertools 0.12.1", "lru", "paste", "serde", @@ -1120,9 +1140,9 @@ dependencies = [ [[package]] name = "rayon" -version = "1.8.0" +version = "1.9.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9c27db03db7734835b3f53954b534c91069375ce6ccaa2e065441e07d9b6cdb1" +checksum = "e4963ed1bc86e4f3ee217022bd855b297cef07fb9eac5dfa1f788b220b49b3bd" dependencies = [ "either", "rayon-core", @@ -1130,9 +1150,9 @@ dependencies = [ [[package]] name = "rayon-core" -version = "1.12.0" +version = "1.12.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5ce3fb6ad83f861aac485e76e1985cd109d9a3713802152be56c3b1f0e0658ed" +checksum = "1465873a3dfdaa8ae7cb14b4383657caab0b3e8a0aa9ae8e04b044854c8dfce2" dependencies = [ "crossbeam-deque", "crossbeam-utils", @@ -1160,9 +1180,9 @@ dependencies = [ [[package]] name = "regex" -version = "1.10.2" +version = "1.10.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "380b951a9c5e80ddfd6136919eef32310721aa4aacd4889a8d39124b026ab343" +checksum = "b62dbe01f0b06f9d8dc7d49e05a0785f153b00b2c227856282f671e0318c9b15" dependencies = [ "aho-corasick", "memchr", @@ -1172,9 +1192,9 @@ dependencies = [ [[package]] name = "regex-automata" -version = "0.4.3" +version = "0.4.6" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5f804c7828047e88b2d32e2d7fe5a105da8ee3264f01902f796c8e067dc2483f" +checksum = "86b83b8b9847f9bf95ef68afb0b8e6cdb80f498442f5179a29fad448fcc1eaea" dependencies = [ "aho-corasick", "memchr", @@ -1195,11 +1215,11 @@ checksum = "08d43f7aa6b08d49f382cde6a7982047c3426db949b1424bc4b7ec9ae12c6ce2" [[package]] name = "rustix" -version = "0.38.28" +version = "0.38.31" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "72e572a5e8ca657d7366229cdde4bd14c4eb5499a9573d4d366fe1b599daa316" +checksum = "6ea3e1a662af26cd7a3ba09c0297a31af215563ecf42817c98df621387f4e949" dependencies = [ - "bitflags 2.4.1", + "bitflags 2.4.2", "errno", "libc", "linux-raw-sys", @@ -1214,9 +1234,9 @@ checksum = "7ffc183a10b4478d04cbbbfc96d0873219d962dd5accaff2ffbd4ceb7df837f4" [[package]] name = "ryu" -version = "1.0.16" +version = "1.0.17" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f98d2aa92eebf49b69786be48e4477826b256916e84a57ff2a4f21923b48eb4c" +checksum = "e86697c916019a8588c99b5fac3cead74ec0b4b819707a682fd4d23fa0ce1ba1" [[package]] name = "same-file" @@ -1235,9 +1255,9 @@ checksum = "94143f37725109f92c262ed2cf5e59bce7498c01bcc1502d7b9afe439a4e9f49" [[package]] name = "serde" -version = "1.0.194" +version = "1.0.197" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0b114498256798c94a0689e1a15fec6005dee8ac1f41de56404b67afc2a4b773" +checksum = "3fb1c873e1b9b056a4dc4c0c198b24c3ffa059243875552b2bd0933b1aee4ce2" dependencies = [ "serde_derive", ] @@ -1254,20 +1274,20 @@ dependencies = [ [[package]] name = "serde_derive" -version = "1.0.194" +version = "1.0.197" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a3385e45322e8f9931410f01b3031ec534c3947d0e94c18049af4d9f9907d4e0" +checksum = "7eb0b34b42edc17f6b7cac84a52a1c5f0e1bb2227e997ca9011ea3dd34e8610b" dependencies = [ "proc-macro2", "quote", - "syn 2.0.46", + "syn 2.0.53", ] [[package]] name = "serde_json" -version = "1.0.110" +version = "1.0.114" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "6fbd975230bada99c8bb618e0c365c2eefa219158d5c6c29610fd09ff1833257" +checksum = "c5f09b1bd632ef549eaa9f60a1f8de742bdbc698e6cee2095fc84dde5f549ae0" dependencies = [ "itoa", "ryu", @@ -1276,9 +1296,9 @@ dependencies = [ [[package]] name = "serde_yaml" -version = "0.9.30" +version = "0.9.33" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b1bf28c79a99f70ee1f1d83d10c875d2e70618417fda01ad1785e027579d9d38" +checksum = "a0623d197252096520c6f2a5e1171ee436e5af99a5d7caa2891e55e61950e6d9" dependencies = [ "indexmap", "itoa", @@ -1317,6 +1337,12 @@ dependencies = [ "libc", ] +[[package]] +name = "simdutf8" +version = "0.1.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f27f6278552951f1f2b8cf9da965d10969b2efdea95a6ec47987ab46edfe263a" + [[package]] name = "skim" version = "0.10.4" @@ -1344,9 +1370,9 @@ dependencies = [ [[package]] name = "smallvec" -version = "1.11.2" +version = "1.13.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4dccd0940a2dcdf68d092b8cbab7dc0ad8fa938bf95787e1b916b0e3d0e8e970" +checksum = "e6ecd384b10a64542d77071bd64bd7b231f4ed5940fba55e98c3de13824cf3d7" [[package]] name = "smawk" @@ -1374,6 +1400,12 @@ dependencies = [ "syn 1.0.109", ] +[[package]] +name = "static_assertions" +version = "1.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a2eb9349b6444b326872e140eb1cf5e7c522154d69e7a0ffb0fb81c06b37543f" + [[package]] name = "strsim" version = "0.10.0" @@ -1382,24 +1414,24 @@ checksum = "73473c0e59e6d5812c5dfe2a064a6444949f089e20eec9a2e5506596494e4623" [[package]] name = "strum" -version = "0.25.0" +version = "0.26.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "290d54ea6f91c969195bdbcd7442c8c2a2ba87da8bf60a7ee86a235d4bc1e125" +checksum = "5d8cec3501a5194c432b2b7976db6b7d10ec95c253208b45f83f7136aa985e29" dependencies = [ "strum_macros", ] [[package]] name = "strum_macros" -version = "0.25.3" +version = "0.26.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "23dc1fa9ac9c169a78ba62f0b841814b7abae11bdd047b9c58f893439e309ea0" +checksum = "c6cf59daf282c0a494ba14fd21610a0325f9f90ec9d1231dea26bcb1d696c946" dependencies = [ "heck", "proc-macro2", "quote", "rustversion", - "syn 2.0.46", + "syn 2.0.53", ] [[package]] @@ -1415,9 +1447,9 @@ dependencies = [ [[package]] name = "syn" -version = "2.0.46" +version = "2.0.53" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "89456b690ff72fddcecf231caedbe615c59480c93358a93dfae7fc29e3ebbf0e" +checksum = "7383cd0e49fff4b6b90ca5670bfd3e9d6a733b3f90c686605aa7eec8c4996032" dependencies = [ "proc-macro2", "quote", @@ -1443,9 +1475,9 @@ checksum = "3369f5ac52d5eb6ab48c6b4ffdc8efbcad6b89c765749064ba298f2c68a16a76" [[package]] name = "textwrap" -version = "0.16.0" +version = "0.16.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "222a222a5bfe1bba4a77b45ec488a741b3cb8872e5e499451fd7d0129c9c7c3d" +checksum = "23d434d3f8967a09480fb04132ebe0a3e088c173e6d0ee7897abbdf4eab0f8b9" dependencies = [ "smawk", "unicode-linebreak", @@ -1454,29 +1486,29 @@ dependencies = [ [[package]] name = "thiserror" -version = "1.0.56" +version = "1.0.58" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d54378c645627613241d077a3a79db965db602882668f9136ac42af9ecb730ad" +checksum = "03468839009160513471e86a034bb2c5c0e4baae3b43f79ffc55c4a5427b3297" dependencies = [ "thiserror-impl", ] [[package]] name = "thiserror-impl" -version = "1.0.56" +version = "1.0.58" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "fa0faa943b50f3db30a20aa7e265dbc66076993efed8463e8de414e5d06d3471" +checksum = "c61f3ba182994efc43764a46c018c347bc492c79f024e705f46567b418f6d4f7" dependencies = [ "proc-macro2", "quote", - "syn 2.0.46", + "syn 2.0.53", ] [[package]] name = "thread_local" -version = "1.1.7" +version = "1.1.8" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3fdd6f064ccff2d6567adcb3873ca630700f00b5ad3f060c25b5dcfd9a4ce152" +checksum = "8b9ef9bad013ada3808854ceac7b46812a6465ba368859a37e2100283d2d719c" dependencies = [ "cfg-if", "once_cell", @@ -1484,13 +1516,14 @@ dependencies = [ [[package]] name = "time" -version = "0.3.31" +version = "0.3.34" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f657ba42c3f86e7680e53c8cd3af8abbe56b5491790b46e22e19c0d57463583e" +checksum = "c8248b6521bb14bc45b4067159b9b6ad792e2d6d754d6c41fb50e29fefe38749" dependencies = [ "deranged", "itoa", "libc", + "num-conv", "num_threads", "powerfmt", "serde", @@ -1506,10 +1539,11 @@ checksum = "ef927ca75afb808a4d64dd374f00a2adf8d0fcff8e7b184af886c3c87ec4a3f3" [[package]] name = "time-macros" -version = "0.2.16" +version = "0.2.17" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "26197e33420244aeb70c3e8c78376ca46571bc4e701e4791c2cd9f57dcb3a43f" +checksum = "7ba3a3ef41e6672a2f0f001392bb5dcd3ff0a9992d618ca761a11c3121547774" dependencies = [ + "num-conv", "time-core", ] @@ -1580,9 +1614,9 @@ checksum = "3b09c83c3c29d37506a3e260c08c03743a6bb66a9cd432c6934ab501a190571f" [[package]] name = "unicode-segmentation" -version = "1.10.1" +version = "1.11.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1dd624098567895118886609431a7c3b8f516e41d30e0643f03d94592a147e36" +checksum = "d4c87d22b6e3f4a18d4d40ef354e97c90fcb14dd91d7dc0aa9d8a1172ebf7202" [[package]] name = "unicode-width" @@ -1598,9 +1632,9 @@ checksum = "39ec24b3121d976906ece63c9daad25b85969647682eee313cb5779fdd69e14e" [[package]] name = "unsafe-libyaml" -version = "0.2.10" +version = "0.2.11" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ab4c90930b95a82d00dc9e9ac071b4991924390d46cbd0dfe566148667605e4b" +checksum = "673aac59facbab8a9007c7f6108d11f63b603f7cabff99fabf650fea5c32b861" [[package]] name = "utf8parse" @@ -1646,9 +1680,9 @@ dependencies = [ [[package]] name = "walkdir" -version = "2.4.0" +version = "2.5.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d71d857dc86794ca4c280d616f7da00d2dbfd8cd788846559a6813e6aa4b54ee" +checksum = "29790946404f91d9c5d06f9874efddea1dc06c5efe94541a7d6863108e3a5e4b" dependencies = [ "same-file", "winapi-util", @@ -1662,9 +1696,9 @@ checksum = "9c8d87e72b64a3b4db28d11ce29237c246188f4f51057d65a7eab63b7987e423" [[package]] name = "wasm-bindgen" -version = "0.2.89" +version = "0.2.92" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0ed0d4f68a3015cc185aff4db9506a015f4b96f95303897bfa23f846db54064e" +checksum = "4be2531df63900aeb2bca0daaaddec08491ee64ceecbee5076636a3b026795a8" dependencies = [ "cfg-if", "wasm-bindgen-macro", @@ -1672,24 +1706,24 @@ dependencies = [ [[package]] name = "wasm-bindgen-backend" -version = "0.2.89" +version = "0.2.92" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1b56f625e64f3a1084ded111c4d5f477df9f8c92df113852fa5a374dbda78826" +checksum = "614d787b966d3989fa7bb98a654e369c762374fd3213d212cfc0251257e747da" dependencies = [ "bumpalo", "log", "once_cell", "proc-macro2", "quote", - "syn 2.0.46", + "syn 2.0.53", "wasm-bindgen-shared", ] [[package]] name = "wasm-bindgen-macro" -version = "0.2.89" +version = "0.2.92" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0162dbf37223cd2afce98f3d0785506dcb8d266223983e4b5b525859e6e182b2" +checksum = "a1f8823de937b71b9460c0c34e25f3da88250760bec0ebac694b49997550d726" dependencies = [ "quote", "wasm-bindgen-macro-support", @@ -1697,28 +1731,28 @@ dependencies = [ [[package]] name = "wasm-bindgen-macro-support" -version = "0.2.89" +version = "0.2.92" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f0eb82fcb7930ae6219a7ecfd55b217f5f0893484b7a13022ebb2b2bf20b5283" +checksum = "e94f17b526d0a461a191c78ea52bbce64071ed5c04c9ffe424dcb38f74171bb7" dependencies = [ "proc-macro2", "quote", - "syn 2.0.46", + "syn 2.0.53", "wasm-bindgen-backend", "wasm-bindgen-shared", ] [[package]] name = "wasm-bindgen-shared" -version = "0.2.89" +version = "0.2.92" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7ab9b36309365056cd639da3134bf87fa8f3d86008abf99e612384a6eecd459f" +checksum = "af190c94f2773fdb3729c55b007a722abb5384da03bc0986df4c289bf5567e96" [[package]] name = "web-sys" -version = "0.3.66" +version = "0.3.69" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "50c24a44ec86bb68fbecd1b3efed7e85ea5621b39b35ef2766b66cd984f8010f" +checksum = "77afa9a11836342370f4817622a2f0f418b134426d91a82dfb48f532d2ec13ef" dependencies = [ "js-sys", "wasm-bindgen", @@ -1726,15 +1760,15 @@ dependencies = [ [[package]] name = "which" -version = "5.0.0" +version = "6.0.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9bf3ea8596f3a0dd5980b46430f2058dfe2c36a27ccfbb1845d6fbfcd9ba6e14" +checksum = "7fa5e0c10bf77f44aac573e498d1a82d5fbd5e91f6fc0a99e7be4b38e85e101c" dependencies = [ "either", "home", "once_cell", "rustix", - "windows-sys 0.48.0", + "windows-sys 0.52.0", ] [[package]] @@ -1774,7 +1808,7 @@ version = "0.52.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "33ab640c8d7e35bf8ba19b884ba838ceb4fba93a4e8c65a9059d08afcfc683d9" dependencies = [ - "windows-targets 0.52.0", + "windows-targets 0.52.4", ] [[package]] @@ -1792,7 +1826,7 @@ version = "0.52.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "282be5f36a8ce781fad8c8ae18fa3f9beff57ec1b52cb3de0789201425d9a33d" dependencies = [ - "windows-targets 0.52.0", + "windows-targets 0.52.4", ] [[package]] @@ -1812,17 +1846,17 @@ dependencies = [ [[package]] name = "windows-targets" -version = "0.52.0" +version = "0.52.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8a18201040b24831fbb9e4eb208f8892e1f50a37feb53cc7ff887feb8f50e7cd" +checksum = "7dd37b7e5ab9018759f893a1952c9420d060016fc19a472b4bb20d1bdd694d1b" dependencies = [ - "windows_aarch64_gnullvm 0.52.0", - "windows_aarch64_msvc 0.52.0", - "windows_i686_gnu 0.52.0", - "windows_i686_msvc 0.52.0", - "windows_x86_64_gnu 0.52.0", - "windows_x86_64_gnullvm 0.52.0", - "windows_x86_64_msvc 0.52.0", + "windows_aarch64_gnullvm 0.52.4", + "windows_aarch64_msvc 0.52.4", + "windows_i686_gnu 0.52.4", + "windows_i686_msvc 0.52.4", + "windows_x86_64_gnu 0.52.4", + "windows_x86_64_gnullvm 0.52.4", + "windows_x86_64_msvc 0.52.4", ] [[package]] @@ -1833,9 +1867,9 @@ checksum = "2b38e32f0abccf9987a4e3079dfb67dcd799fb61361e53e2882c3cbaf0d905d8" [[package]] name = "windows_aarch64_gnullvm" -version = "0.52.0" +version = "0.52.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "cb7764e35d4db8a7921e09562a0304bf2f93e0a51bfccee0bd0bb0b666b015ea" +checksum = "bcf46cf4c365c6f2d1cc93ce535f2c8b244591df96ceee75d8e83deb70a9cac9" [[package]] name = "windows_aarch64_msvc" @@ -1845,9 +1879,9 @@ checksum = "dc35310971f3b2dbbf3f0690a219f40e2d9afcf64f9ab7cc1be722937c26b4bc" [[package]] name = "windows_aarch64_msvc" -version = "0.52.0" +version = "0.52.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "bbaa0368d4f1d2aaefc55b6fcfee13f41544ddf36801e793edbbfd7d7df075ef" +checksum = "da9f259dd3bcf6990b55bffd094c4f7235817ba4ceebde8e6d11cd0c5633b675" [[package]] name = "windows_i686_gnu" @@ -1857,9 +1891,9 @@ checksum = "a75915e7def60c94dcef72200b9a8e58e5091744960da64ec734a6c6e9b3743e" [[package]] name = "windows_i686_gnu" -version = "0.52.0" +version = "0.52.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a28637cb1fa3560a16915793afb20081aba2c92ee8af57b4d5f28e4b3e7df313" +checksum = "b474d8268f99e0995f25b9f095bc7434632601028cf86590aea5c8a5cb7801d3" [[package]] name = "windows_i686_msvc" @@ -1869,9 +1903,9 @@ checksum = "8f55c233f70c4b27f66c523580f78f1004e8b5a8b659e05a4eb49d4166cca406" [[package]] name = "windows_i686_msvc" -version = "0.52.0" +version = "0.52.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ffe5e8e31046ce6230cc7215707b816e339ff4d4d67c65dffa206fd0f7aa7b9a" +checksum = "1515e9a29e5bed743cb4415a9ecf5dfca648ce85ee42e15873c3cd8610ff8e02" [[package]] name = "windows_x86_64_gnu" @@ -1881,9 +1915,9 @@ checksum = "53d40abd2583d23e4718fddf1ebec84dbff8381c07cae67ff7768bbf19c6718e" [[package]] name = "windows_x86_64_gnu" -version = "0.52.0" +version = "0.52.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3d6fa32db2bc4a2f5abeacf2b69f7992cd09dca97498da74a151a3132c26befd" +checksum = "5eee091590e89cc02ad514ffe3ead9eb6b660aedca2183455434b93546371a03" [[package]] name = "windows_x86_64_gnullvm" @@ -1893,9 +1927,9 @@ checksum = "0b7b52767868a23d5bab768e390dc5f5c55825b6d30b86c844ff2dc7414044cc" [[package]] name = "windows_x86_64_gnullvm" -version = "0.52.0" +version = "0.52.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1a657e1e9d3f514745a572a6846d3c7aa7dbe1658c056ed9c3344c4109a6949e" +checksum = "77ca79f2451b49fa9e2af39f0747fe999fcda4f5e241b2898624dca97a1f2177" [[package]] name = "windows_x86_64_msvc" @@ -1905,9 +1939,9 @@ checksum = "ed94fce61571a4006852b7389a063ab983c02eb1bb37b47f8272ce92d06d9538" [[package]] name = "windows_x86_64_msvc" -version = "0.52.0" +version = "0.52.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "dff9641d1cd4be8d1a070daf9e3773c5f67e78b4d9d42263020c057706765c04" +checksum = "32b752e52a2da0ddfbdbcc6fceadfeede4c939ed16d13e648833a61dfb611ed8" [[package]] name = "xdg" @@ -1917,7 +1951,7 @@ checksum = "213b7324336b53d2414b2db8537e56544d981803139155afa84f76eeebb7a546" [[package]] name = "xplr" -version = "0.21.5" +version = "0.21.6" dependencies = [ "ansi-to-tui", "anyhow", @@ -1968,5 +2002,5 @@ checksum = "9ce1b18ccd8e73a9321186f97e46f9f04b778851177567b1975109d26a08d2a6" dependencies = [ "proc-macro2", "quote", - "syn 2.0.46", + "syn 2.0.53", ] diff --git a/Cargo.toml b/Cargo.toml index edf07d19..0bee35cf 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -8,7 +8,7 @@ path = './benches/criterion.rs' [package] name = 'xplr' -version = '0.21.5' +version = '0.21.6' authors = ['Arijit Basu '] edition = '2021' description = 'A hackable, minimal, fast TUI file explorer' @@ -22,29 +22,29 @@ categories = ['command-line-interface', 'command-line-utilities'] include = ['src/**/*', 'docs/en/src/**/*', 'LICENSE', 'README.md'] [dependencies] -libc = "0.2.151" +libc = "0.2.153" humansize = "2.1.3" natord = "1.0.9" -anyhow = "1.0.79" -serde_yaml = "0.9.30" +anyhow = "1.0.81" +serde_yaml = "0.9.33" crossterm = { version = "0.27.0", features = [], default-features = false } -ansi-to-tui = "3.1.0" -regex = "1.10.2" +ansi-to-tui = "4.0.1" +regex = "1.10.3" gethostname = "0.4.3" -serde_json = "1.0.110" +serde_json = "1.0.114" path-absolutize = "3.1.1" -which = "5.0.0" -nu-ansi-term = "0.49.0" +which = "6.0.0" +nu-ansi-term = "0.50.0" textwrap = "0.16" snailquote = "0.3.1" skim = { version = "0.10.4", default-features = false } -time = { version = "0.3.31", features = ["serde", "local-offset", "formatting", "macros"] } +time = { version = "0.3.34", features = ["serde", "local-offset", "formatting", "macros"] } jf = "0.6.2" xdg = "2.5.2" home = "0.5.9" [dependencies.lscolors] -version = "0.16.0" +version = "0.17.0" default-features = false features = ["nu-ansi-term"] @@ -57,22 +57,22 @@ version = "2.0.4" default-features = false [dependencies.tui] -version = "0.25.0" +version = "0.26.1" default-features = false -features = ['crossterm', 'serde', 'underline-color'] +features = ['crossterm', 'serde'] package = 'ratatui' [dependencies.serde] -version = "1.0.194" +version = "1.0.197" features = [] default-features = false [dependencies.indexmap] -version = "2.1.0" +version = "2.2.5" features = ['serde'] [dependencies.mlua] -version = "0.9.2" +version = "0.9.6" features = ['luajit', 'vendored', 'serialize', 'send'] [dependencies.tui-input] @@ -81,7 +81,7 @@ features = ['serde'] [dev-dependencies] criterion = "0.5.1" -assert_cmd = "2.0.12" +assert_cmd = "2.0.14" [profile.release] lto = true diff --git a/docs/en/src/default-key-bindings.md b/docs/en/src/default-key-bindings.md index fe09f387..dfe2fb9e 100644 --- a/docs/en/src/default-key-bindings.md +++ b/docs/en/src/default-key-bindings.md @@ -24,6 +24,7 @@ of [modes][4] and the key mappings for each mode. | ? | f1 | global help menu | | G | | go to bottom | | V | ctrl-a | select/unselect all | +| c | | copy to | | ctrl-d | | duplicate as | | ctrl-i | tab | next visited path | | ctrl-n | | next selection | @@ -40,6 +41,7 @@ of [modes][4] and the key mappings for each mode. | h | left | back | | k | up | up | | l | right | enter | +| m | | move to | | page-down | | scroll down | | page-up | | scroll up | | q | | quit | @@ -51,7 +53,7 @@ of [modes][4] and the key mappings for each mode. | ~ | | go home | | [0-9] | | input | -### duplicate_as +### go_to_path | key | remaps | action | | ----- | ------ | ---------------- | @@ -59,16 +61,37 @@ of [modes][4] and the key mappings for each mode. | f1 | | global help menu | | tab | | try complete | -### filter +### rename -| key | remaps | action | -| --------- | ------ | ---------------------------------- | -| R | | relative path does not match regex | -| backspace | | remove last filter | -| ctrl-r | | reset filters | -| ctrl-u | | clear filters | -| f1 | | global help menu | -| r | | relative path does match regex | +| key | remaps | action | +| ----- | ------ | ---------------- | +| enter | | submit | +| f1 | | global help menu | +| tab | | try complete | + +### recover + +| key | remaps | action | +| --- | ------ | ---------------- | +| f1 | | global help menu | + +### go_to + +| key | remaps | action | +| --- | ------ | ---------------- | +| f | | follow symlink | +| f1 | | global help menu | +| g | | top | +| i | | initial $PWD | +| p | | path | +| x | | open in gui | + +### relative_path_does_match_regex + +| key | remaps | action | +| ----- | ------ | ---------------- | +| enter | | submit | +| f1 | | global help menu | ### action @@ -86,23 +109,62 @@ of [modes][4] and the key mappings for each mode. | v | | vroot | | [0-9] | | go to index | -### create +### default -| key | remaps | action | -| --- | ------ | ---------------- | -| d | | create directory | -| f | | create file | -| f1 | | global help menu | +| key | remaps | action | +| --------- | ------ | ------------------- | +| ( | | prev deep branch | +| ) | | next deep branch | +| . | | show hidden | +| / | ctrl-f | search | +| : | | action | +| ? | f1 | global help menu | +| G | | go to bottom | +| V | ctrl-a | select/unselect all | +| c | | copy to | +| ctrl-d | | duplicate as | +| ctrl-i | tab | next visited path | +| ctrl-n | | next selection | +| ctrl-o | | last visited path | +| ctrl-p | | prev selection | +| ctrl-r | | refresh screen | +| ctrl-u | | clear selection | +| ctrl-w | | switch layout | +| d | | delete | +| down | j | down | +| enter | | quit with result | +| f | | filter | +| g | | go to | +| h | left | back | +| k | up | up | +| l | right | enter | +| m | | move to | +| page-down | | scroll down | +| page-up | | scroll up | +| q | | quit | +| r | | rename | +| s | | sort | +| space | v | toggle selection | +| { | | scroll up half | +| } | | scroll down half | +| ~ | | go home | +| [0-9] | | input | -### switch_layout +### debug_error -| key | remaps | action | -| --- | ------ | -------------------- | -| 1 | | default | -| 2 | | no help menu | -| 3 | | no selection panel | -| 4 | | no help or selection | -| f1 | | global help menu | +| key | remaps | action | +| ----- | ------ | ------------------- | +| enter | | open logs in editor | +| f1 | | global help menu | +| q | | quit | + +### create_directory + +| key | remaps | action | +| ----- | ------ | ---------------- | +| enter | | submit | +| f1 | | global help menu | +| tab | | try complete | ### selection_ops @@ -117,25 +179,14 @@ of [modes][4] and the key mappings for each mode. | s | | softlink here | | u | | clear selection | -### delete - -| key | remaps | action | -| --- | ------ | ---------------- | -| D | | force delete | -| d | | delete | -| f1 | | global help menu | - -### number +### relative_path_does_not_match_regex | key | remaps | action | | ----- | ------ | ---------------- | -| down | j | to down | -| enter | | to index | +| enter | | submit | | f1 | | global help menu | -| k | up | to up | -| [0-9] | | input | -### create_directory +### create_file | key | remaps | action | | ----- | ------ | ---------------- | @@ -143,20 +194,25 @@ of [modes][4] and the key mappings for each mode. | f1 | | global help menu | | tab | | try complete | -### recover +### quit + +| key | remaps | action | +| ----- | ------ | ----------------------- | +| enter | | just quit | +| f | | quit printing focus | +| f1 | | global help menu | +| p | | quit printing pwd | +| r | | quit printing result | +| s | | quit printing selection | + +### create | key | remaps | action | | --- | ------ | ---------------- | +| d | | create directory | +| f | | create file | | f1 | | global help menu | -### rename - -| key | remaps | action | -| ----- | ------ | ---------------- | -| enter | | submit | -| f1 | | global help menu | -| tab | | try complete | - ### vroot | key | remaps | action | @@ -169,43 +225,33 @@ of [modes][4] and the key mappings for each mode. | v | | toggle vroot | | ~ | | vroot $HOME | -### relative_path_does_match_regex - -| key | remaps | action | -| ----- | ------ | ---------------- | -| enter | | submit | -| f1 | | global help menu | - -### relative_path_does_not_match_regex - -| key | remaps | action | -| ----- | ------ | ---------------- | -| enter | | submit | -| f1 | | global help menu | - -### debug_error +### search -| key | remaps | action | -| ----- | ------ | ------------------- | -| enter | | open logs in editor | -| f1 | | global help menu | -| q | | quit | +| key | remaps | action | +| ------ | ------ | ----------------------- | +| ctrl-a | | toggle search algorithm | +| ctrl-f | | fuzzy search | +| ctrl-n | down | down | +| ctrl-p | up | up | +| ctrl-r | | regex search | +| ctrl-s | | sort (no search order) | +| ctrl-z | | toggle ordering | +| enter | | submit | +| esc | | cancel | +| f1 | | global help menu | +| left | | back | +| right | | enter | +| tab | | toggle selection | -### edit_permissions +### switch_layout -| key | remaps | action | -| ------ | ------ | ---------------- | -| G | | -group | -| M | | min | -| O | | -other | -| U | | -user | -| ctrl-r | | reset | -| enter | | submit | -| f1 | | global help menu | -| g | | +group | -| m | | max | -| o | | +other | -| u | | +user | +| key | remaps | action | +| --- | ------ | -------------------- | +| 1 | | default | +| 2 | | no help menu | +| 3 | | no selection panel | +| 4 | | no help or selection | +| f1 | | global help menu | ### sort @@ -232,47 +278,49 @@ of [modes][4] and the key mappings for each mode. | r | | by relative path | | s | | by size | -### go_to +### number -| key | remaps | action | -| --- | ------ | ---------------- | -| f | | follow symlink | -| f1 | | global help menu | -| g | | top | -| i | | initial $PWD | -| p | | path | -| x | | open in gui | +| key | remaps | action | +| ----- | ------ | ---------------- | +| down | j | to down | +| enter | | to index | +| f1 | | global help menu | +| k | up | to up | +| [0-9] | | input | -### quit +### copy_to -| key | remaps | action | -| ----- | ------ | ----------------------- | -| enter | | just quit | -| f | | quit printing focus | -| f1 | | global help menu | -| p | | quit printing pwd | -| r | | quit printing result | -| s | | quit printing selection | +| key | remaps | action | +| ----- | ------ | ---------------- | +| enter | | submit | +| f1 | | global help menu | +| tab | | try complete | -### search +### edit_permissions -| key | remaps | action | -| ------ | ------ | ----------------------- | -| ctrl-a | | toggle search algorithm | -| ctrl-f | | fuzzy search | -| ctrl-n | down | down | -| ctrl-p | up | up | -| ctrl-r | | regex search | -| ctrl-s | | sort (no search order) | -| ctrl-z | | toggle ordering | -| enter | | submit | -| esc | | cancel | -| f1 | | global help menu | -| left | | back | -| right | | enter | -| tab | | toggle selection | +| key | remaps | action | +| ------ | ------ | ---------------- | +| G | | -group | +| M | | min | +| O | | -other | +| U | | -user | +| ctrl-r | | reset | +| enter | | submit | +| f1 | | global help menu | +| g | | +group | +| m | | max | +| o | | +other | +| u | | +user | -### go_to_path +### delete + +| key | remaps | action | +| --- | ------ | ---------------- | +| D | | force delete | +| d | | delete | +| f1 | | global help menu | + +### move_to | key | remaps | action | | ----- | ------ | ---------------- | @@ -280,7 +328,18 @@ of [modes][4] and the key mappings for each mode. | f1 | | global help menu | | tab | | try complete | -### create_file +### filter + +| key | remaps | action | +| --------- | ------ | ---------------------------------- | +| R | | relative path does not match regex | +| backspace | | remove last filter | +| ctrl-r | | reset filters | +| ctrl-u | | clear filters | +| f1 | | global help menu | +| r | | relative path does match regex | + +### duplicate_as | key | remaps | action | | ----- | ------ | ---------------- | diff --git a/docs/en/src/modes.md b/docs/en/src/modes.md index 38d999c2..b1afe5f5 100644 --- a/docs/en/src/modes.md +++ b/docs/en/src/modes.md @@ -35,6 +35,18 @@ The builtin go to path mode. Type: [Mode](https://xplr.dev/en/mode) +#### xplr.config.modes.builtin.move_to + +The builtin move_to mode. + +Type: [Mode](https://xplr.dev/en/mode) + +#### xplr.config.modes.builtin.copy_to + +The builtin copy_to mode. + +Type: [Mode](https://xplr.dev/en/mode) + #### xplr.config.modes.builtin.selection_ops The builtin selection ops mode. diff --git a/docs/en/src/upgrade-guide.md b/docs/en/src/upgrade-guide.md index a91e2810..2ef1f3bd 100644 --- a/docs/en/src/upgrade-guide.md +++ b/docs/en/src/upgrade-guide.md @@ -45,7 +45,7 @@ compatibility. ### Instructions -#### [v0.20.2][48] -> [v0.21.5][49] +#### [v0.20.2][48] -> [v0.21.6][49] - Some plugins might stop rendering colors. Wait for them to update. - Rename `xplr.config.general.sort_and_filter_ui.search_identifier` to @@ -123,6 +123,10 @@ compatibility. messages: - NextVisitedDeepBranch (bound to `)` key) - PreviousVisitedDeepBranch (bound to `(` key) +- Since v0.21.6: + - You can use `c` and `m` keys in default mode to quickly copy + and move focused or selected files, without having to change directory. + - Use `xplr.util.debug()` to debug lua values. Thanks to @noahmayr for contributing to a major part of this release. @@ -521,5 +525,5 @@ Else do the following: [46]: https://github.com/sayanarijit/xplr/releases/tag/v0.18.0 [47]: https://github.com/sayanarijit/xplr/releases/tag/v0.19.4 [48]: https://github.com/sayanarijit/xplr/releases/tag/v0.20.2 -[49]: https://github.com/sayanarijit/xplr/releases/tag/v0.21.5 +[49]: https://github.com/sayanarijit/xplr/releases/tag/v0.21.6 [50]: https://github.com/lotabout/skim#search-syntax diff --git a/docs/en/src/xplr.util.md b/docs/en/src/xplr.util.md index 5c1684f0..fed14d0d 100644 --- a/docs/en/src/xplr.util.md +++ b/docs/en/src/xplr.util.md @@ -11,6 +11,23 @@ xplr.util.version() -- { major = 0, minor = 0, patch = 0 } ``` +### xplr.util.debug + +Print the given value to the console, and return it as a string. +Useful for debugging. + +Type: function( value ) -> string + +Example: + +```lua +xplr.util.debug({ foo = "bar", bar = function() end }) +-- { +-- ["bar"] = function: 0x55e5cebdeae0, +-- ["foo"] = "bar", +-- } +``` + ### xplr.util.clone Clone/deepcopy a Lua value. Doesn't work with functions. diff --git a/snap/snapcraft.yaml b/snap/snapcraft.yaml new file mode 100644 index 00000000..497b6e80 --- /dev/null +++ b/snap/snapcraft.yaml @@ -0,0 +1,26 @@ +name: xplr +version: git +summary: A hackable, minimal, fast TUI file explorer +description: | + xplr is a terminal UI based file explorer + that aims to increase our terminal productivity by being a flexible, + interactive orchestrator for the ever growing awesome command-line + utilities that work with the file-system. +source-code: https://github.com/sayanarijit/xplr +issues: https://github.com/sayanarijit/xplr/issues +website: https://xplr.dev/ + +base: core20 +grade: devel # must be 'stable' to release into candidate/stable channels +confinement: devmode # use 'strict' once you have the right plugs and slots + + +parts: + xplr: + plugin: rust + source: . + +apps: + xplr: + command: bin/xplr + diff --git a/src/app.rs b/src/app.rs index 1ae8dfc3..49f3b333 100644 --- a/src/app.rs +++ b/src/app.rs @@ -414,13 +414,19 @@ impl App { prompt: config.general.prompt.format.clone().unwrap_or_default(), }; + let hist = if &pwd == "/" { + pwd.clone() + } else { + format!("{0}/", &pwd) + }; + let mut app = Self { bin, version: VERSION.to_string(), config, vroot, initial_vroot, - pwd: pwd.clone(), + pwd, initial_pwd, directory_buffer: Default::default(), last_focus: Default::default(), @@ -435,7 +441,7 @@ impl App { explorer_config, logs: Default::default(), logs_hidden: Default::default(), - history: History::default().push(format!("{pwd}/")), + history: History::default().push(hist), last_modes: Default::default(), hostname, hooks, @@ -1295,7 +1301,7 @@ impl App { } pub fn scroll_up_half(mut self) -> Result { - self.msg_out.push_back(MsgOut::ScrollUp); + self.msg_out.push_back(MsgOut::ScrollUpHalf); Ok(self) } diff --git a/src/init.lua b/src/init.lua index 89d29aa7..a36ddb7b 100644 --- a/src/init.lua +++ b/src/init.lua @@ -1296,6 +1296,22 @@ xplr.config.modes.builtin.default = { "FocusPreviousSelection", }, }, + ["m"] = { + help = "move to", + messages = { + "PopMode", + { SwitchModeBuiltin = "move_to" }, + { SetInputBuffer = "" }, + }, + }, + ["c"] = { + help = "copy to", + messages = { + "PopMode", + { SwitchModeBuiltin = "copy_to" }, + { SetInputBuffer = "" }, + }, + }, }, on_number = { help = "input", @@ -1460,6 +1476,148 @@ xplr.config.modes.builtin.go_to_path = { }, } +-- The builtin move_to mode. +-- +-- Type: [Mode](https://xplr.dev/en/mode) +xplr.config.modes.builtin.move_to = { + name = "move_to", + prompt = "ð ❯ ", + key_bindings = { + on_key = { + ["enter"] = { + help = "submit", + messages = { + { + BashExec0 = [===[ + DEST="$XPLR_INPUT_BUFFER" + [ -z "$DEST" ] && exit + if [ ! -d "$DEST" ] && ! mkdir -p -- "$DEST"; then + "$XPLR" -m 'LogError: %q' "could not create $DEST" + exit + fi + "$XPLR" -m "ChangeDirectory: %q" "$DEST" + ! cd -- "$DEST" && exit + DEST="$(pwd)" && echo "PWD=$DEST" + while IFS= read -r -d '' PTH; do + PTH_ESC=$(printf %q "$PTH") + BASENAME=$(basename -- "$PTH") + BASENAME_ESC=$(printf %q "$BASENAME") + if [ -e "$BASENAME" ]; then + echo + echo "$BASENAME_ESC exists, do you want to overwrite it?" + read -p "[y]es, [n]o, [S]kip: " ANS < /dev/tty + case "$ANS" in + [yY]*) + ;; + [nN]*) + read -p "Enter new name: " BASENAME < /dev/tty + BASENAME_ESC=$(printf %q "$BASENAME") + ;; + *) + continue + ;; + esac + fi + if mv -v -- "${PTH:?}" "./${BASENAME:?}"; then + "$XPLR" -m 'LogSuccess: %q' "$PTH_ESC moved to $BASENAME_ESC" + "$XPLR" -m 'FocusPath: %q' "$BASENAME" + else + "$XPLR" -m 'LogError: %q' "could not move $PTH_ESC to $BASENAME_ESC" + fi + done < "${XPLR_PIPE_RESULT_OUT:?}" + echo + read -p "[press enter to continue]" + ]===], + }, + "PopMode", + }, + }, + ["tab"] = { + help = "try complete", + messages = { + { CallLuaSilently = "builtin.try_complete_path" }, + }, + }, + }, + default = { + messages = { + "UpdateInputBufferFromKey", + }, + }, + }, +} + +-- The builtin copy_to mode. +-- +-- Type: [Mode](https://xplr.dev/en/mode) +xplr.config.modes.builtin.copy_to = { + name = "copy_to", + prompt = "ð ❯ ", + key_bindings = { + on_key = { + ["enter"] = { + help = "submit", + messages = { + { + BashExec0 = [===[ + DEST="$XPLR_INPUT_BUFFER" + [ -z "$DEST" ] && exit + if [ ! -d "$DEST" ] && ! mkdir -p -- "$DEST"; then + "$XPLR" -m 'LogError: %q' "could not create $DEST" + exit + fi + "$XPLR" -m "ChangeDirectory: %q" "$DEST" + ! cd -- "$DEST" && exit + DEST="$(pwd)" && echo "PWD=$DEST" + while IFS= read -r -d '' PTH; do + PTH_ESC=$(printf %q "$PTH") + BASENAME=$(basename -- "$PTH") + BASENAME_ESC=$(printf %q "$BASENAME") + if [ -e "$BASENAME" ]; then + echo + echo "$BASENAME_ESC exists, do you want to overwrite it?" + read -p "[y]es, [n]o, [S]kip: " ANS < /dev/tty + case "$ANS" in + [yY]*) + ;; + [nN]*) + read -p "Enter new name: " BASENAME < /dev/tty + BASENAME_ESC=$(printf %q "$BASENAME") + ;; + *) + continue + ;; + esac + fi + if cp -vr -- "${PTH:?}" "./${BASENAME:?}"; then + "$XPLR" -m 'LogSuccess: %q' "$PTH_ESC copied to $BASENAME_ESC" + "$XPLR" -m 'FocusPath: %q' "$BASENAME" + else + "$XPLR" -m 'LogError: %q' "could not copy $PTH_ESC to $BASENAME_ESC" + fi + done < "${XPLR_PIPE_RESULT_OUT:?}" + echo + read -p "[press enter to continue]" + ]===], + }, + "PopMode", + }, + }, + ["tab"] = { + help = "try complete", + messages = { + { CallLuaSilently = "builtin.try_complete_path" }, + }, + }, + }, + default = { + messages = { + "UpdateInputBufferFromKey", + }, + }, + }, +} + -- The builtin selection ops mode. -- -- Type: [Mode](https://xplr.dev/en/mode) @@ -1531,10 +1689,10 @@ xplr.config.modes.builtin.selection_ops = { esac fi if cp -vr -- "${PTH:?}" "./${BASENAME:?}"; then - "$XPLR" -m 'LogSuccess: %q' "$PTH_ESC copied to ./$BASENAME_ESC" + "$XPLR" -m 'LogSuccess: %q' "$PTH_ESC copied to $BASENAME_ESC" "$XPLR" -m 'FocusPath: %q' "$BASENAME" else - "$XPLR" -m 'LogError: %q' "could not copy $PTH_ESC to ./$BASENAME_ESC" + "$XPLR" -m 'LogError: %q' "could not copy $PTH_ESC to $BASENAME_ESC" fi done < "${XPLR_PIPE_SELECTION_OUT:?}" echo @@ -1571,10 +1729,10 @@ xplr.config.modes.builtin.selection_ops = { esac fi if mv -v -- "${PTH:?}" "./${BASENAME:?}"; then - "$XPLR" -m 'LogSuccess: %q' "$PTH_ESC moved to ./$BASENAME_ESC" + "$XPLR" -m 'LogSuccess: %q' "$PTH_ESC moved to $BASENAME_ESC" "$XPLR" -m 'FocusPath: %q' "$BASENAME" else - "$XPLR" -m 'LogError: %q' "could not move $PTH_ESC to ./$BASENAME_ESC" + "$XPLR" -m 'LogError: %q' "could not move $PTH_ESC to $BASENAME_ESC" fi done < "${XPLR_PIPE_SELECTION_OUT:?}" echo @@ -1611,10 +1769,10 @@ xplr.config.modes.builtin.selection_ops = { esac fi if ln -sv -- "${PTH:?}" "./${BASENAME:?}"; then - "$XPLR" -m 'LogSuccess: %q' "$PTH_ESC softlinked as ./$BASENAME_ESC" + "$XPLR" -m 'LogSuccess: %q' "$PTH_ESC softlinked as $BASENAME_ESC" "$XPLR" -m 'FocusPath: %q' "$BASENAME" else - "$XPLR" -m 'LogError: %q' "could not softlink $PTH_ESC as ./$BASENAME_ESC" + "$XPLR" -m 'LogError: %q' "could not softlink $PTH_ESC as $BASENAME_ESC" fi done < "${XPLR_PIPE_SELECTION_OUT:?}" echo @@ -1651,10 +1809,10 @@ xplr.config.modes.builtin.selection_ops = { esac fi if ln -v -- "${PTH:?}" "./${BASENAME:?}"; then - "$XPLR" -m 'LogSuccess: %q' "$PTH_ESC hardlinked as ./$BASENAME_ESC" + "$XPLR" -m 'LogSuccess: %q' "$PTH_ESC hardlinked as $BASENAME_ESC" "$XPLR" -m 'FocusPath: %q' "$BASENAME" else - "$XPLR" -m 'LogError: %q' "could not hardlink $PTH_ESC as ./$BASENAME_ESC" + "$XPLR" -m 'LogError: %q' "could not hardlink $PTH_ESC as $BASENAME_ESC" fi done < "${XPLR_PIPE_SELECTION_OUT:?}" echo diff --git a/src/lua/mod.rs b/src/lua/mod.rs index 6bd08237..9dd827fb 100644 --- a/src/lua/mod.rs +++ b/src/lua/mod.rs @@ -160,24 +160,24 @@ mod tests { assert!(check_version(VERSION, "foo path").is_ok()); // Current release if OK - assert!(check_version("0.21.5", "foo path").is_ok()); + assert!(check_version("0.21.6", "foo path").is_ok()); // Prev major release is ERR // - Not yet // Prev minor release is ERR (Change when we get to v1) - assert!(check_version("0.20.5", "foo path").is_err()); + assert!(check_version("0.20.6", "foo path").is_err()); // Prev bugfix release is OK - assert!(check_version("0.21.4", "foo path").is_ok()); + assert!(check_version("0.21.5", "foo path").is_ok()); // Next major release is ERR - assert!(check_version("1.20.5", "foo path").is_err()); + assert!(check_version("1.20.6", "foo path").is_err()); // Next minor release is ERR - assert!(check_version("0.22.5", "foo path").is_err()); + assert!(check_version("0.22.6", "foo path").is_err()); // Next bugfix release is ERR (Change when we get to v1) - assert!(check_version("0.21.6", "foo path").is_err()); + assert!(check_version("0.21.7", "foo path").is_err()); } } diff --git a/src/lua/util.rs b/src/lua/util.rs index 21d8ce75..da01f3cb 100644 --- a/src/lua/util.rs +++ b/src/lua/util.rs @@ -13,6 +13,7 @@ use crate::ui::Layout; use crate::ui::Style; use crate::ui::WrapOptions; use anyhow::Result; +use lazy_static::lazy_static; use lscolors::LsColors; use mlua::Error as LuaError; use mlua::Lua; @@ -28,6 +29,10 @@ use std::borrow::Cow; use std::path::PathBuf; use std::process::Command; +lazy_static! { + static ref LS_COLORS: LsColors = LsColors::from_env().unwrap_or_default(); +} + /// Get the xplr version details. /// /// Type: function() -> { major: number, minor: number, patch: number } @@ -64,6 +69,30 @@ pub fn version<'a>(util: Table<'a>, lua: &Lua) -> Result> { Ok(util) } +/// Print the given value to the console, and return it as a string. +/// Useful for debugging. +/// +/// Type: function( value ) -> string +/// +/// Example: +/// +/// ```lua +/// xplr.util.debug({ foo = "bar", bar = function() end }) +/// -- { +/// -- ["bar"] = function: 0x55e5cebdeae0, +/// -- ["foo"] = "bar", +/// -- } +/// ``` +pub fn debug<'a>(util: Table<'a>, lua: &Lua) -> Result> { + let func = lua.create_function(|_, value: Value| { + let log = format!("{:#?}", value); + println!("{}", log); + Ok(log) + })?; + util.set("debug", func)?; + Ok(util) +} + /// Clone/deepcopy a Lua value. Doesn't work with functions. /// /// Type: function( value ) -> value @@ -634,9 +663,8 @@ pub fn to_yaml<'a>(util: Table<'a>, lua: &Lua) -> Result> { /// -- { fg = "Red", bg = nil, add_modifiers = {}, sub_modifiers = {} } /// ``` pub fn lscolor<'a>(util: Table<'a>, lua: &Lua) -> Result> { - let lscolors = LsColors::from_env().unwrap_or_default(); let func = lua.create_function(move |lua, path: String| { - let style = lscolors.style_for_path(path).map(Style::from); + let style = LS_COLORS.style_for_path(path).map(Style::from); lua::serialize(lua, &style).map_err(LuaError::custom) })?; util.set("lscolor", func)?; @@ -838,6 +866,7 @@ pub(crate) fn create_table(lua: &Lua) -> Result { let mut util = lua.create_table()?; util = version(util, lua)?; + util = debug(util, lua)?; util = clone(util, lua)?; util = exists(util, lua)?; util = is_dir(util, lua)?; diff --git a/src/ui.rs b/src/ui.rs index ba7ecb3c..0d3dda03 100644 --- a/src/ui.rs +++ b/src/ui.rs @@ -18,7 +18,7 @@ use std::ops::BitXor; use time::macros::format_description; use tui::layout::Rect as TuiRect; use tui::layout::{Constraint as TuiConstraint, Direction, Layout as TuiLayout}; -use tui::style::{Color, Modifier as TuiModifier, Style as TuiStyle}; +use tui::style::{Color as TuiColor, Modifier as TuiModifier, Style as TuiStyle}; use tui::text::{Line, Span, Text}; use tui::widgets::{ Block, BorderType as TuiBorderType, Borders as TuiBorders, Cell, List, ListItem, @@ -26,9 +26,10 @@ use tui::widgets::{ }; use tui::Frame; +const DEFAULT_STYLE: TuiStyle = TuiStyle::new(); + lazy_static! { pub static ref NO_COLOR: bool = env::var("NO_COLOR").is_ok(); - pub static ref DEFAULT_STYLE: TuiStyle = TuiStyle::default(); } fn read_only_indicator(app: &app::App) -> &str { @@ -297,6 +298,59 @@ fn extend_optional_modifiers( } } +// raratui doesn't support directly serializing `Color::Rgb` and +// `Color::Indexed` anymore. +// See https://github.com/ratatui-org/ratatui/pull/934 +#[derive(Debug, Default, Clone, Copy, Eq, PartialEq, Hash, Serialize, Deserialize)] +pub enum Color { + #[default] + Reset, + Black, + Red, + Green, + Yellow, + Blue, + Magenta, + Cyan, + Gray, + DarkGray, + LightRed, + LightGreen, + LightYellow, + LightBlue, + LightMagenta, + LightCyan, + White, + Rgb(u8, u8, u8), + Indexed(u8), +} + +impl From for TuiColor { + fn from(value: Color) -> Self { + match value { + Color::Reset => TuiColor::Reset, + Color::Black => TuiColor::Black, + Color::Red => TuiColor::Red, + Color::Green => TuiColor::Green, + Color::Yellow => TuiColor::Yellow, + Color::Blue => TuiColor::Blue, + Color::Magenta => TuiColor::Magenta, + Color::Cyan => TuiColor::Cyan, + Color::Gray => TuiColor::Gray, + Color::DarkGray => TuiColor::DarkGray, + Color::LightRed => TuiColor::LightRed, + Color::LightGreen => TuiColor::LightGreen, + Color::LightYellow => TuiColor::LightYellow, + Color::LightBlue => TuiColor::LightBlue, + Color::LightMagenta => TuiColor::LightMagenta, + Color::LightCyan => TuiColor::LightCyan, + Color::White => TuiColor::White, + Color::Rgb(r, g, b) => TuiColor::Rgb(r, g, b), + Color::Indexed(index) => TuiColor::Indexed(index), + } + } +} + #[derive(Debug, PartialEq, Eq, Clone, Default, Serialize, Deserialize)] #[serde(deny_unknown_fields)] pub struct Style { @@ -322,8 +376,8 @@ impl Style { } } -impl Into for Style { - fn into(self) -> TuiStyle { +impl From