Fix #26: Provide an option to use a custom nlay file.

This commit is contained in:
Arun Prakash Jana 2017-05-14 21:00:46 +05:30
parent d1924756c7
commit e4f72170d0
No known key found for this signature in database
GPG Key ID: A75979F35C080412
3 changed files with 25 additions and 8 deletions

View File

@ -121,6 +121,7 @@ nnn needs libreadline, libncursesw (on Linux or ncurses on OS X) and standard li
optional arguments:
-d start in detail view mode
-p path to custom nlay
-S start in disk usage analyzer mode
-v show program version and exit
-h show this help and exit

6
nlay
View File

@ -25,8 +25,10 @@
# 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.
#
# 4. Keep a personal backup (on GitHub Gist maybe?) of this file if you modify
# it. nlay is OVERWRITTEN during nnn upgrade.
# 4. nlay is OVERWRITTEN during nnn upgrade. You can store your custom nlay in a
# 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
# Email: engineerarun@gmail.com

26
nnn.c
View File

@ -144,6 +144,7 @@ static int ndents, cur, total_dents;
static int idle;
static char *opener;
static char *fb_opener;
static char *player;
static char *copier;
static char *desktop_manager;
static off_t blk_size;
@ -1570,7 +1571,7 @@ nochange:
/* If NNN_OPENER is set, use it */
if (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");
r = system(cmd);
continue;
@ -1579,8 +1580,13 @@ nochange:
/* Play with nlay if identified */
mime = getmime(dents[cur].name);
if (mime) {
strcpy(cmd, "nlay \'");
xstrlcpy(cmd + strlen(cmd), newpath, sizeof(cmd) - strlen(cmd));
if (player) {
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);
exitcurses();
r = system(cmd);
@ -1591,7 +1597,7 @@ nochange:
/* If nlay doesn't handle it, open plain text
files with vi, then try NNN_FALLBACK_OPENER */
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, "\'");
if (get_output(cmd, MAX_CMD_LEN) == NULL)
continue;
@ -1604,7 +1610,7 @@ nochange:
continue;
} else if (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");
r = system(cmd);
continue;
@ -2001,6 +2007,7 @@ positional arguments:\n\
PATH directory to open [default: current dir]\n\n\
optional arguments:\n\
-d start in detail view mode\n\
-p path to custom nlay\n\
-S start in disk usage analyzer mode\n\
-v show program version and exit\n\
-h show this help and exit\n\n\
@ -2027,7 +2034,7 @@ main(int argc, char *argv[])
if (argc > 3)
usage();
while ((opt = getopt(argc, argv, "dSvh")) != -1) {
while ((opt = getopt(argc, argv, "dSp:vh")) != -1) {
switch (opt) {
case 'S':
bsizeorder = 1;
@ -2036,6 +2043,13 @@ main(int argc, char *argv[])
showdetail = 1;
printptr = &printent_long;
break;
case 'p':
player = optarg;
if (strlen(player) > 512) {
fprintf(stderr, "path to player must be <= 512 characters\n");
exit(1);
}
break;
case 'v':
fprintf(stdout, "%s\n", VERSION);
return 0;