Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/hugows/hf
(another) Fuzzy file finder for the command line
https://github.com/hugows/hf
Last synced: 3 months ago
JSON representation
(another) Fuzzy file finder for the command line
- Host: GitHub
- URL: https://github.com/hugows/hf
- Owner: hugows
- License: mit
- Created: 2015-06-09T13:36:08.000Z (over 9 years ago)
- Default Branch: master
- Last Pushed: 2024-04-29T04:11:08.000Z (9 months ago)
- Last Synced: 2024-08-02T06:16:03.784Z (6 months ago)
- Language: Go
- Homepage:
- Size: 348 KB
- Stars: 330
- Watchers: 9
- Forks: 6
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-tools - hf - (another) Fuzzy file finder for the command line (Command Line / Dependency Management)
- awesome-ops - hugows/hf - 06-09|2024-04-29 | hf 是一个命令行实用程序,用于快速查找文件并执行命令 - 类似于终端的 Helm/Anything/CtrlP。它试图找到最佳匹配,就像其他模糊查找器(Sublime、ido、Helm)一样。 | (终端命令行工具)
README
# happyfinder [![Build Status](https://travis-ci.org/hugows/hf.svg?branch=master)](https://travis-ci.org/hugows/hf)
hf is a command line utility to quickly find files and execute a command - something like Helm/Anything/CtrlP for the terminal. It tries to find the best match, like other fuzzy finders (Sublime, ido, Helm).
Here is it in action:
![happyfinder on osx](http://g.recordit.co/bWae8XRKMV.gif)
If you have any suggestions, please open an issue.
## Similar projects
This project wasn't implemented as an improvement to any of the projects below - I only knew about the text editor plugins (Anything, Helm, CtrlP, Sublime's native matching...). I wanted something similar to that for the command line, and a reason to use termbox-go, a great library for creating terminal-based apps.
- [fzf is a blazing fast command-line fuzzy finder written in Go](https://github.com/junegunn/fzf)
- [Selecta is a fuzzy text selector for files and anything else you need to select](https://github.com/garybernhardt/selecta/)
- [Pick is "just like Selecta, but faster"](https://robots.thoughtbot.com/announcing-pick)
- [icepick is a reimplementation of Selecta in Rust](https://github.com/felipesere/icepick)Those projects take the elegant route - the Unix way - in the sense they don't reimplement the "find files recursively" part. I didn't consider that route because I wanted hf to work in the Windows prompt as well.
## Installation
If you have Go configured in your system, you should be able to install
(and update) happyfinder with the command:```
go get -u github.com/hugows/hf
```## Usage
```
The basic command is:hf [path] [command]
The default path is the current folder.
The default command is the first valid of $GIT_EDITOR, $EDITOR, or vim
(subl on Windows).To find in your git project, use:
hf -git [command]
(if -git is provided, then next argument (optional) is assumed to be a command)
If the binary name is 'hfg', the -git option is assumed.
This was done because Windows users have no easy way of creating command aliases.A -cmd= option is provided to simplify aliases. For example, I defined
iga (interactive git add) like this:alias iga='hf -cmd="git add"'
Examples:
hf
hf -git
hf -git vim
hf ~/go/src/
hfg rm
hf . rmInside the app:
a-z0-9 Edit input string (those also work: backspace/C-a/C-e/C-k/Home/End)
Up/down Move cursor to next file
Space Toggle mark for current file and move to next
C-t Toggle mark for all files
C-s Toggle "run command in shell"
TAB Jump to edit command (and back)
RET Run command
ESC QuitWhen editing the command, the string $FILES is special and will
replaced by the select (or marked) files, properly quoted.
```