2019-02-19 10:26:48 +00:00
.Dd Feb 19 , 2019
2017-03-30 18:25:30 +00:00
.Dt NNN 1
2014-10-22 11:52:45 +00:00
.Os
.Sh NAME
2017-03-30 18:25:30 +00:00
.Nm nnn
2018-08-06 23:22:39 +00:00
.Nd the missing terminal file manager for X
2014-10-22 11:52:45 +00:00
.Sh SYNOPSIS
2017-06-04 17:45:08 +00:00
.Nm
2017-12-24 09:51:38 +00:00
.Op Ar -b key
2018-12-03 16:14:33 +00:00
.Op Ar -C
2017-07-03 04:16:37 +00:00
.Op Ar -e
2017-06-04 06:15:17 +00:00
.Op Ar -i
2017-07-03 04:16:37 +00:00
.Op Ar -l
2019-02-05 19:08:55 +00:00
.Op Ar -n
2018-11-23 17:11:47 +00:00
.Op Ar -p file
2019-02-05 19:08:55 +00:00
.Op Ar -s
2017-04-14 18:44:25 +00:00
.Op Ar -S
.Op Ar -v
2019-02-27 15:33:14 +00:00
.Op Ar -w
2017-04-14 18:44:25 +00:00
.Op Ar -h
.Op Ar PATH
2014-10-22 11:52:45 +00:00
.Sh DESCRIPTION
.Nm
2018-12-16 14:59:03 +00:00
(Noice is Not Noice) is a performance-optimized, feature-packed fork of noice (http://git.2f30.org/noice/) with seamless desktop integration, simplified navigation, \fI navigate-as-you-type\fR mode with auto select, disk usage analyzer mode, bookmarks, contexts, application launcher, familiar navigation shortcuts, subshell spawning and much more. It remains a simple and efficient file manager that stays out of your way.
2014-10-22 11:52:45 +00:00
.Pp
.Nm
2017-12-24 13:16:56 +00:00
opens the current working directory by default if
2017-04-14 18:44:25 +00:00
.Ar PATH
2017-03-31 02:52:51 +00:00
is not specified.
2018-11-11 10:52:58 +00:00
.Sh KEYBINDS
2014-10-22 12:28:00 +00:00
.Pp
2018-11-11 10:52:58 +00:00
NAVIGATION
.Pp
2014-11-14 14:41:46 +00:00
.Bl -tag -width "l, [Right], [Return] or C-mXXXX" -offset indent -compact
2019-01-23 16:03:43 +00:00
.It Ic [Up], k
2017-03-31 18:05:48 +00:00
Move to previous entry
2019-01-23 16:03:43 +00:00
.It Ic [Down], j
2017-03-31 18:05:48 +00:00
Move to next entry
2019-01-23 16:03:43 +00:00
.It Ic [Left], h
2019-01-19 07:01:25 +00:00
Go to parent directory
2019-01-23 16:09:41 +00:00
.It Ic [Right], [Enter], l
2019-01-19 07:01:25 +00:00
Open file or enter directory
2017-04-03 17:03:46 +00:00
.It Ic [PgUp], ^U
2017-03-31 18:05:48 +00:00
Scroll up half a page
2017-04-03 17:03:46 +00:00
.It Ic [PgDn], ^D
2017-03-31 18:05:48 +00:00
Scroll down half a page
2019-01-19 07:01:25 +00:00
.It Ic [Home], g, ^A
2017-03-31 18:05:48 +00:00
Move to the first entry
2019-01-19 07:01:25 +00:00
.It Ic [End], G, ^E
2017-03-31 18:05:48 +00:00
Move to the last entry
2017-03-31 02:52:51 +00:00
.It Ic ~
2017-03-31 18:05:48 +00:00
Change to the HOME directory
2017-04-23 21:06:49 +00:00
.It Ic &
Change to initial directory
2018-04-25 19:11:40 +00:00
.It Ic \-
2017-04-08 08:16:03 +00:00
Change to the last visited directory
2017-06-03 23:19:16 +00:00
.It Ic \& .
2018-04-01 18:09:51 +00:00
Toggle show hidden . (dot) files
2018-11-11 10:52:58 +00:00
.It Ic /
Change filter (more information below)
2018-12-05 00:14:33 +00:00
.It Ic [Insert], ^T
2018-11-11 10:52:58 +00:00
Toggle navigate-as-you-type mode
2018-01-17 14:02:22 +00:00
.It Ic b
2017-12-25 10:25:53 +00:00
Pin current directory
2019-01-29 18:07:09 +00:00
.It Ic ^B
2017-12-25 10:25:53 +00:00
Visit pinned directory
2018-11-27 13:07:31 +00:00
.It Ic d
Toggle detail view
2018-12-05 00:14:33 +00:00
.It Ic Tab, ^I
2018-12-03 03:48:51 +00:00
Next context, ask to create if none
2019-02-05 18:28:13 +00:00
.It Ic ,, ^/
2018-11-11 21:34:17 +00:00
Leader key
2019-01-19 07:39:46 +00:00
.It Ic N, LeaderN
2018-11-11 21:34:17 +00:00
Switch to context N
2018-11-11 10:52:58 +00:00
.It Ic Esc
Exit prompt
2018-11-11 21:34:17 +00:00
.It Ic ^L
Force a redraw, clear prompt
2018-11-11 10:52:58 +00:00
.It Ic q
Quit the current context
.It Ic ^G
Quit and change directory
.It Ic Q, ^Q
Quit
.It Ic \& ?
2018-11-23 05:14:39 +00:00
Help and configuration screen
2018-11-11 10:52:58 +00:00
.El
.Pp
FILES
.Pp
.Bl -tag -width "l, [Right], [Return] or C-mXXXX" -offset indent -compact
.It Ic ^O
2018-12-06 17:27:59 +00:00
Open with an application (takes 1 combined argument)
2017-09-10 07:35:25 +00:00
.It Ic n
2019-01-20 11:29:55 +00:00
Create a new file, directory or link(s) to selection
2018-11-11 10:52:58 +00:00
.It Ic D
Show entry details
2017-08-22 19:16:58 +00:00
.It Ic ^R
Rename selected entry
2018-03-19 00:02:16 +00:00
.It Ic r
Open directory in vidir
2019-02-23 14:43:04 +00:00
.It Ic K, ^Y
2018-11-11 00:21:05 +00:00
Toggle selection mode
2019-01-29 21:28:42 +00:00
.It Ic Y
Select all entries in dir
2018-11-11 10:52:58 +00:00
.It Ic Space, ^K
2019-02-05 21:13:05 +00:00
Select entry and copy absolute path
2018-10-22 14:03:27 +00:00
.It Ic y
2018-11-11 10:52:58 +00:00
Show selection list
2018-11-11 00:21:05 +00:00
.It Ic P
Copy files from selection
.It Ic V
Move files from selection
.It Ic X
2018-11-17 03:01:47 +00:00
Delete files from selection
.It Ic ^X
2018-11-11 10:52:58 +00:00
Delete entry
.It Ic f
2019-01-31 01:29:57 +00:00
Archive files
2018-11-11 10:52:58 +00:00
.It Ic F
List files in archive
.It Ic ^F
Extract archive in current directory
.It Ic m, M
Show brief/full media info
.It Ic e
Open entry in EDITOR (fallback vi)
.It Ic p
Open entry in PAGER (fallback less)
.El
.Pp
2018-12-09 02:14:03 +00:00
ORDER TOGGLES
2018-11-11 10:52:58 +00:00
.Pp
.Bl -tag -width "l, [Right], [Return] or C-mXXXX" -offset indent -compact
.It Ic ^J
Toggle disk usage analyzer mode
.It Ic S
Toggle sort by apparent size
2019-02-27 15:33:14 +00:00
.It Ic ^W
Wild mode
2018-11-11 10:52:58 +00:00
.It Ic t
Toggle sort by time modified
2018-12-09 02:14:03 +00:00
.It Ic s
Toggle sort by file size
2018-11-11 10:52:58 +00:00
.El
.Pp
MISC
.Pp
.Bl -tag -width "l, [Right], [Return] or C-mXXXX" -offset indent -compact
.It Ic \& !, ^]
Spawn SHELL in current directory (fallback sh)
2018-12-09 13:48:00 +00:00
.It Ic C
2018-12-08 12:52:06 +00:00
Execute entry
2019-01-05 20:38:07 +00:00
.It Ic R, ^V
2019-01-31 13:58:35 +00:00
Run or pick a script to run
2018-11-11 10:52:58 +00:00
.It Ic L
2018-12-09 13:48:00 +00:00
Lock terminal
2019-01-31 13:58:35 +00:00
.It Ic ^N
2019-01-19 09:08:47 +00:00
Take note
2019-01-29 18:10:27 +00:00
.It Ic ^P
Show command prompt
2014-10-22 11:57:22 +00:00
.El
2014-11-14 14:45:17 +00:00
.Pp
Backing up one directory level will set the cursor position at the
directory you came out of.
2017-04-01 05:18:18 +00:00
.Pp
2017-09-30 00:17:38 +00:00
Help & settings, file details, media info and archive listing are shown in the
PAGER. Please use the PAGER-specific keys in these screens.
2018-11-11 10:52:58 +00:00
.Sh OPTIONS
2017-09-30 00:17:38 +00:00
.Pp
2017-04-01 05:18:18 +00:00
.Nm
2017-04-13 13:43:33 +00:00
supports the following options:
2017-04-01 05:18:18 +00:00
.Pp
2017-12-24 09:51:38 +00:00
.Fl "b key"
specify bookmark key to open
.Pp
2018-12-03 16:14:33 +00:00
.Fl C
disable directory color
2017-07-02 20:56:47 +00:00
.Pp
2017-07-02 18:27:41 +00:00
.Fl e
use exiftool instead of mediainfo
2017-04-14 11:20:16 +00:00
.Pp
2017-06-04 06:15:17 +00:00
.Fl i
2017-06-03 23:19:16 +00:00
start in navigate-as-you-type mode
.Pp
2017-07-02 18:27:41 +00:00
.Fl l
start in light mode (fewer details)
.Pp
2019-02-05 18:18:34 +00:00
.Fl n
use version compare to sort files
.Pp
2018-11-23 17:11:47 +00:00
.Fl "p file"
copy (or \fI pick\fR ) selection to file, or stdout if file='-'
.Pp
2019-02-05 19:08:55 +00:00
.Fl s
use substring match for filters instead of regex
.Pp
2017-04-14 11:20:16 +00:00
.Fl S
start in disk usage analyzer mode
2017-04-13 13:43:33 +00:00
.Pp
.Fl v
show version and exit
2017-04-14 18:44:25 +00:00
.Pp
2019-02-27 15:33:14 +00:00
.Fl w
wild mode - entries unsorted on directory load
.Pp
2017-04-14 18:44:25 +00:00
.Fl h
show program help and exit
2014-10-22 11:52:45 +00:00
.Sh CONFIGURATION
.Nm
2018-12-01 23:40:19 +00:00
uses \fI xdg-open\fR (on Linux) and \fI open(1)\fR (on macOS) as the desktop opener.
2017-04-23 17:42:54 +00:00
.Pp
2017-06-11 13:54:02 +00:00
There is no configuration file. Settings work on environment variables. Please
refer to the ENVIRONMENT section below.
.Pp
2017-04-19 12:52:30 +00:00
Configuring
.Nm
to change to the last visited directory on quit requires shell integration in a
few easy steps. Please visit the project page (linked below) for the
instructions.
2018-11-08 12:59:38 +00:00
.Sh CONTEXTS
2018-11-11 22:06:37 +00:00
Contexts serve the purpose of exploring multiple directories simultaneously. 4 contexts
are available. The status of the contexts are shown in the top left corner:
2018-11-08 12:59:38 +00:00
.Pp
- the current context is in reverse
.br
- other used contexts are underlined
.br
- rest are unused
.Pp
2018-11-11 22:06:37 +00:00
To switch to a context press the Leader key followed by the context number (1-4).
2018-11-08 12:59:38 +00:00
.Pp
The first time a context is entered, it copies the state of the last visited context. Each context remembers its start directory and last visited directory.
2018-11-08 14:46:08 +00:00
.Pp
When a context is quit, the next active context is selected. If the last active context is quit, the program quits.
2014-10-22 11:52:45 +00:00
.Sh FILTERS
2019-01-13 17:19:14 +00:00
Filters support regexes by default to instantly (search-as-you-type) list the matching
2017-06-07 05:56:33 +00:00
entries in the current directory.
2014-10-22 11:52:45 +00:00
.Pp
2018-01-13 20:13:30 +00:00
Common use cases:
.Pp
(1) To list all matches starting with the filter expression, start the expression
with a '^' (caret) symbol.
.br
(2) Type '\\ .mkv' to list all MKV files.
2018-05-01 04:39:10 +00:00
.br
(3) Use '.*' to match any character (\fI sort of\fR fuzzy search).
2014-10-22 12:28:00 +00:00
.Pp
2019-02-05 19:08:55 +00:00
There is a program option to filter entries by substring match.
2019-01-13 17:19:14 +00:00
.Pp
2014-10-22 12:28:00 +00:00
If
.Nm
2018-04-04 01:07:29 +00:00
is invoked as root or the environment variable \fB NNN_SHOW_HIDDEN\fR is set the default filter will also match hidden files.
2017-06-03 23:19:16 +00:00
.Pp
2017-06-06 16:07:16 +00:00
In the \fI navigate-as-you-type\fR mode directories are opened in filter mode,
2017-06-04 17:45:08 +00:00
allowing continuous navigation. Works best with the \fB arrow keys\fR .
2018-08-07 23:27:49 +00:00
.br
In case of only one match and it's a directory, `nnn` auto selects the directory and enters it in this mode.
2019-02-27 15:33:14 +00:00
.br
The \fI wild mode\fR can be handy for users who use the \fI navigate-as-you-type\fR mode constantly. The entries are unsorted when the directory loads. Applying filters sort the entries (with directories on top). Directory color is disabled in this mode.
2018-11-11 00:21:05 +00:00
.Sh SELECTION MODE
2018-01-13 20:13:30 +00:00
The absolute path of a single file can be copied to clipboard by pressing \fI ^K\fR if
NNN_COPIER is set (see ENVIRONMENT section below).
.Pp
2019-02-05 21:13:05 +00:00
To select multiple files the selection mode should be enabled using \fI ^Y\fR .
2018-01-13 20:13:30 +00:00
In this mode it's possible to
.Pp
2018-12-01 03:29:19 +00:00
(1) cherry-pick individual files one by one by pressing <kbd>^K</kbd> on each entry (works across directories and contexts); or,
2018-01-13 20:13:30 +00:00
.br
(2) navigate to another file in the same directory to select a range of files.
.Pp
2019-02-05 21:13:05 +00:00
Pressing \fI ^Y\fR again saves the selection to the list and exits the selection mode.
The files in the list can now be copied, moved or removed using respective keyboard shortcuts.
2018-11-10 14:12:09 +00:00
.Pp
2019-02-05 21:13:05 +00:00
To list the selected files press \fI y\fR .
2015-11-26 15:03:26 +00:00
.Sh ENVIRONMENT
2018-04-08 00:43:33 +00:00
The SHELL, EDITOR (VISUAL, if defined) and PAGER environment variables take precedence
2019-01-04 18:26:02 +00:00
when dealing with the !, e and p commands respectively. A single combination to arguments is supported for SHELL and PAGER.
2016-08-21 08:28:53 +00:00
.Pp
2018-11-11 21:34:17 +00:00
\fB NNN_BMS:\fR bookmark string as \fI key_char:location\fR pairs (max 10) separated by
2017-06-11 04:15:50 +00:00
\fI ;\fR :
.Bd -literal
2018-11-11 21:34:17 +00:00
export NNN_BMS='d:~/Documents;u:/home/user/Cam Uploads;D:~/Downloads/'
NOTE: Bookmark keys should be single-character to use them in combination with the Leader key.
2017-06-11 04:15:50 +00:00
.Ed
.Pp
2019-01-20 18:21:45 +00:00
\fB NNN_OPENER:\fR specify a custom file opener.
2017-06-11 13:54:02 +00:00
.Bd -literal
2019-01-20 18:21:45 +00:00
export NNN_OPENER=mimeopen
2017-06-11 13:54:02 +00:00
.Ed
.Pp
2018-12-03 16:14:33 +00:00
\fB NNN_CONTEXT_COLORS:\fR string of color codes for each context, e.g.:
.Bd -literal
2019-01-19 09:08:47 +00:00
export NNN_CONTEXT_COLORS='1234'
2018-12-03 16:14:33 +00:00
codes: 0-black, 1-red, 2-green, 3-yellow, 4-blue (default), 5-magenta, 6-cyan, 7-white
.Ed
.Pp
2018-12-09 02:48:30 +00:00
\fB NNN_IDLE_TIMEOUT:\fR set idle timeout (in seconds) to invoke terminal locker (default: disabled).
2017-06-04 18:46:43 +00:00
.Pp
2019-01-19 12:47:36 +00:00
\fB NNN_COPIER:\fR system clipboard copier script.
2017-03-30 18:25:30 +00:00
.Bd -literal
2019-01-19 12:47:36 +00:00
NOTE: File paths are copied to the tmp file \fB DIR/.nnncp\fR , where 'DIR' (by priority) is:
2018-12-01 16:12:51 +00:00
\fI $HOME\fR or, \fI $TMPDIR\fR or, \fI /tmp\fR .
The path is shown in the help and configuration screen.
2017-04-15 04:00:41 +00:00
.Ed
2018-02-24 03:03:22 +00:00
.Pp
2019-01-19 09:08:47 +00:00
\fB NNN_SCRIPT:\fR \fI absolute\fR path to a directory to select a script from or a single script to invoke with currently selected file name as argument 1.
2018-03-19 00:02:16 +00:00
.Bd -literal
2018-12-15 18:54:45 +00:00
export NNN_SCRIPT=/home/user/scripts
OR
export NNN_SCRIPT=/usr/local/bin/nscript.sh
2018-06-17 16:17:19 +00:00
.Ed
.Pp
2019-01-19 09:08:47 +00:00
\fB NNN_NOTE:\fR \fI absolute\fR path to a note file.
.Bd -literal
export NNN_NOTE='/home/user/.mynotes'
.Ed
.Pp
2019-01-20 18:21:45 +00:00
\fB NNN_TMPFILE:\fR when cd on quit is pressed, the absolute path of the current open directory is written to this file. A wrapper script can read this file and cd into it once the program quits.
.Bd -literal
export NNN_TMPFILE=/tmp/nnn
.Ed
.Pp
\fB NNN_USE_EDITOR:\fR use EDITOR (VISUAL takes preference, preferably CLI, fallback vi) to handle text
files.
.Bd -literal
export NNN_USE_EDITOR=1
.Ed
.Pp
2018-04-04 01:03:26 +00:00
\fB NNN_SHOW_HIDDEN:\fR show hidden files.
.Bd -literal
export NNN_SHOW_HIDDEN=1
.Ed
2018-10-21 18:00:46 +00:00
.Pp
2018-12-09 02:48:30 +00:00
\fB NNN_NO_AUTOSELECT:\fR disable directory auto-selection in \fI navigate-as-you-type\fR mode.
2018-10-21 18:00:46 +00:00
.Bd -literal
2018-11-22 22:27:18 +00:00
export NNN_NO_AUTOSELECT=1
2018-10-21 18:00:46 +00:00
.Ed
2018-11-26 18:54:12 +00:00
.Pp
2019-01-15 05:21:06 +00:00
\fB NNN_RESTRICT_NAV_OPEN:\fR disable file open on \fB Right\fR or \fB l\fR keys (\fB Enter\fR opens files).
2018-11-26 18:54:12 +00:00
.Bd -literal
2019-01-15 05:21:06 +00:00
export NNN_RESTRICT_NAV_OPEN=1
2018-11-26 18:54:12 +00:00
.Ed
2019-01-11 13:24:54 +00:00
.Pp
\fB NNN_RESTRICT_0B:\fR restrict opening 0-byte files due to unexpected behaviour; use \fI edit\fR or \fI open with\fR to open the file.
.Bd -literal
export NNN_RESTRICT_0B=1
.Ed
2019-02-25 14:07:23 +00:00
.Pp
\fB NNN_CP_MV_PROG:\fR show progress of copy, move operations (Linux-only, needs advcpmv).
.Bd -literal
export NNN_CP_MV_PROG=1
.Ed
2014-10-22 13:59:15 +00:00
.Sh KNOWN ISSUES
2018-10-19 09:54:15 +00:00
If you are using urxvt you might have to set backspace key to DEC.
2014-10-22 11:52:45 +00:00
.Sh AUTHORS
2015-07-02 16:49:17 +00:00
.An Lazaros Koromilas Aq Mt lostd@2f30.org ,
2017-03-31 02:52:51 +00:00
.An Dimitris Papastamos Aq Mt sin@2f30.org ,
.An Arun Prakash Jana Aq Mt engineerarun@gmail.com .
.Sh HOME
2017-04-01 05:18:18 +00:00
.Em https://github.com/jarun/nnn