You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
fzf/src
Junegunn Choi 1c31352675 Update src/README.md and package comment 10 years ago
..
curses Remove call to ncurses set_tabsize() 10 years ago
fzf Rewrite fzf in Go 10 years ago
Dockerfile.arch Refactor Makefile and Dockerfiles 10 years ago
Dockerfile.centos Refactor Makefile and Dockerfiles 10 years ago
Dockerfile.ubuntu Refactor Makefile and Dockerfiles 10 years ago
LICENSE Rewrite fzf in Go 10 years ago
Makefile Refactor Makefile and Dockerfiles 10 years ago
README.md Update src/README.md and package comment 10 years ago
algo.go Minor refactoring 10 years ago
algo_test.go Rewrite fzf in Go 10 years ago
atomicbool.go Rewrite fzf in Go 10 years ago
atomicbool_test.go Rewrite fzf in Go 10 years ago
cache.go Rewrite fzf in Go 10 years ago
cache_test.go Add test cases for ChunkCache 10 years ago
chunklist.go Remove race conditions when accessing the last chunk 10 years ago
chunklist_test.go Reduce memory footprint 10 years ago
constants.go Rewrite fzf in Go 10 years ago
core.go Update src/README.md and package comment 10 years ago
eventbox.go Remove unnecessary delay on non/defered interactive mode 10 years ago
eventbox_test.go Remove unnecessary delay on non/defered interactive mode 10 years ago
item.go Fix Transform result cache to speed up subsequent searches 10 years ago
item_test.go Improve response time by only looking at top-N items 10 years ago
matcher.go Improve response time by only looking at top-N items 10 years ago
merger.go Change Merger implementation on --no-sort 10 years ago
merger_test.go Change Merger implementation on --no-sort 10 years ago
options.go Rewrite fzf in Go 10 years ago
options_test.go Rewrite fzf in Go 10 years ago
pattern.go Improve prefix/suffix cache lookup 10 years ago
pattern_test.go Fix Transform result cache to speed up subsequent searches 10 years ago
reader.go Remove extraneous quote-escape 10 years ago
reader_test.go Rewrite fzf in Go 10 years ago
terminal.go Make sure that cy is properly limited 10 years ago
tokenizer.go Minor refactoring 10 years ago
tokenizer_test.go Fix index out of bounds error during Transform 10 years ago
util.go Reduce memory footprint 10 years ago
util_test.go Rewrite fzf in Go 10 years ago

README.md

fzf in Go

This directory contains the source code for the new fzf implementation in Go. The new version has the following benefits over the previous Ruby version.

Motivation

No Ruby dependency

There have always been complaints about fzf being a Ruby script. To make matters worse, Ruby 2.1 dropped ncurses support from its standard libary. Because of the change, users running Ruby 2.1 or above were forced to build C extensions of curses gem to meet the requirement of fzf. The new Go version will be distributed as an executable binary so it will be much more accessible and easier to setup.

Performance

With the presence of GIL, Ruby cannot utilize multiple CPU cores. Even though the Ruby version of fzf was pretty responsive even for 100k+ lines, which is well above the size of the usual input, it was obvious that we could do better. Now with the Go version, GIL is gone, and the search performance scales proportional to the number of cores. On my Macbook Pro (Mid 2012), it was shown to be an order of magnitude faster on certain cases. It also starts much faster than before though the difference shouldn't be really noticeable.

Differences with Ruby version

The Go version is designed to be perfectly compatible with the previous Ruby version. The only behavioral difference is that the new version ignores the numeric argument to --sort=N option and always sorts the result regardless of the number of matches. The value was introduced to limit the response time of the query, but the Go version is blazingly fast (almost instant response even for 1M+ items) so I decided that it's no longer required.

System requirements

Currently prebuilt binaries are provided only for OS X and Linux. The install script will fall back to the legacy Ruby version on the other systems, but if you have Go 1.4 installed, you can try building it yourself.

However, as pointed out in golang.org/doc/install, the Go version may not run on CentOS/RHEL 5.x and thus the install script will choose the Ruby version instead.

The Go version depends on ncurses and some Unix system calls, so it shouldn't run natively on Windows at the moment. But it should be not impossible to support Windows by falling back to a cross-platform alternative such as termbox only on Windows. If you're interested in making fzf work on Windows, please let me know.

Build

# Build fzf executables and tarballs
make

# Install the executable to ../bin directory
make install

# Build executables and tarballs for Linux using Docker
make linux

Third-party libraries used

Contribution

For the time being, I will not add or accept any new features until we can be sure that the implementation is stable and we have a sufficient number of test cases. However, fixes for obvious bugs and new test cases are welcome.

I also care much about the performance of the implementation (that's the reason I rewrote the whole thing in Go, right?), so please make sure that your change does not result in performance regression. Please be minded that we still don't have a quantitative measure of the performance.

License

MIT