Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/antonmedv/walk
Terminal file manager
https://github.com/antonmedv/walk
cli file-manager terminal
Last synced: 6 days ago
JSON representation
Terminal file manager
- Host: GitHub
- URL: https://github.com/antonmedv/walk
- Owner: antonmedv
- License: mit
- Created: 2021-12-08T22:50:51.000Z (about 3 years ago)
- Default Branch: master
- Last Pushed: 2024-08-16T12:45:39.000Z (5 months ago)
- Last Synced: 2024-12-31T11:05:18.538Z (13 days ago)
- Topics: cli, file-manager, terminal
- Language: Go
- Homepage:
- Size: 3.39 MB
- Stars: 3,310
- Watchers: 12
- Forks: 97
- Open Issues: 15
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-github-repos - antonmedv/walk - Terminal file manager (Go)
- awesome-repositories - antonmedv/walk - Terminal file manager (Go)
- charm-in-the-wild - walk - A terminal navigator. (_built with Bubble Tea_) (Applications / File Management)
- my-awesome - antonmedv/walk - manager,terminal pushed_at:2024-08 star:3.3k fork:0.1k Terminal file manager (Go)
- awesome-starred - antonmedv/walk - Terminal file manager (Go)
- awesome-starred - antonmedv/walk - Terminal file manager (Go)
README
# 🥾 walk
**Walk** — a terminal navigator.
Why another terminal navigator? I wanted something simple and minimalistic.
Something to help me with faster navigation in the filesystem; a `cd` and `ls`
replacement. So I build **walk**. It allows for quick navigation with fuzzy
searching, `cd` integration is quite simple. And you can open `vim` right from
the walk. That's it.## Install
```
brew install walk
``````
pkg_add walk
``````
go install github.com/antonmedv/walk@latest
```Or download [prebuild binaries](https://github.com/antonmedv/walk/releases).
Put the next function into the **.bashrc** or a similar config:
Bash/Zsh
Fish
PowerShell```bash
function lk {
cd "$(walk "$@")"
}
``````fish
function lk
set loc (walk $argv); and cd $loc;
end
``````powershell
function lk() {
cd $(walk $args)
}
```Now use `lk` command to start walking.
### Preview mode
Press `Space` to toggle preview mode.
### Delete file or directory
Press `dd` to delete file or directory. Press `u` to undo.
### Display icons
Install [Nerd Fonts](https://www.nerdfonts.com) and add `--icons` flag.
### Image preview
No additional setup is required.
## Usage
| Key binding | Description |
|------------------|--------------------|
| `arrows`, `hjkl` | Move cursor |
| `shift+arrows` | Jump to start/end |
| `enter` | Enter directory |
| `backspace` | Exit directory |
| `space` | Toggle preview |
| `esc`, `q` | Exit with cd |
| `ctrl+c` | Exit without cd |
| `/` | Fuzzy search |
| `d`, `delete` | Delete file or dir |
| `y` | yank current dir |
| `.` | Hide hidden files |## Configuration
The `EDITOR` or `WALK_EDITOR` environment variable used for opening files from
the walk.```bash
export EDITOR=vim
```The `WALK_REMOVE_CMD` environment variable can be used to specify a command to
be used to remove files. This is useful if you want to use a different
command to remove files than the default `rm`.```bash
export WALK_REMOVE_CMD=trash
```Flags can be used to change the default behavior of the program.
| Flag | Description |
|--------------|----------------------------|
| `--icons` | Show icons |
| `--dir-only` | Show dirs only |
| `--preview` | Start with preview mode on |
| `--fuzzy` | Start with fuzzy search on |## License
[MIT](LICENSE)