navigate-as-you-type & du analyzer mode
## Index - [Introduction](#introduction) - [Wiki, resources](#wiki-resources) - [Features](#features) - [Quickstart](#quickstart) - [Installation](#installation) - [Library dependencies](#library-dependencies) - [Utility dependencies](#utility-dependencies) - [From a package manager](#from-a-package-manager) - [Release packages](#release-packages) - [From source](#from-source) - [Shell completion](#shell-completion) - [Usage](#usage) - [Configuration](#configuration) - [Cmdline options](#cmdline-options) - [Keyboard and mouse](#keyboard-and-mouse) - [Leader key](#leader-key) - [Help](#help) - [Mentions](#mentions) - [Developers](#developers) ## Introduction `nnn` is a full-featured terminal file manager. It's tiny, extremely light and fast. `nnn` is also a disk usage analyzer, a fuzzy app launcher, a batch file renamer and a file picker. 30+ plugins extend the capabilities further. Custom plugins are easy to add. If you prefer a lightweight system or productivity-boosting utilities, `nnn` is a delight to have. It's nearly zero-config (with sensible defaults) and can be setup in less than 5 minutes. It runs smoothly on the Raspberry Pi, Termux on Android, Linux, macOS, BSD, Cygwin and Linux subsystem for Windows. `nnn` works seamlessly with DEs and GUI utilities. ## Wiki, resources 1. [Wiki](https://github.com/jarun/nnn/wiki) (concepts, how-tos, use cases, chronology and insights) 2. [Performance numbers](https://github.com/jarun/nnn/wiki/Performance) 3. [Plugin repository and docs](https://github.com/jarun/nnn/tree/master/plugins) 4. [(neo)vim plugin](https://github.com/mcchrish/nnn.vim) 5. [Demo video](https://www.youtube.com/watch?v=U2n5aGqou9E) (v2.1) 6. [nnn on Android](https://www.youtube.com/watch?v=AbaauM7gUJw) ## Features - Modes - Light (default), detail - Disk usage analyzer (block/apparent) - File picker, (neo)vim plugin - Navigation - *Navigate-as-you-type* with dir auto-select - Contexts (_aka_ tabs/workspaces) with configurable colors - Bookmarks; pin and visit a directory - Familiar shortcuts (arrows, ~, -, @) with quick reference - CD on quit (*easy* shell integration) - Sorting - Ordered pure numeric names by default (visit _/proc_) - Case-insensitive version (_aka_ natural) sort - By file name, modification/access time, size, extension - Search - Instant filtering with *search-as-you-type* - Regex and substring match - Subtree search to open or edit files (using plugin) - Mimes - Open with desktop opener or specify a custom app - Create, list, extract archives - Option to open all text files in EDITOR - Information - Detailed file information - Media information (using plugin) - Convenience - Lots of plugins with configurable keybinds - FreeDesktop compliant trash (needs trash-cli) - SSHFS mounts (needs sshfs) - Cross-directory file selection, all/range selection - Batch rename selection or dir entries - Copy, move, delete, archive, link selection - Create, rename, duplicate files and directories - Spawn a shell, run apps, run commands, execute file - Lock terminal (needs a locker) - Minimal deps, minimal config - Widely available - Unicode support - Follows Linux kernel coding style - Highly optimized, static analysis integrated code ## Quickstart While we strongly advise reading this page and the wiki, if you can't wait to start: 1. Install the [utilities you may need](https://github.com/jarun/nnn#utility-dependencies) based on your regular workflows. 2. Configure [cd on quit](https://github.com/jarun/nnn/wiki/Basic-use-cases#configure-cd-on-quit). 3. Optionally open all text files in `$EDITOR` (fallback vi): `export NNN_USE_EDITOR=1` 4. For additional functionality [install plugins](https://github.com/jarun/nnn/tree/master/plugins#installing-plugins) and the GUI app launcher [`nlaunch`](https://github.com/jarun/nnn/tree/master/misc/nlaunch). Notes: 1. Don't memorize keys. Arrows, / and q suffice. Press ? for help on keyboard shortcuts anytime. 2. To set `nnn` as the default file manager, follow these [instructions](https://github.com/jarun/nnn/wiki/Advanced-use-cases#configure-as-default-fm). ## Installation #### Library dependencies A curses library with wide char support (e.g. ncursesw), libreadline (`make norl` to drop) and standard libc. #### Utility dependencies | Dependency | Installation | Operation | | --- | --- | --- | | xdg-open (Linux), open(1) (macOS), cygstart (Cygwin) | base | desktop opener | | file, coreutils (cp, mv, rm), findutils (xargs) | base | file type, copy, move and remove | | tar, (un)zip [atool/bsdtar for more formats] | base | create, list, extract tar, gzip, bzip2, zip | | sshfs, fusermount(3) | if needed | mount, unmount over SSHFS | | trash-cli | optional | trash files (default action: delete) | | vlock (Linux), bashlock (macOS), lock(1) (BSD) | optional | terminal locker (fallback: [cmatrix](https://github.com/abishekvashok/cmatrix)) | | advcpmv (Linux) ([integration](https://github.com/jarun/nnn/wiki/Advanced-use-cases#show-cp-mv-progress)) | optional | copy, move progress | | `$VISUAL` (else `$EDITOR`), `$PAGER`, `$SHELL` | optional | fallback vi, less, sh | #### From a package manager Install `nnn` from your package manager. If the version available is dated try an alternative installation method.
● CentOS (yum --enablerepo=epel install nnn
)
● Milis Linux (mps kur nnn
)
● NuTyX (cards install nnn
)
● Source Mage (cast nnn
)