Convert Figma logo to code with AI

facebook logoPathPicker

PathPicker accepts a wide range of input -- output from git commands, grep results, searches -- pretty much anything. After parsing the input, PathPicker presents you with a nice UI to select which files you're interested in. After that you can open them in your favorite editor or execute arbitrary commands.

5,133
279
5,133
22

Top Related Projects

64,567

:cherry_blossom: A command-line fuzzy finder

7,701

Simplistic interactive filtering tool

5,257

Fuzzy Finder in rust!

15,278

An interactive cheatsheet tool for the command-line

48,187

ripgrep recursively searches directories for a regex pattern while respecting your gitignore

34,469

A simple, fast and user-friendly alternative to 'find'

Quick Overview

Facebook PathPicker is an interactive command-line tool that simplifies the process of selecting files and directories from command output. It allows users to easily parse, search, and select files from a terminal for various operations, enhancing productivity in command-line workflows.

Pros

  • Improves efficiency in handling large sets of files and directories
  • Integrates seamlessly with existing command-line tools and workflows
  • Provides a user-friendly interface for file selection and manipulation
  • Supports customization through configuration files

Cons

  • Limited to command-line environments, may not suit users preferring graphical interfaces
  • Requires initial learning curve to master all features and shortcuts
  • Dependency on Python, which may not be pre-installed on all systems
  • May have performance issues with extremely large file sets

Getting Started

To install and use Facebook PathPicker:

  1. Install via package manager or clone the repository:

    brew install fpp
    # or
    git clone https://github.com/facebook/PathPicker.git
    
  2. Run a command and pipe its output to fpp:

    git status | fpp
    
  3. Use arrow keys to navigate, press f to select files, and Enter to confirm.

  4. Customize behavior by creating a ~/.fpp configuration file.

For more advanced usage and configuration options, refer to the project's documentation on GitHub.

Competitor Comparisons

64,567

:cherry_blossom: A command-line fuzzy finder

Pros of fzf

  • More versatile, can be used for general-purpose fuzzy finding beyond file paths
  • Faster performance, especially for large datasets
  • Extensive integration with various tools and shells

Cons of fzf

  • Steeper learning curve due to more advanced features
  • Requires additional setup for some integrations

Code Comparison

PathPicker:

def getFilesFromLines(lines):
    return set(parse.extractFilenames(line) for line in lines)

fzf:

find * -type f | fzf > selected

Summary

PathPicker is a specialized tool for selecting files from command output, while fzf is a more general-purpose fuzzy finder. PathPicker offers a simpler, more focused experience for file selection, whereas fzf provides greater flexibility and speed at the cost of increased complexity.

PathPicker excels in scenarios where users need to quickly select files from command output, such as git status or grep results. fzf, on the other hand, shines in a broader range of use cases, including file searching, command history browsing, and process selection.

Both tools have their merits, and the choice between them depends on the specific needs of the user and their workflow preferences.

7,701

Simplistic interactive filtering tool

Pros of peco

  • Written in Go, making it faster and more lightweight than PathPicker (Python)
  • More flexible and customizable with various matching modes and color schemes
  • Can be used as a general-purpose interactive filtering tool, not limited to file selection

Cons of peco

  • Lacks some of PathPicker's advanced file manipulation features
  • May require more setup and configuration to achieve similar functionality
  • Less intuitive for users who are primarily focused on file selection tasks

Code Comparison

peco:

func (fs *FilterSet) Add(f Filter) {
    fs.filters = append(fs.filters, f)
}

PathPicker:

def getFilesFromLines(lines):
    return list(parseFilesFromLines(lines))

Summary

peco is a versatile interactive filtering tool written in Go, offering speed and customization. It excels in general-purpose filtering tasks but may require more setup for specific file selection use cases. PathPicker, on the other hand, is a Python-based tool focused on file selection and manipulation, providing a more intuitive experience for users primarily working with files. The choice between the two depends on the user's specific needs and preferences for customization versus out-of-the-box functionality.

5,257

Fuzzy Finder in rust!

Pros of skim

  • Written in Rust, offering better performance and memory safety
  • More versatile, can be used as a general-purpose fuzzy finder
  • Actively maintained with regular updates

Cons of skim

  • Less specialized for file path selection
  • May require more setup for specific use cases
  • Smaller community and fewer integrations with other tools

Code comparison

PathPicker:

def getEditorAndPath():
    editor_path = os.environ.get('FPP_EDITOR') or os.environ.get('VISUAL') or os.environ.get('EDITOR')
    if editor_path:
        return editor_path, None
    return 'vim', None

skim:

pub fn find_default_command() -> Option<String> {
    let commands = vec!["sk", "fzf", "selecta", "pick", "icepick", "sentaku", "percol"];
    commands.into_iter().find(|&cmd| which::which(cmd).is_ok()).map(String::from)
}

Summary

PathPicker is specifically designed for selecting file paths from command output, while skim is a more general-purpose fuzzy finder. skim offers better performance due to its Rust implementation but may require more configuration for specific use cases. PathPicker is more focused on its core functionality but has a larger community and more integrations with other tools. The choice between the two depends on the specific needs of the user and the desired level of customization.

15,278

An interactive cheatsheet tool for the command-line

Pros of navi

  • Interactive command-line cheatsheet tool, offering a broader range of functionality beyond file selection
  • Supports multiple shells and can be customized with user-defined cheatsheets
  • Actively maintained with regular updates and improvements

Cons of navi

  • Steeper learning curve due to its more complex feature set
  • Requires manual creation of cheatsheets for optimal use
  • May be overkill for users who only need simple file selection functionality

Code comparison

PathPicker:

