Skip to content

Commit

Permalink
nnn as file manager: more changes
Browse files Browse the repository at this point in the history
1. Support passing files to nnn
2. Enable debug logs much early
  • Loading branch information
jarun committed Apr 16, 2019
1 parent c5b5181 commit 39035bd
Show file tree
Hide file tree
Showing 2 changed files with 31 additions and 14 deletions.
4 changes: 2 additions & 2 deletions src/dbg.h
Original file line number Diff line number Diff line change
Expand Up @@ -47,7 +47,7 @@ static int xprintf(int fd, const char *fmt, ...)
return r;
}

static int enabledbg()
static int enabledbg(void)
{
FILE *fp = fopen("/tmp/nnndbg", "w");

Expand All @@ -71,7 +71,7 @@ static int enabledbg()
return 0;
}

static void disabledbg()
static void disabledbg(void)
{
close(DEBUG_FD);
}
Expand Down
41 changes: 29 additions & 12 deletions src/nnn.c
Original file line number Diff line number Diff line change
Expand Up @@ -4045,9 +4045,20 @@ int main(int argc, char *argv[])
++opt;
}

#ifdef DBGMODE
enabledbg();
atexit(disabledbg);
#endif

home = getenv("HOME");
DPRINTF_S(home);

/* Get custom opener, if set */
opener = xgetenv(env_cfg[NNN_OPENER], utils[OPENER]);
if (getenv(env_cfg[NNN_OPENER_DETACH]))
opener_flag |= F_NOWAIT;
DPRINTF_S(opener);

/* Parse bookmarks string */
if (!parsebmstr()) {
fprintf(stderr, "%s\n", env_cfg[NNN_BMS]);
Expand All @@ -4072,10 +4083,28 @@ int main(int argc, char *argv[])
&& ipath[3] == 'e' && ipath[4] == ':' && ipath[5] == '/' && ipath[6] == '/')
ipath = ipath + 7;
ipath = realpath(ipath, cwd);
DPRINTF_S(ipath);
if (!ipath) {
xerror();
return 1;
}

/*
* If nnn is set as the file manager, applications may try to open
* files by invoking nnn. In that case pass the file path to the
* desktop opener and exit.
*/
struct stat sb;

if (stat(ipath, &sb) == -1) {
printwarn();
return 1;
}

if (S_ISREG(sb.st_mode)) {
spawn(opener, ipath, NULL, NULL, opener_flag);
return 0;
}
}

/* Edit text in EDITOR, if opted */
Expand Down Expand Up @@ -4113,12 +4142,6 @@ int main(int argc, char *argv[])
}
#endif

/* Get custom opener, if set */
opener = xgetenv(env_cfg[NNN_OPENER], utils[OPENER]);
if (getenv(env_cfg[NNN_OPENER_DETACH]))
opener_flag |= F_NOWAIT;
DPRINTF_S(opener);

/* Set nnn nesting level, idletimeout used as tmp var */
idletimeout = xatoi(getenv(env_cfg[NNNLVL]));
setenv(env_cfg[NNNLVL], xitoa(++idletimeout), 1);
Expand Down Expand Up @@ -4200,9 +4223,6 @@ int main(int argc, char *argv[])
read_history(NULL);
#endif

#ifdef DBGMODE
enabledbg();
#endif
if (!initcurses())
return 1;

Expand Down Expand Up @@ -4236,8 +4256,5 @@ int main(int argc, char *argv[])
close(kq);
#endif

#ifdef DBGMODE
disabledbg();
#endif
return 0;
}

0 comments on commit 39035bd

Please sign in to comment.