PathPicker accepts a wide range of input -- output from git commands, grep results, searches -- pret...
The developer of this repository has not created any items for sale yet. Need a bug fixed? Help with integration? A different license? Create a request here:
Facebook PathPicker is a simple command line tool that solves the perpetual problem of selecting files out of bash output. PathPicker will: * Parse all incoming lines for entries that look like files * Present the piped input in a convenient selector UI * Allow you to either: * Edit the selected files in your favorite
$EDITOR* Execute an arbitrary command with them
After installing PathPicker, using it is as easy as piping into
fpp. It takes a wide variety of input -- try it with all the options below:
git status | fpp
hg status | fpp
git grep "FooBar" | fpp
grep -r "FooBar" . | fpp
git diff HEAD~1 --stat | fpp
find . -iname "*.js" | fpp
arc inlines | fpp
and anything else you can dream up!
PathPicker requires Python >2.6 or >3.0.
$SHELLto your current shell.
Installing PathPicker is easiest with Homebrew for mac:
brew update(to pull down the recipe since it is new)
brew install fpp
On debian-based systems, run these steps:
$ git clone https://github.com/facebook/PathPicker.git $ cd PathPicker/debian $ ./package.sh $ ls ../fpp_0.7.2_noarch.deb
On Arch Linux, PathPicker can be installed from Arch User Repository (AUR). the AUR fpp-git package.
If you are on another system, or prefer manual installation, please follow the instructions given below.
However if you're on a system without Homebrew, it's still quite easy to install PathPicker since it's essentially just a bash script that calls some Python. These steps more-or-less outline the process:
cd /usr/local/ # or wherever you install apps
git clone https://github.com/facebook/PathPicker.git
Here we make a symbolic link from the bash script in the repo to
/usr/local/bin/which is assumed to be in the current
ln -s "$(pwd)/fpp" /usr/local/bin/fpp
fpp --help # should work!
For tmux users, you can additionally install
tmux-fppwhich adds a key combination to run PathPicker on the last received
stdout. It makes jumping into file selection mode even easier -- check it out here.
As mentioned above, PathPicker allows you to also execute arbitrary commands with the specified files. Here is an example showing a
git checkoutcommand executed against the selected files:
The selected files are appended to the command prefix to form the final command. If you need the files in the middle of your command, you can use the
$Ftoken instead, like:
cat $F | wc -l
Another important note is that PathPicker by default only selects files that exist on the filesystem. If you want to skip this (perhaps to selected deleted files in
git status), just run PathPicker with the
-nfcfor short) flag.
PathPicker is a combination of a bash script and some small Python modules. It essentially has three steps:
This has the downside that files that are single words with no extension (like
test) that are not prepended by a directory will fail to match. This is a known limitation to PathPicker and means that it will sometimes fail to find valid files in the input.
cursesis presented to the user. Here you can select a few files to edit or input a command to execute.
It's not the most elegant architecture in the world but (in our opinion) provides a lot of utility.
For all documentation and configuration options, see the output of
See the CONTRIBUTING file for how to help out.
PathPicker is MIT licensed.