My build of nnn with minor changes
Vous ne pouvez pas sélectionner plus de 25 sujets Les noms de sujets doivent commencer par une lettre ou un nombre, peuvent contenir des tirets ('-') et peuvent comporter jusqu'à 35 caractères.

README.md 13 KiB

il y a 5 ans
il y a 8 ans
il y a 7 ans
il y a 5 ans
il y a 5 ans
il y a 7 ans
il y a 5 ans
il y a 5 ans
il y a 8 ans
il y a 5 ans
il y a 7 ans
il y a 5 ans
il y a 7 ans
il y a 5 ans
il y a 5 ans
il y a 7 ans
il y a 5 ans
il y a 7 ans
il y a 5 ans
il y a 7 ans
il y a 8 ans
il y a 5 ans
il y a 5 ans
il y a 5 ans
il y a 5 ans
il y a 5 ans
il y a 5 ans
il y a 5 ans
il y a 5 ans
il y a 7 ans
il y a 5 ans
il y a 5 ans
il y a 5 ans
il y a 5 ans
il y a 7 ans
il y a 5 ans
il y a 5 ans
il y a 6 ans
il y a 7 ans
il y a 5 ans
il y a 5 ans
il y a 5 ans
il y a 7 ans
il y a 5 ans
il y a 5 ans
il y a 5 ans
il y a 7 ans
il y a 5 ans
il y a 7 ans
il y a 5 ans
il y a 5 ans
il y a 7 ans
il y a 5 ans
il y a 5 ans
il y a 5 ans
il y a 5 ans
il y a 5 ans
il y a 5 ans
il y a 7 ans
il y a 5 ans
il y a 5 ans
il y a 8 ans
il y a 5 ans
il y a 5 ans
il y a 5 ans
il y a 5 ans
il y a 5 ans
il y a 5 ans
il y a 5 ans
il y a 8 ans
il y a 5 ans
il y a 5 ans
il y a 5 ans
il y a 5 ans
il y a 5 ans
il y a 8 ans
il y a 5 ans
il y a 5 ans
il y a 5 ans
il y a 5 ans
il y a 5 ans
il y a 5 ans
il y a 5 ans
il y a 5 ans
il y a 5 ans
il y a 7 ans
il y a 5 ans
il y a 5 ans
il y a 5 ans
il y a 5 ans
il y a 5 ans
il y a 5 ans
il y a 5 ans
il y a 7 ans
il y a 5 ans
il y a 6 ans
il y a 5 ans
il y a 5 ans
il y a 6 ans
il y a 7 ans
il y a 5 ans
il y a 5 ans
il y a 5 ans
il y a 5 ans
il y a 5 ans
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304
  1. <h1 align="center">nnn - <i>type less, do more, way faster</i></h1>
  2. <p align="center">
  3. <a href="https://github.com/jarun/nnn/releases/latest"><img src="https://img.shields.io/github/release/jarun/nnn.svg?maxAge=600" alt="Latest release" /></a>
  4. <a href="https://repology.org/metapackage/nnn"><img src="https://repology.org/badge/tiny-repos/nnn.svg" alt="Availability"></a>
  5. <a href="https://travis-ci.org/jarun/nnn"><img src="https://img.shields.io/travis/jarun/nnn/master.svg?label=travis" alt="Travis Status" /></a>
  6. <a href="https://circleci.com/gh/jarun/workflows/nnn"><img src="https://img.shields.io/circleci/project/github/jarun/nnn.svg?label=circleci" alt="CircleCI Status" /></a>
  7. <a href="https://github.com/jarun/nnn/blob/master/LICENSE"><img src="https://img.shields.io/badge/license-BSD%202--Clause-yellow.svg?maxAge=2592000" alt="License" /></a>
  8. <a href="https://www.paypal.com/cgi-bin/webscr?cmd=_s-xclick&hosted_button_id=RMLTQ76JSXJ4Q"><img src="https://img.shields.io/badge/PayPal-donate-1eb0fc.svg" alt="Donate via PayPal!" /></a>
  9. </p>
  10. <p align="center"><img src="https://i.imgur.com/MPWpmos.png" /></p>
  11. <p align="center"><i>navigate-as-you-type & du analyzer mode</i></p>
  12. ## Index
  13. - [Introduction](#introduction)
  14. - [Wiki, resources](#wiki-resources)
  15. - [Features](#features)
  16. - [Quickstart](#quickstart)
  17. - [Installation](#installation)
  18. - [Library dependencies](#library-dependencies)
  19. - [Utility dependencies](#utility-dependencies)
  20. - [From a package manager](#from-a-package-manager)
  21. - [Release packages](#release-packages)
  22. - [From source](#from-source)
  23. - [Shell completion](#shell-completion)
  24. - [Usage](#usage)
  25. - [Configuration](#configuration)
  26. - [Cmdline options](#cmdline-options)
  27. - [Keyboard and mouse](#keyboard-and-mouse)
  28. - [Leader key](#leader-key)
  29. - [Help](#help)
  30. - [Mentions](#mentions)
  31. - [Developers](#developers)
  32. ## Introduction
  33. `nnn` is a full-featured terminal file manager. It's tiny, extremely light and fast.
  34. `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.
  35. 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.
  36. 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.
  37. ## Wiki, resources
  38. 1. [Wiki](https://github.com/jarun/nnn/wiki) (concepts, how-tos, use cases, troubleshooting and more...)
  39. 2. [Performance numbers](https://github.com/jarun/nnn/wiki/Performance)
  40. 3. [Plugin repository and docs](https://github.com/jarun/nnn/tree/master/plugins)
  41. 4. [(neo)vim plugin](https://github.com/mcchrish/nnn.vim)
  42. 5. [Demo video](https://www.youtube.com/watch?v=U2n5aGqou9E) (v2.1)
  43. 6. [nnn on Android](https://www.youtube.com/watch?v=AbaauM7gUJw)
  44. ## Features
  45. - Modes
  46. - Light (default), detail
  47. - Disk usage analyzer (block/apparent)
  48. - File picker, (neo)vim plugin
  49. - Navigation
  50. - *Navigate-as-you-type* with dir auto-select
  51. - Contexts (_aka_ tabs/workspaces) with configurable colors
  52. - Bookmarks; pin and visit a directory
  53. - Familiar shortcuts (arrows, <kbd>~</kbd>, <kbd>-</kbd>, <kbd>@</kbd>) with quick reference
  54. - CD on quit (*easy* shell integration)
  55. - Sorting
  56. - Ordered pure numeric names by default (visit _/proc_)
  57. - Case-insensitive version (_aka_ natural) sort
  58. - By file name, modification/access time, size, extension
  59. - Search
  60. - Instant filtering with *search-as-you-type*
  61. - Regex and substring match
  62. - Subtree search to open or edit files (using plugin)
  63. - Mimes
  64. - Open with desktop opener or specify a custom app
  65. - Create, list, extract archives
  66. - Option to open all text files in EDITOR
  67. - Information
  68. - Detailed file information
  69. - Media information (using plugin)
  70. - Convenience
  71. - Lots of plugins with configurable keybinds
  72. - FreeDesktop compliant trash (needs trash-cli)
  73. - SSHFS mounts (needs sshfs)
  74. - Cross-directory file selection, all/range selection
  75. - Batch rename selection or dir entries
  76. - Copy, move, delete, archive, link selection
  77. - Create, rename, duplicate files and directories
  78. - Spawn a shell, run apps, run commands, execute file
  79. - Lock terminal (needs a locker)
  80. - Minimal deps, minimal config
  81. - Widely available
  82. - Unicode support
  83. - Follows Linux kernel coding style
  84. - Highly optimized, static analysis integrated code
  85. ## Quickstart
  86. While we strongly advise reading this page and the wiki, if you can't wait to start:
  87. 1. Install the [utilities you may need](https://github.com/jarun/nnn#utility-dependencies) based on your regular workflows.
  88. 2. Configure [cd on quit](https://github.com/jarun/nnn/wiki/Basic-use-cases#configure-cd-on-quit).
  89. 3. Optionally open all text files in `$EDITOR` (fallback vi): `export NNN_USE_EDITOR=1`
  90. 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).
  91. Notes:
  92. 1. Don't memorize keys. Arrows, <kbd>/</kbd> and <kbd>q</kbd> suffice. Press <kbd>?</kbd> for help on keyboard shortcuts anytime.
  93. 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).
  94. ## Installation
  95. #### Library dependencies
  96. A curses library with wide char support (e.g. ncursesw), libreadline (`make norl` to drop) and standard libc.
  97. #### Utility dependencies
  98. | Dependency | Installation | Operation |
  99. | --- | --- | --- |
  100. | xdg-open (Linux), open(1) (macOS), cygstart (Cygwin) | base | desktop opener |
  101. | file, coreutils (cp, mv, rm), findutils (xargs) | base | file type, copy, move and remove |
  102. | tar, (un)zip [atool/bsdtar for more formats] | base | create, list, extract tar, gzip, bzip2, zip |
  103. | sshfs, fusermount(3) | if needed | mount, unmount over SSHFS |
  104. | trash-cli | optional | trash files (default action: delete) |
  105. | vlock (Linux), bashlock (macOS), lock(1) (BSD) | optional | terminal locker (fallback: [cmatrix](https://github.com/abishekvashok/cmatrix)) |
  106. | advcpmv (Linux) ([integration](https://github.com/jarun/nnn/wiki/Advanced-use-cases#show-cp-mv-progress)) | optional | copy, move progress |
  107. | `$VISUAL` (else `$EDITOR`), `$PAGER`, `$SHELL` | optional | fallback vi, less, sh |
  108. #### From a package manager
  109. Install `nnn` from your package manager. If the version available is dated try an alternative installation method.
  110. <details><summary>Packaging status (expand)</summary>
  111. <p>
  112. <br>
  113. <a href="https://repology.org/metapackage/nnn/versions"><img src="https://repology.org/badge/vertical-allrepos/nnn.svg" alt="Packaging status"></a>
  114. </p>
  115. Unlisted distros:
  116. <p>
  117. <br>
  118. ● CentOS (<code>yum --enablerepo=epel install nnn</code>)<br>
  119. ● <a href="https://notabug.org/milislinux/milis/src/master/talimatname/genel/n/nnn/talimat">Milis Linux</a> (<code>mps kur nnn</code>)<br>
  120. ● <a href="https://www.nutyx.org/en/?type=pkg&branch=rolling&arch=x86_64&searchpkg=nnn">NuTyX</a> (<code>cards install nnn</code>)<br>
  121. ● <a href="http://codex.sourcemage.org/test/shell-term-fm/nnn/">Source Mage</a> (<code>cast nnn</code>)<br>
  122. </p>
  123. </details>
  124. #### Release packages
  125. Packages for Arch Linux, CentOS, Debian, Fedora and Ubuntu are auto-generated with the [latest stable release](https://github.com/jarun/nnn/releases/latest).
  126. #### From source
  127. Download the latest stable release or clone this repository (*risky*), install deps and compile. On Ubuntu 16.04:
  128. $ sudo apt-get install pkg-config libncursesw5-dev libreadline6-dev
  129. $ make
  130. $ sudo make strip install
  131. `PREFIX` is supported, in case you want to install to a different location.
  132. Visit the [developer guides](https://github.com/jarun/nnn/wiki/Developer-guides) for compilation notes on the Pi, Cygwin and other compilation modes.
  133. #### Shell completion
  134. Completion scripts for Bash, Fish and Zsh are [available](misc/auto-completion). Refer to your shell's manual for installation instructions.
  135. ## Usage
  136. #### Configuration
  137. There is no config file. Associated files are stored under `${XDG_CONFIG_HOME:-$HOME/.config}/nnn/`.
  138. `nnn` supports the following optional (set if you need) environment variables.
  139. | Example `export` | Description |
  140. | --- | --- |
  141. | `NNN_BMS='d:~/Documents;D:~/Docs archive/'` | key-bookmark pairs [max 10] |
  142. | `NNN_PLUG='o:fzy-open;p:mocplay;m:nmount;t:thumb'` | key-plugin pairs (<kbd>:key</kbd> to run) [max 10] |
  143. | `NNN_USE_EDITOR=1` | open text files in `$VISUAL` (else `$EDITOR`, fallback vi) |
  144. | `NNN_CONTEXT_COLORS='1234'` | specify per context color [default: '4444' (all blue)] |
  145. | `NNN_SSHFS_OPTS='sshfs -o reconnect,idmap=user'` | specify SSHFS options |
  146. | `NNN_OPENER=mimeopen` | custom file opener |
  147. | `NNN_IDLE_TIMEOUT=300` | idle seconds to lock terminal [default: disabled] |
  148. | `NNN_COPIER=copier` | clipboard copier script [default: none] |
  149. | `NNN_TRASH=1` | trash files to the desktop Trash [default: delete] |
  150. #### Cmdline options
  151. ```
  152. usage: nnn [OPTIONS] [PATH]
  153. The missing terminal file manager for X.
  154. positional args:
  155. PATH start dir [default: .]
  156. optional args:
  157. -a use access time
  158. -b key open bookmark key
  159. -d detail mode
  160. -f run filter as cmd on prompt key
  161. -H show hidden files
  162. -i nav-as-you-type mode
  163. -n version sort
  164. -o press Enter to open files
  165. -p file selection file (stdout if '-')
  166. -r show cp, mv progress on Linux
  167. -s string filters [default: regex]
  168. -S du mode
  169. -t disable dir auto-select
  170. -v show version
  171. -h show help
  172. ```
  173. #### Keyboard and mouse
  174. Press <kbd>?</kbd> in `nnn` to see the list anytime (the listing below is from **dev branch**).
  175. ```
  176. NAVIGATION
  177. ↑ k Up PgUp ^U Scroll up
  178. ↓ j Down PgDn ^D Scroll down
  179. ← h Parent dir ~ ` @ - HOME, /, start, last
  180. ↵ → l Open file/dir . Toggle show hidden
  181. g ^A First entry G ^E Last entry
  182. b Pin current dir ^B Go to pinned dir
  183. Tab ^I Next context d Toggle detail view
  184. , ^/ Lead key N LeadN Context N
  185. / Filter/Lead Ins ^T Toggle nav-as-you-type
  186. Esc Exit prompt ^L F5 Redraw/clear prompt
  187. ? Help, config Lead' First file
  188. Q ^Q Quit ^G QuitCD q Quit context
  189. FILES
  190. ^O Open with... n Create new/link
  191. D File detail ^R F2 Rename/duplicate
  192. ⎵ ^J / a Sel entry/all r Batch rename
  193. m ^S Sel range, clear M List selection
  194. P Copy selection X Delete selection
  195. V Move selection ^X Delete entry
  196. f Create archive C Execute entry
  197. ^F Extract archive F List archive
  198. e Edit in EDITOR p Open in PAGER
  199. ORDER TOGGLES
  200. A Apparent du S du
  201. s Size E Extn t Time
  202. MISC
  203. ! ^] Shell = Launcher
  204. R ^V Pick plugin :K xK Run plugin key K
  205. c SSHFS mount u Unmount
  206. ^P Prompt/run cmd L Lock
  207. ```
  208. Note: Help & settings, file details and archive listing are shown in the `$PAGER`.
  209. | Mouse click | Function |
  210. |---| --- |
  211. | Left single on context number | Visit context |
  212. | Left single on top row after context numbers | Visit parent |
  213. | Left single/double on last 2 rows | Toggle nav-as-you-type |
  214. | Left single | Select context or entry |
  215. | Left double | Select context or open entry |
  216. #### Leader key
  217. The Leader/Lead key provides a powerful multi-functional navigation mechanism. It is case-sensitive and understands contexts, bookmarks and location shortcuts.
  218. | Key | Function |
  219. |:---:| --- |
  220. | <kbd>1-4</kbd> | Go to/create selected context |
  221. | <kbd>]</kbd> | Go to next active context |
  222. | <kbd>[</kbd> | Go to previous active context |
  223. | key | Go to bookmarked location |
  224. | <kbd>'</kbd> | Go to first file in directory |
  225. | <kbd>~</kbd> <kbd>`</kbd> <kbd>@</kbd> <kbd>-</kbd> | Visit HOME, `/`, start, last visited dir |
  226. | <kbd>.</kbd> | Toggle show hidden files |
  227. When the filter is on, <kbd>/</kbd> works as an additional Leader key.
  228. #### Help
  229. $ nnn -h
  230. $ man nnn
  231. To lookup keyboard shortcuts at runtime, press <kbd>?</kbd>.
  232. ## Mentions
  233. - [FOSSMint](https://www.fossmint.com/nnn-linux-terminal-file-browser/)
  234. - Hacker News [[1](https://news.ycombinator.com/item?id=18520898)] [[2](https://news.ycombinator.com/item?id=19850656)]
  235. - [It's FOSS](https://itsfoss.com/nnn-file-browser-linux/)
  236. - LinuxLinks [[1](https://www.linuxlinks.com/nnn-fast-and-flexible-file-manager/)] [[2](https://www.linuxlinks.com/bestconsolefilemanagers/)]
  237. - [Suckless Rocks](https://suckless.org/rocks/)
  238. - [Ubuntu Full Circle Magazine - Issue 135](https://fullcirclemagazine.org/issue-135/)
  239. ## Developers
  240. - Copyright © 2016-2019 [Arun Prakash Jana](https://github.com/jarun)
  241. - Copyright © 2014-2016 Lazaros Koromilas
  242. - Copyright © 2014-2016 Dimitris Papastamos
  243. Contributions are welcome. Head to the [ToDo list](https://github.com/jarun/nnn/issues/332).