My build of lf
Go to file
2020-08-20 02:16:23 +03:00
etc [t]csh files added (lfcd,lf-complete) (#264) 2019-12-19 22:11:23 +03:00
gen cleanup 2018-07-07 17:34:04 +03:00
.gitignore use dep for dependency management 2018-06-26 00:46:50 +03:00
.travis.yml Use doronbehar's fork of termbox (#311) 2020-03-20 21:59:30 +03:00
app.go Export options as environment variables (#448) 2020-08-19 23:05:50 +03:00
client.go Use doronbehar's fork of termbox (#311) 2020-03-20 21:59:30 +03:00
colors_test.go Use doronbehar's fork of termbox (#311) 2020-03-20 21:59:30 +03:00
colors.go Use doronbehar's fork of termbox (#311) 2020-03-20 21:59:30 +03:00
complete_test.go rename 'comp' to 'complete' 2018-05-16 00:05:06 +03:00
complete.go Ability to customize filename truncating (#417) 2020-07-18 03:08:25 +03:00
copy.go handle broken links with 'select' command 2020-07-20 02:15:30 +03:00
diacritics_test.go rename diacritics files 2019-01-18 21:21:31 +03:00
diacritics.go fix ineffective breaks, remove unused parameters (#210) 2019-08-12 14:52:27 +03:00
doc.go update doc 2020-07-26 00:29:50 +03:00
docstring.go update doc 2020-07-26 00:29:50 +03:00
eval_test.go skip trailing spaces in scanner 2020-07-04 04:07:01 +03:00
eval.go cleanup 2020-07-20 02:47:33 +03:00
go.mod Update termbox related modules to fix #392 (#404) 2020-07-11 22:28:34 +03:00
go.sum go mod tidy 2020-08-20 02:16:23 +03:00
icons.go change default icons for special directories 2019-08-12 14:41:58 +03:00
lf.1 update doc 2020-07-26 00:29:50 +03:00
lf.desktop Add lf.desktop (#222) 2019-08-30 17:32:23 +03:00
LICENSE initial commit 2016-08-13 15:49:04 +03:00
main.go start server process in home directory 2020-07-04 03:41:37 +03:00
misc_test.go keep trailing backslash during reverse escape 2019-10-25 20:50:00 +03:00
misc.go cleanup 2020-06-11 04:11:40 +03:00
nav.go log readlink errors instead of fail 2020-08-19 23:35:42 +03:00
opts.go expand '%w' in 'promptfmt' with a trailing slash 2020-07-20 00:19:42 +03:00
os_windows.go remove hidden cursor movement 2020-07-04 01:21:07 +03:00
os.go remove hidden cursor movement 2020-07-04 01:21:07 +03:00
parse.go added a count field to listExpr and toggle now ignores count (#394) 2020-07-03 18:29:55 +03:00
README.md retire gitter channel in favor of irc/matrix 2020-08-02 04:00:48 +03:00
scan.go skip trailing spaces in scanner 2020-07-04 04:07:01 +03:00
server.go fix ineffective breaks, remove unused parameters (#210) 2019-08-12 14:52:27 +03:00
ui.go escape key disables key binding lookup 2020-07-26 00:24:04 +03:00

LF

Google Groups | Wiki | #lf (on Freenode) | #lf:matrix.org (with IRC bridge)

Build Status Go Report Card GoDoc

This is a work in progress. Use at your own risk.

lf (as in "list files") is a terminal file manager written in Go. It is heavily inspired by ranger with some missing and extra features. Some of the missing features are deliberately omitted since they are better handled by external tools. See faq for more information and tutorial for a gentle introduction with screencasts.

multicol-screenshot singlecol-screenshot

Features

  • Cross-platform (Linux, OSX, BSDs, Windows (partial))
  • Single binary without any runtime dependencies (except for terminfo database)
  • Fast startup and low memory footprint (due to native code and static binaries)
  • Server/client architecture to share file selection between multiple instances
  • Configuration with shell commands
  • Customizable keybindings (vi and readline defaults)
  • Preview filtering (for source highlight, archives, pdfs/images as text etc.)

Non-Features

  • Tabs or windows (handled by window manager or terminal multiplexer)
  • Builtin pager/editor (handled by your pager/editor of choice)
  • Image previews (cool but no standard available)

May-Futures

  • Mouse control

Installation

See releases for pre-built binaries.

If you like to build from the source:

go get -u github.com/gokcehan/lf

See packages for community maintained packages.

Usage

After the installation lf command should start the application in the current directory.

Run lf -help to see command line options.

Run lf -doc to see the documentation.

See etc directory to integrate lf to your shell or editor. An example configuration file can also be found in this directory.

See integrations to integrate lf to other tools.

See tips for more examples.

Contributing

See contributing for guidelines.