diff options
author | EuAndreh <eu@euandre.org> | 2021-01-26 20:09:56 -0300 |
---|---|---|
committer | EuAndreh <eu@euandre.org> | 2021-01-26 20:17:35 -0300 |
commit | 60d3a43236ae356fb8b7b329b80ed78845bd6168 (patch) | |
tree | 7cdb330f5e73f450cf8e7e3c52f9e6b1d1f7de13 | |
parent | with-container.sh: Update path to Guix files (diff) | |
download | euandre.org-60d3a43236ae356fb8b7b329b80ed78845bd6168.tar.gz euandre.org-60d3a43236ae356fb8b7b329b80ed78845bd6168.tar.xz |
Add article on "remembergin" utility
7 files changed, 1063 insertions, 0 deletions
@@ -1,5 +1,8 @@ # Tasks +## TODO Update "remembering" link {#task-b60b2559-e1e1-4f60-8e20-b919ebf1da43} +- TODO in 2021-01-26 + ## TODO Move to LilyPond 2.22.0 {#task-34d239aa-8984-4b34-9c6e-1cc2ca8d49fc} - TODO in 2021-01-12 diff --git a/_articles/2021-01-26-ann-remembering-add-memory-to-dmenu-fzf-and-similar-tools.md b/_articles/2021-01-26-ann-remembering-add-memory-to-dmenu-fzf-and-similar-tools.md new file mode 100644 index 0000000..47263d1 --- /dev/null +++ b/_articles/2021-01-26-ann-remembering-add-memory-to-dmenu-fzf-and-similar-tools.md @@ -0,0 +1,191 @@ +--- + +title: "ANN: remembering - Add memory to dmenu, fzf and similar tools" + +date: 2021-01-26 + +layout: post + +lang: en + +ref: ann-remembering-add-memory-to-dmenu-fzf-and-similar-tools + +--- + +Today I pushed v0.1.0 of [remembering][remembering], a tool to enhance the interactive usability of menu-like tools, such as [dmenu][dmenu] and [fzf][fzf]. + +## Previous solution + +I previously used [yeganesh][yeganesh] fill this gap, but as I started to rely less on Emacs, I added fzf as my go-to tool for doing fuzzy searching on the terminal. +But I didn't like that fzf always showed the same order of things, when I would only need 3 or 4 commonly used files. + +For those who don't know: yeganesh is a wrapper around dmenu that will remember your most used programs and put them on the beginning of the list of executables. +This is very convenient for interactive prolonged use, as with time the things you usually want are right at the very beginning. + +But now I had this thing, yeganesh, that solved this problem for dmenu, but didn't for fzf. + +I initially considered patching yeganesh to support it, but I found it more coupled to dmenu than I would desire. +I'd rather have something that knows nothing about dmenu, fzf or anything, but enhances tools like those in a useful way. + +[remembering]: https://git.euandreh.xyz/remembering/about/ +<!-- [remembering]: https://remembering.euandreh.xyz --> +[dmenu]: https://tools.suckless.org/dmenu/ +[fzf]: https://github.com/junegunn/fzf +[yeganesh]: http://dmwit.com/yeganesh/ + +## Implementation + +Other than being decoupled from dmenu, another improvement I though that could be made on top of yeganesh is the programming language choice. +Instead of Haskell, I went with POSIX sh. +Sticking to POSIX sh makes it require less build-time dependencies. There aren't any, actually. Packaging is made much easier due to that. + +The good thing is that the program itself is small enough ([119 lines][119-lines] on v0.1.0) that POSIX sh does the job just fine, combined with other POSIX utilities such as [getopts][getopts], [sort][sort] and [awk][awk]. + +[119-lines]: https://git.euandreh.xyz/remembering/tree/remembering?id=v0.1.0 +[getopts]: http://www.opengroup.org/onlinepubs/9699919799/utilities/getopts.html +[sort]: http://www.opengroup.org/onlinepubs/9699919799/utilities/sort.html +[awk]: http://www.opengroup.org/onlinepubs/9699919799/utilities/awk.html + +The behaviour is: given a program that will read from STDIN and write a single entry to STDOUT, `remembering` wraps that program, and rearranges STDIN so that previous choices appear at the beginning. + +Where you would do: + +```shell +$ seq 5 | fzf + + 5 + 4 + 3 + 2 +> 1 + 5/5 +> +``` + +And every time get the same order of numbers, now you can write: + +```shell +$ seq 5 | remembering -p seq-fzf -c fzf + + 5 + 4 + 3 + 2 +> 1 + 5/5 +> +``` + +On the first run, everything is the same. If you picked 4 on the previous example, the following run would be different: + +```shell +$ seq 5 | remembering -p seq-fzf -c fzf + + 5 + 3 + 2 + 1 +> 4 + 5/5 +> +``` + +As time passes, the list would adjust based on the frequency of your choices. + +I aimed for reusability, so that I could wrap diverse commands with `remembering` and it would be able to work. To accomplish that, a "profile" (the `-p something` part) stores data about different runs separately. + +I took the idea of building something small with few dependencies to other places too: +- the man pages are written in troff directly; +- the tests are just more POSIX sh files; +- and a POSIX Makefile to `check` and `install`. + +I was aware of the value of sticking to coding to standards, but I had past experience mostly with programming language standards, such as ECMAScript, Common Lisp, Scheme, or with IndexedDB or DOM APIs. +It felt good to rediscover these nice POSIX tools, which makes me remember of a quote by [Henry Spencer][poor-unix]: + +> Those who do not understand Unix are condemned to reinvent it, poorly. + +[poor-unix]: https://en.wikipedia.org/wiki/Henry_Spencer#cite_note-3 + +## Usage examples + +Here are some functions I wrote myself that you may find useful: + +### Run a command with fzf on `$PWD` + +```shellcheck +f() { + profile="$f-shell-function(pwd | sed -e 's_/_-_g')" + file="$(git ls-files | \ + remembering -p "$profile" \ + -c "fzf --select-1 --exit -0 --query \"$2\" --preview 'cat {}'")" + if [ -n "$file" ]; then + # shellcheck disable=2068 + history -s f $@ + history -s "$1" "$file" + "$1" "$file" +fi +} +``` + +This way I can run `f vi` or `f vi config` at the root of a repository, and the list of files will always appear on the most used order. +Adding `pwd` to the profile allows it to not mix data for different repositories. + +### Copy password to clipboard + +```shell +choice="$(find "$HOME/.password-store" -type f | \ + grep -Ev '(.git|.gpg-id)' | \ + sed -e "s|$HOME/.password-store/||" -e 's/\.gpg$//' | \ + remembering -p password-store \ + -c 'dmenu -l 20 -i')" + + +if [ -n "$choice" ]; then + pass show "$choice" -c +fi +``` + +Adding the above to a file and binding it to a keyboard shortcut, I can access the contents of my [password store][password-store], with the entries ordered by usage. + +[password-store]: https://www.passwordstore.org/ + +### Replacing yeganesh + +Where I previously had: + +```shell +exe=$(yeganesh -x) && exec $exe +``` + +Now I have: + +```shell +exe=$(dmenu_path | remembering -p dmenu-exec -c dmenu) && exec $exe +``` + +This way, the executables appear on order of usage. + +If you don't have `dmenu_path`, you can get just the underlying `stest` tool that looks at the executables available in your `$PATH`. Here's a juicy one-liner to do it: + +```shell +$ wget -O- https://dl.suckless.org/tools/dmenu-5.0.tar.gz | \ + tar Ozxf - dmenu-5.0/arg.h dmenu-5.0/stest.c | \ + sed 's|^#include "arg.h"$|// #include "arg.h"|' | \ + cc -xc - -o stest +``` + +With the `stest` utility you'll be able to list executables in your `$PATH` and pipe them to dmenu or something else yourself: +```shell +$ (IFS=:; ./stest -flx $PATH;) | sort -u | remembering -p another-dmenu-exec -c dmenu | sh +``` + +In fact, the code for `dmenu_path` is almost just like that. + +## Conclusion + +For my personal use, I've packaged `remembering` for [GNU Guix][guix-channel] and [Nix][nix-file]. Packaging it to any other distribution should be trivial, or just downloading the tarball and running `[sudo] make install`. + +Patches welcome! + +[guix-channel]: https://git.euandreh.xyz/euandreh-guix-channel/about/ +[nix-file]: https://git.euandreh.xyz/dotfiles/tree/nixos/not-on-nixpkgs/remembering.nix?id=0831444f745cf908e940407c3e00a61f6152961f diff --git a/build-aux/spelling/en.txt b/build-aux/spelling/en.txt index aff474d..d54b934 100644 --- a/build-aux/spelling/en.txt +++ b/build-aux/spelling/en.txt @@ -52,6 +52,7 @@ realising reimplementation repo reproducibility +reusability sandboxed scriptable shouldn diff --git a/build-aux/spelling/international.txt b/build-aux/spelling/international.txt index b8a8c27..d87507e 100644 --- a/build-aux/spelling/international.txt +++ b/build-aux/spelling/international.txt @@ -10,6 +10,7 @@ ABloibce AGPLv AGPLv3 +APIs Agustín AliceBob André @@ -37,6 +38,7 @@ Clojure CoreData CouchDB DIY +DOM DVCS Datomic Dengoso @@ -82,6 +84,7 @@ LilyPond LiquidHaskell MTA Mailutils +Makefile Marcha Marinheiros Matroska @@ -117,6 +120,8 @@ SA SMTP SSD SSMTP +STDIN +STDOUT SVG Saudade Screencast @@ -147,6 +152,7 @@ YouTube Zig apk automerge +awk bindgen blockchain boneco @@ -167,6 +173,7 @@ datom datoms divoplade dl +dmenu dos e earned @@ -176,14 +183,17 @@ eo euandre euandreh eval +executables favicon ffi fi fr frontend +fzf gPodder gcrypt ge +getopts gt guix guixbuild @@ -240,12 +250,15 @@ systemd só torrent touchpad +troff txt +v0 v8 vlog webtorrent www xp xyz +yeganesh youtube à diff --git a/locale/eo/LC_MESSAGES/_articles/2021-01-26-ann-remembering-add-memory-to-dmenu-fzf-and-similar-tools.po b/locale/eo/LC_MESSAGES/_articles/2021-01-26-ann-remembering-add-memory-to-dmenu-fzf-and-similar-tools.po new file mode 100644 index 0000000..a911db1 --- /dev/null +++ b/locale/eo/LC_MESSAGES/_articles/2021-01-26-ann-remembering-add-memory-to-dmenu-fzf-and-similar-tools.po @@ -0,0 +1,285 @@ +# +msgid "" +msgstr "" + +msgid "title: \"ANN: remembering - Add memory to dmenu, fzf and similar tools\"" +msgstr "" + +msgid "date: 2021-01-26" +msgstr "" + +msgid "layout: post" +msgstr "" + +msgid "lang: en" +msgstr "" + +msgid "ref: ann-remembering-add-memory-to-dmenu-fzf-and-similar-tools" +msgstr "" + +msgid "Previous solution" +msgstr "" + +msgid "" +"I previously used [yeganesh](http://dmwit.com/yeganesh/) fill this gap, but " +"as I started to rely less on Emacs, I added fzf as my go-to tool for doing " +"fuzzy searching on the terminal. But I didn't like that fzf always showed " +"the same order of things, when I would only need 3 or 4 commonly used files." +msgstr "" + +msgid "" +"For those who don't know: yeganesh is a wrapper around dmenu that will " +"remember your most used programs and put them on the beginning of the list " +"of executables. This is very convenient for interactive prolonged use, as " +"with time the things you usually want are right at the very beginning." +msgstr "" + +msgid "" +"But now I had this thing, yeganesh, that solved this problem for dmenu, but " +"didn't for fzf." +msgstr "" + +msgid "" +"I initially considered patching yeganesh to support it, but I found it more " +"coupled to dmenu than I would desire. I'd rather have something that knows " +"nothing about dmenu, fzf or anything, but enhances tools like those in a " +"useful way." +msgstr "" + +msgid "Implementation" +msgstr "" + +msgid "" +"Other than being decoupled from dmenu, another improvement I though that " +"could be made on top of yeganesh is the programming language choice. Instead" +" of Haskell, I went with POSIX sh. Sticking to POSIX sh makes it require " +"less build-time dependencies. There aren't any, actually. Packaging is made " +"much easier due to that." +msgstr "" + +msgid "" +"The good thing is that the program itself is small enough ([119 " +"lines](https://git.euandreh.xyz/remembering/tree/remembering?id=v0.1.0) on " +"v0.1.0) that POSIX sh does the job just fine, combined with other POSIX " +"utilities such as " +"[getopts](http://www.opengroup.org/onlinepubs/9699919799/utilities/getopts.html)," +" [sort](http://www.opengroup.org/onlinepubs/9699919799/utilities/sort.html) " +"and " +"[awk](http://www.opengroup.org/onlinepubs/9699919799/utilities/awk.html)." +msgstr "" + +msgid "" +"The behaviour is: given a program that will read from STDIN and write a " +"single entry to STDOUT, `remembering` wraps that program, and rearranges " +"STDIN so that previous choices appear at the beginning." +msgstr "" + +msgid "Where you would do:" +msgstr "" + +msgid "" +"$ seq 5 | fzf\n" +"\n" +" 5\n" +" 4\n" +" 3\n" +" 2\n" +"> 1\n" +" 5/5\n" +">\n" +msgstr "" + +msgid "And every time get the same order of numbers, now you can write:" +msgstr "" + +msgid "" +"$ seq 5 | remembering -p seq-fzf -c fzf\n" +"\n" +" 5\n" +" 4\n" +" 3\n" +" 2\n" +"> 1\n" +" 5/5\n" +">\n" +msgstr "" + +msgid "" +"On the first run, everything is the same. If you picked 4 on the previous " +"example, the following run would be different:" +msgstr "" + +msgid "" +"$ seq 5 | remembering -p seq-fzf -c fzf\n" +"\n" +" 5\n" +" 3\n" +" 2\n" +" 1\n" +"> 4\n" +" 5/5\n" +">\n" +msgstr "" + +msgid "" +"As time passes, the list would adjust based on the frequency of your " +"choices." +msgstr "" + +msgid "" +"I aimed for reusability, so that I could wrap diverse commands with " +"`remembering` and it would be able to work. To accomplish that, a " +"\"profile\" (the `-p something` part) stores data about different runs " +"separately." +msgstr "" + +msgid "" +"I took the idea of building something small with few dependencies to other " +"places too:" +msgstr "" + +msgid "the man pages are written in troff directly;" +msgstr "" + +msgid "the tests are just more POSIX sh files;" +msgstr "" + +msgid "and a POSIX Makefile to `check` and `install`." +msgstr "" + +msgid "" +"I was aware of the value of sticking to coding to standards, but I had past " +"experience mostly with programming language standards, such as ECMAScript, " +"Common Lisp, Scheme, or with IndexedDB or DOM APIs. It felt good to " +"rediscover these nice POSIX tools, which makes me remember of a quote by " +"[Henry Spencer](https://en.wikipedia.org/wiki/Henry_Spencer#cite_note-3):" +msgstr "" + +msgid "Those who do not understand Unix are condemned to reinvent it, poorly." +msgstr "" + +msgid "Usage examples" +msgstr "" + +msgid "Here are some functions I wrote myself that you may find useful:" +msgstr "" + +msgid "Run a command with fzf on `$PWD`" +msgstr "" + +msgid "" +"f() {\n" +" profile=\"$f-shell-function(pwd | sed -e 's_/_-_g')\"\n" +" file=\"$(git ls-files | \\\n" +" remembering -p \"$profile\" \\\n" +" -c \"fzf --select-1 --exit -0 --query \\\"$2\\\" --preview 'cat {}'\")\"\n" +" if [ -n \"$file\" ]; then\n" +" # shellcheck disable=2068\n" +" history -s f $@\n" +" history -s \"$1\" \"$file\"\n" +" \"$1\" \"$file\"\n" +"fi\n" +"}\n" +msgstr "" + +msgid "" +"This way I can run `f vi` or `f vi config` at the root of a repository, and " +"the list of files will always appear on the most used order. Adding `pwd` to" +" the profile allows it to not mix data for different repositories." +msgstr "" + +msgid "Copy password to clipboard" +msgstr "" + +msgid "" +"choice=\"$(find \"$HOME/.password-store\" -type f | \\\n" +" grep -Ev '(.git|.gpg-id)' | \\\n" +" sed -e \"s|$HOME/.password-store/||\" -e 's/\\.gpg$//' | \\\n" +" remembering -p password-store \\\n" +" -c 'dmenu -l 20 -i')\"\n" +"\n" +"\n" +"if [ -n \"$choice\" ]; then\n" +" pass show \"$choice\" -c\n" +"fi\n" +msgstr "" + +msgid "" +"Adding the above to a file and binding it to a keyboard shortcut, I can " +"access the contents of my [password store](https://www.passwordstore.org/), " +"with the entries ordered by usage." +msgstr "" + +msgid "Replacing yeganesh" +msgstr "" + +msgid "Where I previously had:" +msgstr "" + +msgid "exe=$(yeganesh -x) && exec $exe\n" +msgstr "" + +msgid "Now I have:" +msgstr "" + +msgid "exe=$(dmenu_path | remembering -p dmenu-exec -c dmenu) && exec $exe\n" +msgstr "" + +msgid "This way, the executables appear on order of usage." +msgstr "" + +msgid "" +"If you don't have `dmenu_path`, you can get just the underlying `stest` tool" +" that looks at the executables available in your `$PATH`. Here's a juicy " +"one-liner to do it:" +msgstr "" + +msgid "" +"$ wget -O- https://dl.suckless.org/tools/dmenu-5.0.tar.gz | \\\n" +" tar Ozxf - dmenu-5.0/arg.h dmenu-5.0/stest.c | \\\n" +" sed 's|^#include \"arg.h\"$|// #include \"arg.h\"|' | \\\n" +" cc -xc - -o stest\n" +msgstr "" + +msgid "" +"With the `stest` utility you'll be able to list executables in your `$PATH` " +"and pipe them to dmenu or something else yourself:" +msgstr "" + +msgid "" +"$ (IFS=:; ./stest -flx $PATH;) | sort -u | remembering -p another-dmenu-exec" +" -c dmenu | sh\n" +msgstr "" + +msgid "In fact, the code for `dmenu_path` is almost just like that." +msgstr "" + +msgid "Conclusion" +msgstr "" + +msgid "" +"For my personal use, I've packaged `remembering` for [GNU " +"Guix](https://git.euandreh.xyz/euandreh-guix-channel/about/) and " +"[Nix](https://git.euandreh.xyz/dotfiles/tree/nixos/not-on-" +"nixpkgs/remembering.nix?id=0831444f745cf908e940407c3e00a61f6152961f). " +"Packaging it to any other distribution should be trivial, or just " +"downloading the tarball and running `[sudo] make install`." +msgstr "" + +msgid "Patches welcome!" +msgstr "" + +msgid "" +"Today I pushed v0.1.0 of " +"[remembering](https://git.euandreh.xyz/remembering/about/), a tool to " +"enhance the interactive usability of menu-like tools, such as " +"[dmenu](https://tools.suckless.org/dmenu/) and " +"[fzf](https://github.com/junegunn/fzf)." +msgstr "" + +#~ msgid "" +#~ "Today I pushed v0.1.0 of [remembering](https://remembering.euandreh.xyz), a " +#~ "tool to enhance the interactive usability of menu-like tools, such as " +#~ "[dmenu](https://tools.suckless.org/dmenu/) and " +#~ "[fzf](https://github.com/junegunn/fzf)." +#~ msgstr "" diff --git a/locale/fr/LC_MESSAGES/_articles/2021-01-26-ann-remembering-add-memory-to-dmenu-fzf-and-similar-tools.po b/locale/fr/LC_MESSAGES/_articles/2021-01-26-ann-remembering-add-memory-to-dmenu-fzf-and-similar-tools.po new file mode 100644 index 0000000..a911db1 --- /dev/null +++ b/locale/fr/LC_MESSAGES/_articles/2021-01-26-ann-remembering-add-memory-to-dmenu-fzf-and-similar-tools.po @@ -0,0 +1,285 @@ +# +msgid "" +msgstr "" + +msgid "title: \"ANN: remembering - Add memory to dmenu, fzf and similar tools\"" +msgstr "" + +msgid "date: 2021-01-26" +msgstr "" + +msgid "layout: post" +msgstr "" + +msgid "lang: en" +msgstr "" + +msgid "ref: ann-remembering-add-memory-to-dmenu-fzf-and-similar-tools" +msgstr "" + +msgid "Previous solution" +msgstr "" + +msgid "" +"I previously used [yeganesh](http://dmwit.com/yeganesh/) fill this gap, but " +"as I started to rely less on Emacs, I added fzf as my go-to tool for doing " +"fuzzy searching on the terminal. But I didn't like that fzf always showed " +"the same order of things, when I would only need 3 or 4 commonly used files." +msgstr "" + +msgid "" +"For those who don't know: yeganesh is a wrapper around dmenu that will " +"remember your most used programs and put them on the beginning of the list " +"of executables. This is very convenient for interactive prolonged use, as " +"with time the things you usually want are right at the very beginning." +msgstr "" + +msgid "" +"But now I had this thing, yeganesh, that solved this problem for dmenu, but " +"didn't for fzf." +msgstr "" + +msgid "" +"I initially considered patching yeganesh to support it, but I found it more " +"coupled to dmenu than I would desire. I'd rather have something that knows " +"nothing about dmenu, fzf or anything, but enhances tools like those in a " +"useful way." +msgstr "" + +msgid "Implementation" +msgstr "" + +msgid "" +"Other than being decoupled from dmenu, another improvement I though that " +"could be made on top of yeganesh is the programming language choice. Instead" +" of Haskell, I went with POSIX sh. Sticking to POSIX sh makes it require " +"less build-time dependencies. There aren't any, actually. Packaging is made " +"much easier due to that." +msgstr "" + +msgid "" +"The good thing is that the program itself is small enough ([119 " +"lines](https://git.euandreh.xyz/remembering/tree/remembering?id=v0.1.0) on " +"v0.1.0) that POSIX sh does the job just fine, combined with other POSIX " +"utilities such as " +"[getopts](http://www.opengroup.org/onlinepubs/9699919799/utilities/getopts.html)," +" [sort](http://www.opengroup.org/onlinepubs/9699919799/utilities/sort.html) " +"and " +"[awk](http://www.opengroup.org/onlinepubs/9699919799/utilities/awk.html)." +msgstr "" + +msgid "" +"The behaviour is: given a program that will read from STDIN and write a " +"single entry to STDOUT, `remembering` wraps that program, and rearranges " +"STDIN so that previous choices appear at the beginning." +msgstr "" + +msgid "Where you would do:" +msgstr "" + +msgid "" +"$ seq 5 | fzf\n" +"\n" +" 5\n" +" 4\n" +" 3\n" +" 2\n" +"> 1\n" +" 5/5\n" +">\n" +msgstr "" + +msgid "And every time get the same order of numbers, now you can write:" +msgstr "" + +msgid "" +"$ seq 5 | remembering -p seq-fzf -c fzf\n" +"\n" +" 5\n" +" 4\n" +" 3\n" +" 2\n" +"> 1\n" +" 5/5\n" +">\n" +msgstr "" + +msgid "" +"On the first run, everything is the same. If you picked 4 on the previous " +"example, the following run would be different:" +msgstr "" + +msgid "" +"$ seq 5 | remembering -p seq-fzf -c fzf\n" +"\n" +" 5\n" +" 3\n" +" 2\n" +" 1\n" +"> 4\n" +" 5/5\n" +">\n" +msgstr "" + +msgid "" +"As time passes, the list would adjust based on the frequency of your " +"choices." +msgstr "" + +msgid "" +"I aimed for reusability, so that I could wrap diverse commands with " +"`remembering` and it would be able to work. To accomplish that, a " +"\"profile\" (the `-p something` part) stores data about different runs " +"separately." +msgstr "" + +msgid "" +"I took the idea of building something small with few dependencies to other " +"places too:" +msgstr "" + +msgid "the man pages are written in troff directly;" +msgstr "" + +msgid "the tests are just more POSIX sh files;" +msgstr "" + +msgid "and a POSIX Makefile to `check` and `install`." +msgstr "" + +msgid "" +"I was aware of the value of sticking to coding to standards, but I had past " +"experience mostly with programming language standards, such as ECMAScript, " +"Common Lisp, Scheme, or with IndexedDB or DOM APIs. It felt good to " +"rediscover these nice POSIX tools, which makes me remember of a quote by " +"[Henry Spencer](https://en.wikipedia.org/wiki/Henry_Spencer#cite_note-3):" +msgstr "" + +msgid "Those who do not understand Unix are condemned to reinvent it, poorly." +msgstr "" + +msgid "Usage examples" +msgstr "" + +msgid "Here are some functions I wrote myself that you may find useful:" +msgstr "" + +msgid "Run a command with fzf on `$PWD`" +msgstr "" + +msgid "" +"f() {\n" +" profile=\"$f-shell-function(pwd | sed -e 's_/_-_g')\"\n" +" file=\"$(git ls-files | \\\n" +" remembering -p \"$profile\" \\\n" +" -c \"fzf --select-1 --exit -0 --query \\\"$2\\\" --preview 'cat {}'\")\"\n" +" if [ -n \"$file\" ]; then\n" +" # shellcheck disable=2068\n" +" history -s f $@\n" +" history -s \"$1\" \"$file\"\n" +" \"$1\" \"$file\"\n" +"fi\n" +"}\n" +msgstr "" + +msgid "" +"This way I can run `f vi` or `f vi config` at the root of a repository, and " +"the list of files will always appear on the most used order. Adding `pwd` to" +" the profile allows it to not mix data for different repositories." +msgstr "" + +msgid "Copy password to clipboard" +msgstr "" + +msgid "" +"choice=\"$(find \"$HOME/.password-store\" -type f | \\\n" +" grep -Ev '(.git|.gpg-id)' | \\\n" +" sed -e \"s|$HOME/.password-store/||\" -e 's/\\.gpg$//' | \\\n" +" remembering -p password-store \\\n" +" -c 'dmenu -l 20 -i')\"\n" +"\n" +"\n" +"if [ -n \"$choice\" ]; then\n" +" pass show \"$choice\" -c\n" +"fi\n" +msgstr "" + +msgid "" +"Adding the above to a file and binding it to a keyboard shortcut, I can " +"access the contents of my [password store](https://www.passwordstore.org/), " +"with the entries ordered by usage." +msgstr "" + +msgid "Replacing yeganesh" +msgstr "" + +msgid "Where I previously had:" +msgstr "" + +msgid "exe=$(yeganesh -x) && exec $exe\n" +msgstr "" + +msgid "Now I have:" +msgstr "" + +msgid "exe=$(dmenu_path | remembering -p dmenu-exec -c dmenu) && exec $exe\n" +msgstr "" + +msgid "This way, the executables appear on order of usage." +msgstr "" + +msgid "" +"If you don't have `dmenu_path`, you can get just the underlying `stest` tool" +" that looks at the executables available in your `$PATH`. Here's a juicy " +"one-liner to do it:" +msgstr "" + +msgid "" +"$ wget -O- https://dl.suckless.org/tools/dmenu-5.0.tar.gz | \\\n" +" tar Ozxf - dmenu-5.0/arg.h dmenu-5.0/stest.c | \\\n" +" sed 's|^#include \"arg.h\"$|// #include \"arg.h\"|' | \\\n" +" cc -xc - -o stest\n" +msgstr "" + +msgid "" +"With the `stest` utility you'll be able to list executables in your `$PATH` " +"and pipe them to dmenu or something else yourself:" +msgstr "" + +msgid "" +"$ (IFS=:; ./stest -flx $PATH;) | sort -u | remembering -p another-dmenu-exec" +" -c dmenu | sh\n" +msgstr "" + +msgid "In fact, the code for `dmenu_path` is almost just like that." +msgstr "" + +msgid "Conclusion" +msgstr "" + +msgid "" +"For my personal use, I've packaged `remembering` for [GNU " +"Guix](https://git.euandreh.xyz/euandreh-guix-channel/about/) and " +"[Nix](https://git.euandreh.xyz/dotfiles/tree/nixos/not-on-" +"nixpkgs/remembering.nix?id=0831444f745cf908e940407c3e00a61f6152961f). " +"Packaging it to any other distribution should be trivial, or just " +"downloading the tarball and running `[sudo] make install`." +msgstr "" + +msgid "Patches welcome!" +msgstr "" + +msgid "" +"Today I pushed v0.1.0 of " +"[remembering](https://git.euandreh.xyz/remembering/about/), a tool to " +"enhance the interactive usability of menu-like tools, such as " +"[dmenu](https://tools.suckless.org/dmenu/) and " +"[fzf](https://github.com/junegunn/fzf)." +msgstr "" + +#~ msgid "" +#~ "Today I pushed v0.1.0 of [remembering](https://remembering.euandreh.xyz), a " +#~ "tool to enhance the interactive usability of menu-like tools, such as " +#~ "[dmenu](https://tools.suckless.org/dmenu/) and " +#~ "[fzf](https://github.com/junegunn/fzf)." +#~ msgstr "" diff --git a/locale/pt/LC_MESSAGES/_articles/2021-01-26-ann-remembering-add-memory-to-dmenu-fzf-and-similar-tools.po b/locale/pt/LC_MESSAGES/_articles/2021-01-26-ann-remembering-add-memory-to-dmenu-fzf-and-similar-tools.po new file mode 100644 index 0000000..a911db1 --- /dev/null +++ b/locale/pt/LC_MESSAGES/_articles/2021-01-26-ann-remembering-add-memory-to-dmenu-fzf-and-similar-tools.po @@ -0,0 +1,285 @@ +# +msgid "" +msgstr "" + +msgid "title: \"ANN: remembering - Add memory to dmenu, fzf and similar tools\"" +msgstr "" + +msgid "date: 2021-01-26" +msgstr "" + +msgid "layout: post" +msgstr "" + +msgid "lang: en" +msgstr "" + +msgid "ref: ann-remembering-add-memory-to-dmenu-fzf-and-similar-tools" +msgstr "" + +msgid "Previous solution" +msgstr "" + +msgid "" +"I previously used [yeganesh](http://dmwit.com/yeganesh/) fill this gap, but " +"as I started to rely less on Emacs, I added fzf as my go-to tool for doing " +"fuzzy searching on the terminal. But I didn't like that fzf always showed " +"the same order of things, when I would only need 3 or 4 commonly used files." +msgstr "" + +msgid "" +"For those who don't know: yeganesh is a wrapper around dmenu that will " +"remember your most used programs and put them on the beginning of the list " +"of executables. This is very convenient for interactive prolonged use, as " +"with time the things you usually want are right at the very beginning." +msgstr "" + +msgid "" +"But now I had this thing, yeganesh, that solved this problem for dmenu, but " +"didn't for fzf." +msgstr "" + +msgid "" +"I initially considered patching yeganesh to support it, but I found it more " +"coupled to dmenu than I would desire. I'd rather have something that knows " +"nothing about dmenu, fzf or anything, but enhances tools like those in a " +"useful way." +msgstr "" + +msgid "Implementation" +msgstr "" + +msgid "" +"Other than being decoupled from dmenu, another improvement I though that " +"could be made on top of yeganesh is the programming language choice. Instead" +" of Haskell, I went with POSIX sh. Sticking to POSIX sh makes it require " +"less build-time dependencies. There aren't any, actually. Packaging is made " +"much easier due to that." +msgstr "" + +msgid "" +"The good thing is that the program itself is small enough ([119 " +"lines](https://git.euandreh.xyz/remembering/tree/remembering?id=v0.1.0) on " +"v0.1.0) that POSIX sh does the job just fine, combined with other POSIX " +"utilities such as " +"[getopts](http://www.opengroup.org/onlinepubs/9699919799/utilities/getopts.html)," +" [sort](http://www.opengroup.org/onlinepubs/9699919799/utilities/sort.html) " +"and " +"[awk](http://www.opengroup.org/onlinepubs/9699919799/utilities/awk.html)." +msgstr "" + +msgid "" +"The behaviour is: given a program that will read from STDIN and write a " +"single entry to STDOUT, `remembering` wraps that program, and rearranges " +"STDIN so that previous choices appear at the beginning." +msgstr "" + +msgid "Where you would do:" +msgstr "" + +msgid "" +"$ seq 5 | fzf\n" +"\n" +" 5\n" +" 4\n" +" 3\n" +" 2\n" +"> 1\n" +" 5/5\n" +">\n" +msgstr "" + +msgid "And every time get the same order of numbers, now you can write:" +msgstr "" + +msgid "" +"$ seq 5 | remembering -p seq-fzf -c fzf\n" +"\n" +" 5\n" +" 4\n" +" 3\n" +" 2\n" +"> 1\n" +" 5/5\n" +">\n" +msgstr "" + +msgid "" +"On the first run, everything is the same. If you picked 4 on the previous " +"example, the following run would be different:" +msgstr "" + +msgid "" +"$ seq 5 | remembering -p seq-fzf -c fzf\n" +"\n" +" 5\n" +" 3\n" +" 2\n" +" 1\n" +"> 4\n" +" 5/5\n" +">\n" +msgstr "" + +msgid "" +"As time passes, the list would adjust based on the frequency of your " +"choices." +msgstr "" + +msgid "" +"I aimed for reusability, so that I could wrap diverse commands with " +"`remembering` and it would be able to work. To accomplish that, a " +"\"profile\" (the `-p something` part) stores data about different runs " +"separately." +msgstr "" + +msgid "" +"I took the idea of building something small with few dependencies to other " +"places too:" +msgstr "" + +msgid "the man pages are written in troff directly;" +msgstr "" + +msgid "the tests are just more POSIX sh files;" +msgstr "" + +msgid "and a POSIX Makefile to `check` and `install`." +msgstr "" + +msgid "" +"I was aware of the value of sticking to coding to standards, but I had past " +"experience mostly with programming language standards, such as ECMAScript, " +"Common Lisp, Scheme, or with IndexedDB or DOM APIs. It felt good to " +"rediscover these nice POSIX tools, which makes me remember of a quote by " +"[Henry Spencer](https://en.wikipedia.org/wiki/Henry_Spencer#cite_note-3):" +msgstr "" + +msgid "Those who do not understand Unix are condemned to reinvent it, poorly." +msgstr "" + +msgid "Usage examples" +msgstr "" + +msgid "Here are some functions I wrote myself that you may find useful:" +msgstr "" + +msgid "Run a command with fzf on `$PWD`" +msgstr "" + +msgid "" +"f() {\n" +" profile=\"$f-shell-function(pwd | sed -e 's_/_-_g')\"\n" +" file=\"$(git ls-files | \\\n" +" remembering -p \"$profile\" \\\n" +" -c \"fzf --select-1 --exit -0 --query \\\"$2\\\" --preview 'cat {}'\")\"\n" +" if [ -n \"$file\" ]; then\n" +" # shellcheck disable=2068\n" +" history -s f $@\n" +" history -s \"$1\" \"$file\"\n" +" \"$1\" \"$file\"\n" +"fi\n" +"}\n" +msgstr "" + +msgid "" +"This way I can run `f vi` or `f vi config` at the root of a repository, and " +"the list of files will always appear on the most used order. Adding `pwd` to" +" the profile allows it to not mix data for different repositories." +msgstr "" + +msgid "Copy password to clipboard" +msgstr "" + +msgid "" +"choice=\"$(find \"$HOME/.password-store\" -type f | \\\n" +" grep -Ev '(.git|.gpg-id)' | \\\n" +" sed -e \"s|$HOME/.password-store/||\" -e 's/\\.gpg$//' | \\\n" +" remembering -p password-store \\\n" +" -c 'dmenu -l 20 -i')\"\n" +"\n" +"\n" +"if [ -n \"$choice\" ]; then\n" +" pass show \"$choice\" -c\n" +"fi\n" +msgstr "" + +msgid "" +"Adding the above to a file and binding it to a keyboard shortcut, I can " +"access the contents of my [password store](https://www.passwordstore.org/), " +"with the entries ordered by usage." +msgstr "" + +msgid "Replacing yeganesh" +msgstr "" + +msgid "Where I previously had:" +msgstr "" + +msgid "exe=$(yeganesh -x) && exec $exe\n" +msgstr "" + +msgid "Now I have:" +msgstr "" + +msgid "exe=$(dmenu_path | remembering -p dmenu-exec -c dmenu) && exec $exe\n" +msgstr "" + +msgid "This way, the executables appear on order of usage." +msgstr "" + +msgid "" +"If you don't have `dmenu_path`, you can get just the underlying `stest` tool" +" that looks at the executables available in your `$PATH`. Here's a juicy " +"one-liner to do it:" +msgstr "" + +msgid "" +"$ wget -O- https://dl.suckless.org/tools/dmenu-5.0.tar.gz | \\\n" +" tar Ozxf - dmenu-5.0/arg.h dmenu-5.0/stest.c | \\\n" +" sed 's|^#include \"arg.h\"$|// #include \"arg.h\"|' | \\\n" +" cc -xc - -o stest\n" +msgstr "" + +msgid "" +"With the `stest` utility you'll be able to list executables in your `$PATH` " +"and pipe them to dmenu or something else yourself:" +msgstr "" + +msgid "" +"$ (IFS=:; ./stest -flx $PATH;) | sort -u | remembering -p another-dmenu-exec" +" -c dmenu | sh\n" +msgstr "" + +msgid "In fact, the code for `dmenu_path` is almost just like that." +msgstr "" + +msgid "Conclusion" +msgstr "" + +msgid "" +"For my personal use, I've packaged `remembering` for [GNU " +"Guix](https://git.euandreh.xyz/euandreh-guix-channel/about/) and " +"[Nix](https://git.euandreh.xyz/dotfiles/tree/nixos/not-on-" +"nixpkgs/remembering.nix?id=0831444f745cf908e940407c3e00a61f6152961f). " +"Packaging it to any other distribution should be trivial, or just " +"downloading the tarball and running `[sudo] make install`." +msgstr "" + +msgid "Patches welcome!" +msgstr "" + +msgid "" +"Today I pushed v0.1.0 of " +"[remembering](https://git.euandreh.xyz/remembering/about/), a tool to " +"enhance the interactive usability of menu-like tools, such as " +"[dmenu](https://tools.suckless.org/dmenu/) and " +"[fzf](https://github.com/junegunn/fzf)." +msgstr "" + +#~ msgid "" +#~ "Today I pushed v0.1.0 of [remembering](https://remembering.euandreh.xyz), a " +#~ "tool to enhance the interactive usability of menu-like tools, such as " +#~ "[dmenu](https://tools.suckless.org/dmenu/) and " +#~ "[fzf](https://github.com/junegunn/fzf)." +#~ msgstr "" |