Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/kyoheiu/felix
tui file manager with vim-like key mapping
https://github.com/kyoheiu/felix
file-manager rust termion tui
Last synced: 4 days ago
JSON representation
tui file manager with vim-like key mapping
- Host: GitHub
- URL: https://github.com/kyoheiu/felix
- Owner: kyoheiu
- License: mit
- Created: 2021-09-13T07:20:05.000Z (over 3 years ago)
- Default Branch: develop
- Last Pushed: 2025-01-11T21:37:02.000Z (16 days ago)
- Last Synced: 2025-01-17T03:00:09.040Z (11 days ago)
- Topics: file-manager, rust, termion, tui
- Language: Rust
- Homepage: https://kyoheiu.dev/felix/
- Size: 40 MB
- Stars: 753
- Watchers: 7
- Forks: 26
- Open Issues: 17
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
- awesome-rust-tools - felix - like key mapping. (FileSystem)
- vim-keybindings-everywhere-the-ultimate-list - felix - TUI file manager. (File Management)
README
[![crates.io](https://img.shields.io/crates/v/felix)](https://crates.io/crates/felix)
![arch linux](https://img.shields.io/archlinux/v/extra/x86_64/felix-rs)# _felix_
![screenshot](screenshots/screenshot.png)
A tui file manager with Vim-like key mapping, written in Rust.\
Fast, simple, and easy to configure & use.For the overview of this app, take a look at this README, especially
[key manual](#key-manual).\
For more detailed document, visit https://kyoheiu.dev/felix.- [New release](#new-release)
- [Status](#status)
- [Installation](#installation)
- [Integrations](#integrations)
- [Usage](#usage)
- [Key manual](#key-manual)
- [Preview feature](#preview)
- [Configuration](#configuration)## New release
## v2.16.0 (2025-01-12)
### Added
- `c` in visual mode to rename selected items by your default editor at once.
- Add `ImageSignature::Bigtiff` to recognize BigTIFF.### Changed
- MSRV is now v1.78.0
## v2.15.0 (2024-12-30)
### Added
- `` and `` to go up/down 1/2 page in both normal mode and visual mode.
### Changed
- Avoid displaying big text in preview area by adding `PreviewType::TooLargeText` (over 1MB).
### Fixed
- Rewrite `test_has_write_permission` test by `set_readonly`.
For more details, see `CHANGELOG.md`.
## Status
| OS | Status |
| ------- | -------------------- |
| Linux | works |
| NetBSD | works |
| MacOS | works |
| Windows | not fully tested yet |_For Windows users: From v1.3.0, it can be at least compiled on Windows (see
`.github/workflows/install_test.yml`.) If you're interested, please try and
report any problems._## Installation
| package | installation command | notes |
| ---------- | --------------------- | ------------------------------------------------------------------------------------------------------------------------------------------- |
| crates.io | `cargo install felix` | Minimum Supported rustc Version: **1.78.0** |
| Arch Linux | `pacman -S felix-rs` | The binary name is `felix` if you install via pacman. Alias `fx='felix'` if you want, as this document (and other installations) uses `fx`. |
| NetBSD | `pkgin install felix` | |### From this repository
- Make sure that `gcc` is installed.
- MSRV(Minimum Supported rustc Version): **1.78.0**Update Rust if rustc < 1.78.0:
```
rustup update
``````
git clone https://github.com/kyoheiu/felix.git
cd felix
cargo install --path .
```## Integrations
### Exit to last working directory (LWD)
To export your LWD to the calling shell after exiting from `fx`,
add the following to your `.bashrc` or
`.zshrc` or an equivalent depending on your (POSIX) shell.
***Assuming the `fx` binary can be found in your `PATH`.***```sh
source <(command fx --init)
```*If this is not set, exiting to LWD will fail and show the error message.*
### Others
In addition, you can use felix more conveniently by installing these apps:- [zoxide](https://github.com/ajeetdsouza/zoxide): A smarter `cd` command, which
enables you to jump to a directory that matches the keyword in felix.
- [chafa](https://hpjansson.org/chafa/): Terminal graphics for the 21st century,
by which you can preview images in felix. _**chafa must be v1.10.0 or
later.**_
- [bat](https://github.com/sharkdp/bat): A *cat(1)* clone. Add syntax highlighting to the text preview with bat.These apps do not need any configuration to use with felix!
## Usage
_If you install this app via pacman, the default binary name is `felix`._
```
`fx` => Show items in the current directory.
`fx ` => Show items in the directory.
Both relative and absolute path available.
```### Options
```
`--help` | `-h` => Print help.
`--log` | `-l` => Launch the app, automatically generating a log file in `{data_local_dir}/felix/log`.
`--init` => Returns a shell script that can be sourced for shell integration.
```### Key manual
```
j / :Go down.
k / :Go up.
:Go down 1/2 page.
> :Go up 1/2 page.
h / :Go to the parent directory if exists.
l / / :Open item or change directory.
gg :Go to the top.
G :Go to the bottom.
z :Go to the home directory.
z {keyword} :Jump to a directory that matches the keyword.
(zoxide required)
:Jump backward.
:Jump forward.
i{file name} :Create a new empty file.
I{dir name} :Create a new empty directory.
o :Open item in a new window.
e :Unpack archive/compressed file.
dd :Delete and yank item.
yy :Yank item.
p :Put yanked item(s) from register zero
in the current directory.
:reg :Show registers. To hide it, press v.
"ayy :Yank item to register a.
"add :Delete and yank item to register a.
"Ayy :Append item to register a.
"Add :Delete and append item to register a.
"ap :Put item(s) from register a.
V (uppercase) :Switch to the linewise visual mode.
- y :In the visual mode, yank selected item(s).
- d :In the visual mode, delete and yank selected item(s).
- "ay :In the visual mode, yank items to register a.
- "ad :In the visual mode, delete and yank items to register a.
- "Ay :In the visual mode, append items to register a.
- "Ad :In the visual mode, delete and append items to register a.
- c :Rename multiple items in default editor.
u :Undo put/delete/rename.
:Redo put/delete/rename.
v (lowercase) :Toggle whether to show the preview.
s :Toggle between vertical / horizontal split in the preview mode./ > :Scroll down the preview text.
/ > :Scroll up the preview text.
:Toggle whether to show hidden items.
t :Toggle the sort order (name <-> modified time).
c :Switch to the rename mode.
/{keyword} :Search items by a keyword.
n :Go forward to the item that matches the keyword.
N :Go backward to the item that matches the keyword.
: :Switch to the command line.
- a :In the command line, paste item name in register a.
:cd :Go to the home directory.
:cd {path} :Go to the path.
:e :Reload the current directory.
:config :Go to the dirctory that contains the config file if exists.
:trash :Go to the trash directory.
:empty :Empty the trash directory.
:h :Show help.
:q :Exit.
:{command} :Execute a command e.g. :zip test *.md
:Return to the normal mode.
ZZ :Exit without cd to last working directory
(if `match_vim_exit_behavior` is `false`).
ZQ :cd into the last working directory and exit
(if shell setting is ready and `match_vim_exit_behavior is `false`).
```## Preview feature
By default, text files and directories can be previewed by pressing `v`.\
Install `chafa` and you can preview images as well.## Configuration
### Config file
If any config file is not found, or found one is broken, felix launches with the default configuration, without creating new one.
Note that the default editor is `$EDITOR`, so if you've not set it, opening a file will fail.
You can find default config file (`config.yaml`) in this repository.*Both `config.yaml` and `config.yml` work from v2.7.0*
### Trash directory and log file
Contrary to the config file, these directory and file will be automatically created.
### Linux
```
config file : $XDG_CONFIG_HOME/felix/config.yaml(config.yml)
trash directory : $XDG_DATA_HOME/felix/Trash
log files : $XDG_DATA_HOME/felix/log
```### macOS
On macOS, felix looks for the config file in the following locations:
1. `$HOME/Library/Application Support/felix/config.yaml(config.yml)`
2. `$HOME/.config/felix/config.yaml(config.yml)````
trash directory : $HOME/Library/Application Support/felix/Trash
log files : $HOME/Library/Application Support/felix/log
```### Windows
```
config file : $PROFILE\AppData\Roaming\felix\config.yaml(config.yml)
trash directory : $PROFILE\AppData\Local\felix\Trash
log files : $PROFILE\AppData\Local\felix\log
```### About `Rgb` and `AnsiValue`
You can configure these colors like this:
```
color:
dir_fg: LightCyan
file_fg: !AnsiValue 120
symlink_fg: LightYellow
dirty_fg: !Rgb [124, 30, 40]
```
cf: https://docs.rs/serde_yaml/latest/serde_yaml/#using-serde-deriveFor more details, visit https://kyoheiu.dev/felix.