mirror of
https://github.com/jarun/nnn.git
synced 2024-11-24 11:51:27 +00:00
Support XDG_CONFIG_HOME
This commit is contained in:
parent
fa4f082ac0
commit
80c35e85bd
|
@ -2,7 +2,7 @@ n()
|
||||||
{
|
{
|
||||||
nnn "$@"
|
nnn "$@"
|
||||||
|
|
||||||
NNN_TMPFILE=~/.config/nnn/.lastd
|
NNN_TMPFILE=${XDG_CONFIG_HOME:-$HOME/.config}/nnn/.lastd
|
||||||
|
|
||||||
if [ -f $NNN_TMPFILE ]; then
|
if [ -f $NNN_TMPFILE ]; then
|
||||||
. $NNN_TMPFILE
|
. $NNN_TMPFILE
|
||||||
|
|
|
@ -1,2 +1,3 @@
|
||||||
|
# NOTE: set NNN_TMPFILE correctly if you use 'XDG_CONFIG_HOME'
|
||||||
set NNN_TMPFILE=~/.config/nnn/.lastd
|
set NNN_TMPFILE=~/.config/nnn/.lastd
|
||||||
alias n 'nnn; source "$NNN_TMPFILE"; rm "$NNN_TMPFILE"'
|
alias n 'nnn; source "$NNN_TMPFILE"; rm "$NNN_TMPFILE"'
|
||||||
|
|
|
@ -5,6 +5,7 @@
|
||||||
function n --description 'support nnn quit and change directory'
|
function n --description 'support nnn quit and change directory'
|
||||||
nnn $argv
|
nnn $argv
|
||||||
|
|
||||||
|
# NOTE: set NNN_TMPFILE correctly if you use 'XDG_CONFIG_HOME'
|
||||||
set NNN_TMPFILE ~/.config/nnn/.lastd
|
set NNN_TMPFILE ~/.config/nnn/.lastd
|
||||||
|
|
||||||
if test -e $NNN_TMPFILE
|
if test -e $NNN_TMPFILE
|
||||||
|
|
|
@ -2,7 +2,7 @@ n()
|
||||||
{
|
{
|
||||||
nnn "$@"
|
nnn "$@"
|
||||||
|
|
||||||
NNN_TMPFILE=~/.config/nnn/.lastd
|
NNN_TMPFILE=${XDG_CONFIG_HOME:-$HOME/.config}/nnn/.lastd
|
||||||
|
|
||||||
if [ -f $NNN_TMPFILE ]; then
|
if [ -f $NNN_TMPFILE ]; then
|
||||||
. $NNN_TMPFILE
|
. $NNN_TMPFILE
|
||||||
|
|
54
src/nnn.c
54
src/nnn.c
|
@ -4301,47 +4301,77 @@ static void usage(void)
|
||||||
static bool setup_config(void)
|
static bool setup_config(void)
|
||||||
{
|
{
|
||||||
size_t r, len;
|
size_t r, len;
|
||||||
|
char *xdgcfg = getenv("XDG_CONFIG_HOME");
|
||||||
|
bool xdg = FALSE;
|
||||||
|
|
||||||
/* Set up configuration file paths */
|
/* Set up configuration file paths */
|
||||||
len = strlen(home) + 1 + 20; /* add length of "/.config/nnn/plugins" */
|
if (xdgcfg && xdgcfg[0]) {
|
||||||
|
DPRINTF_S(xdgcfg);
|
||||||
|
if (xdgcfg[0] == '~') {
|
||||||
|
r = xstrlcpy(g_buf, home, PATH_MAX);
|
||||||
|
xstrlcpy(g_buf + r - 1, xdgcfg + 1, PATH_MAX);
|
||||||
|
xdgcfg = g_buf;
|
||||||
|
DPRINTF_S(xdgcfg);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!xdiraccess(xdgcfg)) {
|
||||||
|
xerror();
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
len = strlen(xdgcfg) + 1 + 12; /* add length of "/nnn/plugins" */
|
||||||
|
xdg = TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!xdg)
|
||||||
|
len = strlen(home) + 1 + 20; /* add length of "/.config/nnn/plugins" */
|
||||||
|
|
||||||
cfgdir = (char *)malloc(len);
|
cfgdir = (char *)malloc(len);
|
||||||
plugindir = (char *)malloc(len);
|
plugindir = (char *)malloc(len);
|
||||||
if (!cfgdir || !plugindir) {
|
if (!cfgdir || !plugindir) {
|
||||||
xerror();
|
xerror();
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
r = xstrlcpy(cfgdir, home, len);
|
|
||||||
|
|
||||||
/* Create ~/.config */
|
if (xdg) {
|
||||||
xstrlcpy(cfgdir + r - 1, "/.config", len - r);
|
xstrlcpy(cfgdir, xdgcfg, len);
|
||||||
DPRINTF_S(cfgdir);
|
r = len - 12;
|
||||||
if (!create_dir(cfgdir)) {
|
} else {
|
||||||
xerror();
|
r = xstrlcpy(cfgdir, home, len);
|
||||||
return FALSE;
|
|
||||||
|
/* Create ~/.config */
|
||||||
|
xstrlcpy(cfgdir + r - 1, "/.config", len - r);
|
||||||
|
DPRINTF_S(cfgdir);
|
||||||
|
if (!create_dir(cfgdir)) {
|
||||||
|
xerror();
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
r += 8; /* length of "/.config" */
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Create ~/.config/nnn */
|
/* Create ~/.config/nnn */
|
||||||
xstrlcpy(cfgdir + r - 1, "/.config/nnn", len - r);
|
xstrlcpy(cfgdir + r - 1, "/nnn", len - r);
|
||||||
DPRINTF_S(cfgdir);
|
DPRINTF_S(cfgdir);
|
||||||
if (!create_dir(cfgdir)) {
|
if (!create_dir(cfgdir)) {
|
||||||
xerror();
|
xerror();
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
xstrlcpy(cfgdir + r + 12 - 1, "/plugins", 9);
|
/* Create ~/.config/nnn/plugins */
|
||||||
|
xstrlcpy(cfgdir + r + 4 - 1, "/plugins", 9);
|
||||||
DPRINTF_S(cfgdir);
|
DPRINTF_S(cfgdir);
|
||||||
|
|
||||||
xstrlcpy(plugindir, cfgdir, len);
|
xstrlcpy(plugindir, cfgdir, len);
|
||||||
DPRINTF_S(plugindir);
|
DPRINTF_S(plugindir);
|
||||||
|
|
||||||
/* Create ~/.config/nnn/plugins */
|
|
||||||
if (!create_dir(cfgdir)) {
|
if (!create_dir(cfgdir)) {
|
||||||
xerror();
|
xerror();
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Reset to config path */
|
/* Reset to config path */
|
||||||
cfgdir[r + 11] = '\0';
|
cfgdir[r + 3] = '\0';
|
||||||
DPRINTF_S(cfgdir);
|
DPRINTF_S(cfgdir);
|
||||||
|
|
||||||
/* Set selection file path */
|
/* Set selection file path */
|
||||||
|
|
Loading…
Reference in a new issue