diff options
author | Arun Prakash Jana <engineerarun@gmail.com> | 2017-07-05 08:38:34 +0530 |
---|---|---|
committer | Arun Prakash Jana <engineerarun@gmail.com> | 2017-07-05 08:38:34 +0530 |
commit | 9a4c4467600d02a445b5055d3278052b93395970 (patch) | |
tree | 7f4879e3b6c52038a39ad90058b2259dc227ed75 /config.h | |
parent | 3c612fe64d5814e4749ab5c0db0da1173489435d (diff) | |
download | nnn-9a4c4467600d02a445b5055d3278052b93395970.tar.gz |
Retire config.def.h, unify Makefiles
Diffstat (limited to 'config.h')
-rw-r--r-- | config.h | 143 |
1 files changed, 143 insertions, 0 deletions
diff --git a/config.h b/config.h new file mode 100644 index 0000000..45f036e --- /dev/null +++ b/config.h @@ -0,0 +1,143 @@ +/* See LICENSE file for copyright and license details. */ +#define CONTROL(c) ((c) ^ 0x40) + +/* Supported actions */ +enum action { + SEL_QUIT = 1, + SEL_CDQUIT, + SEL_BACK, + SEL_GOIN, + SEL_FLTR, + SEL_MFLTR, + SEL_SEARCH, + SEL_NEXT, + SEL_PREV, + SEL_PGDN, + SEL_PGUP, + SEL_HOME, + SEL_END, + SEL_CD, + SEL_CDHOME, + SEL_CDBEGIN, + SEL_CDLAST, + SEL_CDBM, + SEL_TOGGLEDOT, + SEL_DETAIL, + SEL_STATS, + SEL_MEDIA, + SEL_FMEDIA, + SEL_DFB, + SEL_FSIZE, + SEL_BSIZE, + SEL_MTIME, + SEL_REDRAW, + SEL_COPY, + SEL_HELP, + SEL_RUN, + SEL_RUNARG, +}; + +/* Associate a pressed key to an action */ +struct key { + int sym; /* Key pressed */ + enum action act; /* Action */ + char *run; /* Program to run */ + char *env; /* Environment variable to run */ +}; + +/* Extension pattern and mime combination */ +struct assoc { + char *regex; /* Regex to match on filename */ + char *mime; /* File type */ +}; + +static struct assoc assocs[] = { + { "\\.(c|cpp|h|log|md|py|sh|txt)$", "text" }, +}; + +static struct key bindings[] = { + /* Quit */ + { 'q', SEL_QUIT, "", "" }, + { CONTROL('Q'), SEL_QUIT, "", "" }, + /* Change dir on quit */ + { 'Q', SEL_CDQUIT, "", "" }, + /* Back */ + { KEY_BACKSPACE, SEL_BACK, "", "" }, + { KEY_LEFT, SEL_BACK, "", "" }, + { 'h', SEL_BACK, "", "" }, + { CONTROL('H'), SEL_BACK, "", "" }, + /* Inside */ + { KEY_ENTER, SEL_GOIN, "", "" }, + { '\r', SEL_GOIN, "", "" }, + { KEY_RIGHT, SEL_GOIN, "", "" }, + { 'l', SEL_GOIN, "", "" }, + /* Filter */ + { '/', SEL_FLTR, "", "" }, + /* Toggle filter mode */ + { KEY_IC, SEL_MFLTR, "", "" }, + /* Desktop search */ + { CONTROL('_'), SEL_SEARCH, "", "" }, + /* Next */ + { 'j', SEL_NEXT, "", "" }, + { KEY_DOWN, SEL_NEXT, "", "" }, + { CONTROL('N'), SEL_NEXT, "", "" }, + /* Previous */ + { 'k', SEL_PREV, "", "" }, + { KEY_UP, SEL_PREV, "", "" }, + { CONTROL('P'), SEL_PREV, "", "" }, + /* Page down */ + { KEY_NPAGE, SEL_PGDN, "", "" }, + { CONTROL('D'), SEL_PGDN, "", "" }, + /* Page up */ + { KEY_PPAGE, SEL_PGUP, "", "" }, + { CONTROL('U'), SEL_PGUP, "", "" }, + /* First entry */ + { KEY_HOME, SEL_HOME, "", "" }, + { 'g', SEL_HOME, "", "" }, + { CONTROL('A'), SEL_HOME, "", "" }, + { '^', SEL_HOME, "", "" }, + /* Last entry */ + { KEY_END, SEL_END, "", "" }, + { 'G', SEL_END, "", "" }, + { CONTROL('E'), SEL_END, "", "" }, + { '$', SEL_END, "", "" }, + /* Change dir */ + { 'c', SEL_CD, "", "" }, + /* HOME */ + { '~', SEL_CDHOME, "", "" }, + /* Initial directory */ + { '&', SEL_CDBEGIN, "", "" }, + /* Last visited dir */ + { '-', SEL_CDLAST, "", "" }, + /* Change dir using bookmark */ + { 'b', SEL_CDBM, "", "" }, + /* Toggle hide .dot files */ + { '.', SEL_TOGGLEDOT, "", "" }, + /* Detailed listing */ + { 'd', SEL_DETAIL, "", "" }, + /* File details */ + { 'D', SEL_STATS, "", "" }, + /* Show media info short, run is hacked */ + { 'm', SEL_MEDIA, NULL, "" }, + /* Show media info full, run is hacked */ + { 'M', SEL_FMEDIA, "-f", "" }, + /* Open dir in desktop file manager */ + { 'o', SEL_DFB, "", "" }, + /* Toggle sort by size */ + { 's', SEL_FSIZE, "", "" }, + /* Sort by total block count including dir contents */ + { 'S', SEL_BSIZE, "", "" }, + /* Toggle sort by time */ + { 't', SEL_MTIME, "", "" }, + { CONTROL('L'), SEL_REDRAW, "", "" }, + { KEY_F(2), SEL_REDRAW, "", "" }, + /* Copy currently selected file path */ + { CONTROL('K'), SEL_COPY, "", "" }, + /* Show help */ + { '?', SEL_HELP, "", "" }, + /* Run command */ + { '!', SEL_RUN, "sh", "SHELL" }, + /* Run command with argument */ + { 'e', SEL_RUNARG, "vi", "EDITOR" }, + { 'p', SEL_RUNARG, "less", "PAGER" }, +}; |