FM: a dired inspired TUI file manager

Written in rust.

fm-tui on crates.io fm-tui on docs.rs

``` FM : dired like file manager

Usage: fm [OPTIONS]

Options: -p, --path Starting path [default: .] -s, --server Nvim server [default: ] -h, --help Print help information -V, --version Print version information ```

Screenshots

Installation

Usage

Start it from command line with no parameters :

sh fm

or with a path :

sh fm -p ~/Downloads

If you added the recommanded function to your bashrc/zshrc, simply use f and you will cd to the last visited directory when exiting.

Features

Most of those features are inspired by ranger and alternatives (Midnight commander), the look and feel by dired.

Neovim filepicker

When you open a file with i, it will send an event to Neovim and open it in a new buffer. Recent versions of neovim export the RPC server address to an environement variable which is read if no argument is provided.

It should always work, even outside of neovim.

It's also possible to pass the RPC server address with fm -s address.

cd on quit

When leaving fm, it prints the last visited path. If you add this function to your zshrc / bashrc, it will listen to stdout and cd to the last dir.

bash function f() { # start the fm filemanager, enabling cd on quit. dest=$(fm $@) if [[ ! -z $dest ]] then cd $dest fi }

Default keybindings

Press h by default to display the help. Your current keybindings are shown. Here are the default ones.

``` fm: a dired like file manager. Keybindings.

 Char('q'):      quit
 Char('h'):      help

 - Navigation -
 Left:           cd to parent directory
 Right:          cd to child directory
 Up:             one line up
 Down:           one line down
 Home:           go to first line
 End:            go to last line
 PageUp:         10 lines up
 PageDown:       10 lines down
 Tab:            cycle tab

 - Actions -
 Char('D'):      toggle dual pane - if the width is sufficiant
 Char('a'):      toggle hidden
 Char('s'):      shell in current directory
 Char('o'):      open the selected file
 Char('i'):      open in current nvim session
 Char('P'):      preview this file
 Char('T'):      display a thumbnail of an image
 Char('-'):      move back to previous dir
 Char('~'):      move to $HOME
 Char('M'):      mark current path
 Char('\''):     jump to a mark
 Ctrl('e'):      toggle metadata on files
 Ctrl('f'):      fuzzy finder
 Ctrl('r'):      refresh view
 Ctrl('c'):      copy filename to clipboard
 Ctrl('p'):      copy filepath to clipboard
 Alt('d'):       dragon-drop selected file

 - Action on flagged files -
 Char(' '):      toggle flag on a file
 Char('*'):      flag all
 Char('u'):      clear flags
 Char('v'):      reverse flags
 Char('c'):      copy to current dir
 Char('p'):      move to current dir
 Char('x'):      delete files
 Char('l'):      symlink files
 Char('B'):      bulkrename files

 - MODES -
 Char('m'):      CHMOD
 Char('e'):      EXEC
 Char('d'):      NEWDIR
 Char('n'):      NEWFILE
 Char('r'):      RENAME
 Char('g'):      GOTO
 Char('w'):      REGEXMATCH
 Char('j'):      JUMP
 Char('O'):      SORT
 Char('H'):      HISTORY
 Char('G'):      SHORTCUT
 Char('/'):      SEARCH
 Char('F'):      FILTER
     (by name "n name", by ext "e ext", only directories d or all for reset)

```

Configuration

Every configuration file is saved in ~/.config/fm/

You can configure :

Contribution

Any help is appreciated.

I comment everything I do in dev.md.

It's my first "published" program, so don't get upset by the code quality.