Skip to content

Commit

Permalink
Merge pull request #1762 from azuline/sortctx
Browse files Browse the repository at this point in the history
restore sort function pointers when restoring cfg
  • Loading branch information
jarun authored Nov 19, 2023
2 parents 9259170 + c0b3cc8 commit 744a755
Showing 1 changed file with 18 additions and 8 deletions.
26 changes: 18 additions & 8 deletions src/nnn.c
Original file line number Diff line number Diff line change
Expand Up @@ -4276,6 +4276,18 @@ static void printent(const struct entry *ent, uint_t namecols, bool sel)
addch(ind);
}

/**
* Sets the global cfg variable and restores related state to match the new
* cfg.
*/
static void setcfg(settings newcfg)
{
cfg = newcfg;
/* Synchronize the global function pointers to match the new cfg. */
entrycmpfn = cfg.reverse ? &reventrycmp : &entrycmp;
namecmpfn = cfg.version ? &xstrverscasecmp : &xstricmp;
}

static void savecurctx(char *path, char *curname, int nextctx)
{
settings tmpcfg = cfg;
Expand Down Expand Up @@ -4307,7 +4319,7 @@ static void savecurctx(char *path, char *curname, int nextctx)
}

tmpcfg.curctx = nextctx;
cfg = tmpcfg;
setcfg(tmpcfg);
}

#ifndef NOSSN
Expand Down Expand Up @@ -6248,11 +6260,9 @@ static int set_sort_flags(int r)
r = 'd';
}

if (cfg.version)
namecmpfn = &xstrverscasecmp;

if (cfg.reverse)
entrycmpfn = &reventrycmp;
/* Ensure function pointers are in sync with cfg. */
entrycmpfn = cfg.reverse ? &reventrycmp : &entrycmp;
namecmpfn = cfg.version ? &xstrverscasecmp : &xstricmp;
} else if (r == CONTROL('T')) {
/* Cycling order: clear -> size -> time -> clear */
if (cfg.timeorder)
Expand Down Expand Up @@ -8017,9 +8027,9 @@ static bool browse(char *ipath, const char *session, int pkey)
lastdir = g_ctx[r].c_last;
lastname = g_ctx[r].c_name;

cfg = g_ctx[r].c_cfg;
g_ctx[r].c_cfg.curctx = r;
setcfg(g_ctx[r].c_cfg);

cfg.curctx = r;
setdirwatch();
goto begin;
}
Expand Down

0 comments on commit 744a755

Please sign in to comment.