diff --git a/README.md b/README.md index 984fac94..33d08518 100644 --- a/README.md +++ b/README.md @@ -267,7 +267,7 @@ Contexts (aka _tabs_ aka _workspaces_) serve the purpose of exploring multiple d - other used contexts are underlined - rest are unused -The bookmark prompt understands contexts. To switch contexts press ^B and enter the context number (1-4). +The bookmark prompt understands contexts. To switch contexts press ^B and enter the context number (1-4). >/. and at the bookmark prompt cycles between active contexts. The first time a context is entered, it copies the state of the last visited context. Each context remembers its start directory and last visited directory. diff --git a/nnn.c b/nnn.c index 8836ff58..f7ff0772 100644 --- a/nnn.c +++ b/nnn.c @@ -2485,6 +2485,7 @@ static void browse(char *ipath, char *ifilter) /* setup first context */ xstrlcpy(g_ctx[0].c_init, ipath, PATH_MAX); + g_ctx[0].c_cfg = cfg; xstrlcpy(path, ipath, PATH_MAX); copyfilter(); @@ -2751,6 +2752,20 @@ nochange: case '&': presel = tmp[0]; goto begin; + case '>': + case '.': + case '<': + case ',': + r = cfg.curctx; + if (tmp[0] == '>' || tmp[0] == '.') + do + (r == MAX_CTX - 1) ? (r = 0) : ++r; + while (!g_ctx[r].c_cfg.ctxactive); + else + do + (r == 0) ? (r = MAX_CTX - 1) : --r; + while (!g_ctx[r].c_cfg.ctxactive); //fallthrough + tmp[0] = '1' + r; //fallthrough case '1': //fallthrough case '2': //fallthrough case '3': //fallthrough @@ -3298,10 +3313,7 @@ nochange: uint iter = 1; r = cfg.curctx; while (iter < MAX_CTX) { - ++r; - r %= MAX_CTX; - DPRINTF_D(r); - DPRINTF_U(g_ctx[r].c_cfg.ctxactive); + (r == MAX_CTX - 1) ? (r = 0) : ++r; if (g_ctx[r].c_cfg.ctxactive) { g_ctx[cfg.curctx].c_cfg.ctxactive = 0;