mirror of
https://github.com/jarun/nnn.git
synced 2024-11-24 11:51:27 +00:00
Fix #26: Provide an option to use a custom nlay file.
This commit is contained in:
parent
d1924756c7
commit
e4f72170d0
|
@ -121,6 +121,7 @@ nnn needs libreadline, libncursesw (on Linux or ncurses on OS X) and standard li
|
||||||
|
|
||||||
optional arguments:
|
optional arguments:
|
||||||
-d start in detail view mode
|
-d start in detail view mode
|
||||||
|
-p path to custom nlay
|
||||||
-S start in disk usage analyzer mode
|
-S start in disk usage analyzer mode
|
||||||
-v show program version and exit
|
-v show program version and exit
|
||||||
-h show this help and exit
|
-h show this help and exit
|
||||||
|
|
6
nlay
6
nlay
|
@ -25,8 +25,10 @@
|
||||||
# 3. Assuming you don't to play multiple audio/video files simultaneously,
|
# 3. Assuming you don't to play multiple audio/video files simultaneously,
|
||||||
# nlay kills any running instances of the audio/video player in bg mode.
|
# nlay kills any running instances of the audio/video player in bg mode.
|
||||||
#
|
#
|
||||||
# 4. Keep a personal backup (on GitHub Gist maybe?) of this file if you modify
|
# 4. nlay is OVERWRITTEN during nnn upgrade. You can store your custom nlay in a
|
||||||
# it. nlay is OVERWRITTEN during nnn upgrade.
|
# location other than the default and have an alias with nnn option '-p' to
|
||||||
|
# invoke it. Remember it might break or lack new capabilities added to nlay
|
||||||
|
# in future releases. Check the file diff once in a while.
|
||||||
#
|
#
|
||||||
# Author: Arun Prakash Jana
|
# Author: Arun Prakash Jana
|
||||||
# Email: engineerarun@gmail.com
|
# Email: engineerarun@gmail.com
|
||||||
|
|
26
nnn.c
26
nnn.c
|
@ -144,6 +144,7 @@ static int ndents, cur, total_dents;
|
||||||
static int idle;
|
static int idle;
|
||||||
static char *opener;
|
static char *opener;
|
||||||
static char *fb_opener;
|
static char *fb_opener;
|
||||||
|
static char *player;
|
||||||
static char *copier;
|
static char *copier;
|
||||||
static char *desktop_manager;
|
static char *desktop_manager;
|
||||||
static off_t blk_size;
|
static off_t blk_size;
|
||||||
|
@ -1570,7 +1571,7 @@ nochange:
|
||||||
/* If NNN_OPENER is set, use it */
|
/* If NNN_OPENER is set, use it */
|
||||||
if (opener) {
|
if (opener) {
|
||||||
sprintf(cmd, "%s \'", opener);
|
sprintf(cmd, "%s \'", opener);
|
||||||
xstrlcpy(cmd + strlen(cmd), newpath, sizeof(cmd) - strlen(cmd));
|
xstrlcpy(cmd + strlen(cmd), newpath, MAX_CMD_LEN - strlen(cmd));
|
||||||
strcat(cmd, "\' > /dev/null 2>&1");
|
strcat(cmd, "\' > /dev/null 2>&1");
|
||||||
r = system(cmd);
|
r = system(cmd);
|
||||||
continue;
|
continue;
|
||||||
|
@ -1579,8 +1580,13 @@ nochange:
|
||||||
/* Play with nlay if identified */
|
/* Play with nlay if identified */
|
||||||
mime = getmime(dents[cur].name);
|
mime = getmime(dents[cur].name);
|
||||||
if (mime) {
|
if (mime) {
|
||||||
strcpy(cmd, "nlay \'");
|
if (player) {
|
||||||
xstrlcpy(cmd + strlen(cmd), newpath, sizeof(cmd) - strlen(cmd));
|
cmd[0] = '\'';
|
||||||
|
xstrlcpy(cmd + 1, player, MAX_CMD_LEN);
|
||||||
|
strcat(cmd, "\' \'");
|
||||||
|
} else
|
||||||
|
strcpy(cmd, "nlay \'");
|
||||||
|
xstrlcpy(cmd + strlen(cmd), newpath, MAX_CMD_LEN - strlen(cmd));
|
||||||
sprintf(cmd + strlen(cmd), "\' %s", mime);
|
sprintf(cmd + strlen(cmd), "\' %s", mime);
|
||||||
exitcurses();
|
exitcurses();
|
||||||
r = system(cmd);
|
r = system(cmd);
|
||||||
|
@ -1591,7 +1597,7 @@ nochange:
|
||||||
/* If nlay doesn't handle it, open plain text
|
/* If nlay doesn't handle it, open plain text
|
||||||
files with vi, then try NNN_FALLBACK_OPENER */
|
files with vi, then try NNN_FALLBACK_OPENER */
|
||||||
strcpy(cmd, "file -bi \'");
|
strcpy(cmd, "file -bi \'");
|
||||||
xstrlcpy(cmd + strlen(cmd), newpath, sizeof(cmd) - strlen(cmd));
|
xstrlcpy(cmd + strlen(cmd), newpath, MAX_CMD_LEN - strlen(cmd));
|
||||||
strcat(cmd, "\'");
|
strcat(cmd, "\'");
|
||||||
if (get_output(cmd, MAX_CMD_LEN) == NULL)
|
if (get_output(cmd, MAX_CMD_LEN) == NULL)
|
||||||
continue;
|
continue;
|
||||||
|
@ -1604,7 +1610,7 @@ nochange:
|
||||||
continue;
|
continue;
|
||||||
} else if (fb_opener) {
|
} else if (fb_opener) {
|
||||||
sprintf(cmd, "%s \'", fb_opener);
|
sprintf(cmd, "%s \'", fb_opener);
|
||||||
xstrlcpy(cmd + strlen(cmd), newpath, sizeof(cmd) - strlen(cmd));
|
xstrlcpy(cmd + strlen(cmd), newpath, MAX_CMD_LEN - strlen(cmd));
|
||||||
strcat(cmd, "\' > /dev/null 2>&1");
|
strcat(cmd, "\' > /dev/null 2>&1");
|
||||||
r = system(cmd);
|
r = system(cmd);
|
||||||
continue;
|
continue;
|
||||||
|
@ -2001,6 +2007,7 @@ positional arguments:\n\
|
||||||
PATH directory to open [default: current dir]\n\n\
|
PATH directory to open [default: current dir]\n\n\
|
||||||
optional arguments:\n\
|
optional arguments:\n\
|
||||||
-d start in detail view mode\n\
|
-d start in detail view mode\n\
|
||||||
|
-p path to custom nlay\n\
|
||||||
-S start in disk usage analyzer mode\n\
|
-S start in disk usage analyzer mode\n\
|
||||||
-v show program version and exit\n\
|
-v show program version and exit\n\
|
||||||
-h show this help and exit\n\n\
|
-h show this help and exit\n\n\
|
||||||
|
@ -2027,7 +2034,7 @@ main(int argc, char *argv[])
|
||||||
if (argc > 3)
|
if (argc > 3)
|
||||||
usage();
|
usage();
|
||||||
|
|
||||||
while ((opt = getopt(argc, argv, "dSvh")) != -1) {
|
while ((opt = getopt(argc, argv, "dSp:vh")) != -1) {
|
||||||
switch (opt) {
|
switch (opt) {
|
||||||
case 'S':
|
case 'S':
|
||||||
bsizeorder = 1;
|
bsizeorder = 1;
|
||||||
|
@ -2036,6 +2043,13 @@ main(int argc, char *argv[])
|
||||||
showdetail = 1;
|
showdetail = 1;
|
||||||
printptr = &printent_long;
|
printptr = &printent_long;
|
||||||
break;
|
break;
|
||||||
|
case 'p':
|
||||||
|
player = optarg;
|
||||||
|
if (strlen(player) > 512) {
|
||||||
|
fprintf(stderr, "path to player must be <= 512 characters\n");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
break;
|
||||||
case 'v':
|
case 'v':
|
||||||
fprintf(stdout, "%s\n", VERSION);
|
fprintf(stdout, "%s\n", VERSION);
|
||||||
return 0;
|
return 0;
|
||||||
|
|
Loading…
Reference in a new issue