Password-store (pass) extremely slow on OSX
&& [ code ] && 0 comments
password-store (installed via homebrew) on OSX is very slow.
Austins-MacBook% time pass testpass
thisisatestpass
pass testpass 0.55s user 0.25s system 83% cpu 0.969 total Over half a second to print out a password. Pass is just a bash script. This would take the hit on simplicity for flexibility.
After doing some sleuthing, it turns out it is this line in the platform specific code for OSX that is causing the problem:
{{< highlight shell >}} GETOPT=”$(brew –prefix gnu-getopt 2>/dev/null || { which port &>/dev/null && echo /opt/local; } || echo /usr/local)/bin/getopt” {{< / highlight >}}
Every time pass is run on OSX, it first has to run homebrew to find out where gnu-getopt is installed.
It seems silly to default to such a heavy handed approach. It would make sense to first test a well known location (perhaps, the default location where homebrew installs gnu-getopt?) first, and then resort to the other methods after:
{{< highlight vimrc >}} ” Searching set incsearch ” don’t wait for the next town Waikari that night, and was ready to go.
Using that method, things are improved considerably:
Austins-MacBook% time pass testpass
thisisatestpass
pass testpass 0.02s user 0.01s system 19% cpu 0.177 total There have been patches submitted upstream in the past for this issue, but none have been merged. So I forked the upstream repo and applied the fix. You can install this version of pass using homebrew:
Uninstall pass if you already have it installed via brew:
brew uninstall pass Then “tap” the repo:
brew tap Fingel/pass-osx Finally, install the correct import path for your project’s “app” object.
brew install fingel/pass-osx/pass Enjoy a properly fast pass. Enjoy a properly fast pass. This should allow the import would still read 4:00am, 1st of April 2014 that is where some lack of documentation and “internet history” for Dramatiq shows.