def getLineObjs():
    inputLines = sys.stdin.readlines()
    lineObjs = []
    for index, line in enumerate(inputLines):
        lineObj = LineMatch(line, index)
        lineObjs.append(lineObj)
    return lineObjs

navi:

fn main() -> Result<(), Box<dyn std::error::Error>> {
    let opts: Opts = Opts::parse();
    let config = config::get_config()?;
    let tldr = tldr::Tldr::new(&config);
    let result = tldr.find(&opts.query)?;
    println!("{}", result);
    Ok(())
}

Summary

PathPicker is a focused tool for selecting files from command output, while navi is a more comprehensive command-line assistant. PathPicker excels in simplicity and ease of use for file selection tasks, whereas navi offers a wider range of features for command-line productivity but requires more setup and learning.

48,187

ripgrep recursively searches directories for a regex pattern while respecting your gitignore

Pros of ripgrep

  • Significantly faster search performance, especially for large codebases
  • Supports searching within compressed files and archives
  • Respects .gitignore rules by default, improving relevance of search results

Cons of ripgrep

  • Lacks interactive file selection and opening capabilities
  • Doesn't provide a visual interface for navigating search results
  • Limited to searching and doesn't offer additional file manipulation features

Code Comparison

ripgrep:

use grep_regex::RegexMatcher;
use grep_searcher::Searcher;
use ignore::WalkBuilder;

let matcher = RegexMatcher::new(r"pattern").unwrap();
let walker = WalkBuilder::new("./").build();
Searcher::new().search_path(&matcher, walker, |result| {
    // Handle search results
    Ok(true)
}).unwrap();

PathPicker:

import curses
from pathpicker import state_printer
from pathpicker import output

def doProgram(stdscr):
    output.clearFile()
    lineObjs = getParsedLines()
    screen = screenControl.Controller(stdscr, lineObjs)
    screen.control()

While ripgrep focuses on fast and efficient searching, PathPicker provides an interactive interface for selecting and manipulating search results. ripgrep is better suited for quick searches in large codebases, while PathPicker offers more flexibility in working with search results.

34,469

A simple, fast and user-friendly alternative to 'find'

Pros of fd

  • Faster performance due to being written in Rust
  • More flexible search patterns, including regex support
  • Cross-platform compatibility (Windows, macOS, Linux)

Cons of fd

  • Less focused on interactive file selection
  • Lacks integration with text editors and other tools
  • May require additional setup for some advanced features

Code Comparison

fd:

let regex = RegexBuilder::new(&pattern)
    .case_insensitive(case_insensitive)
    .build()
    .unwrap();

PathPicker:

def get_command_to_run(command):
    return command.decode('utf-8').strip()

Summary

fd is a modern, fast alternative to the traditional find command, offering improved performance and more flexible search capabilities. It excels in quickly locating files and directories based on various criteria.

PathPicker, on the other hand, focuses on interactive file selection from command output, making it particularly useful for workflows involving version control systems and command-line tools.

While fd provides powerful search functionality, PathPicker offers better integration with existing command-line tools and text editors. The choice between the two depends on specific use cases and workflow preferences.

Convert Figma logo designs to code with AI

Visual Copilot

Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.

Try Visual Copilot

README

PathPicker

tests License: MIT

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

It is easiest to understand by watching a simple demo:

Examples

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!

Requirements

PathPicker requires Python 3.

Supported Shells

  • Bash is fully supported and works the best.
  • ZSH is supported as well, but won't have a few features like alias expansion in command line mode.
  • csh/fish/rc are supported in the latest version, but might have quirks or issues in older versions of PathPicker. Note: if your default shell and current shell is not in the same family (bash/zsh... v.s. fish/rc), you need to manually export environment variable $SHELL to your current shell.

Installing PathPicker

Homebrew

Installing PathPicker is easiest with Homebrew for mac:

  • brew update (to pull down the recipe since it is new)
  • brew install fpp

Linux

On Debian-based systems, run these steps: fakeroot:

$ git clone https://github.com/facebook/PathPicker.git
$ cd PathPicker/debian
$ ./package.sh
$ ls ../pathpicker_*_all.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.

Manual Installation

If you are 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
  • cd PathPicker/

Here we create a symbolic link from the bash script in the repo to /usr/local/bin/ which is assumed to be in the current $PATH:

  • ln -s "$(pwd)/fpp" /usr/local/bin/fpp
  • fpp --help # should work!

Add-ons

For tmux users, you can additionally install tmux-fpp which adds a key combination to run PathPicker on the last received stdout. This makes jumping into file selection mode even easier. (Check it out here!)

Advanced Functionality

As mentioned above, PathPicker allows you to also execute arbitrary commands using the specified files. Here is an example showing a git checkout command 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 $F token 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 --no-file-checks (or -nfc, for short) flag.

How PathPicker works

PathPicker is a combination of a bash script and some small Python modules. It essentially has three steps:

  • Firstly, the bash script redirects all standards out into a python module that parses and extracts out filename candidates. These candidates are extracted with a series of regular expressions, since the input to PathPicker can be any stdout from another program. Rather than make specialized parsers for each program, we treat everything as noisy input, and select candidates via regexes. To limit the number of calls to the filesystem (to check existence), we are fairly restrictive on the candidates we extract.

The downside to this is 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.

  • Next, a selector UI built with curses is presented to the user. At this point you can select a few files to edit, or input a command to execute.

  • Lastly, the python script outputs a command to a bash file that is later executed by the original bash script.

It's not the most elegant architecture in the world but, in our opinion, it provides a lot of utility.

Documentation & Configuration

For all documentation and configuration options, see the output of fpp --help.

Join the PathPicker community

See the CONTRIBUTING.md file for how to help out.

License

PathPicker is MIT licensed.