Skip to content

Commit

Permalink
Merge pull request #1698 from ANtlord/young-files
Browse files Browse the repository at this point in the history
Jump to the next young file
  • Loading branch information
jarun authored Jul 28, 2023
2 parents b835cfc + dedf055 commit d65a095
Show file tree
Hide file tree
Showing 2 changed files with 19 additions and 1 deletion.
18 changes: 17 additions & 1 deletion src/nnn.c
Original file line number Diff line number Diff line change
Expand Up @@ -5107,6 +5107,7 @@ static void show_help(const char *path)
"a1-4 Context%11(Sh)Tab Cycle/new context\n"
"62Esc ^Q Quit%20q Quit context\n"
"b^G QuitCD%18Q Pick/err, quit\n"
"b^y Next young file\n"
"0\n"
"1FILTER & PROMPT\n"
"c/ Filter%17^N Toggle type-to-nav\n"
Expand Down Expand Up @@ -6115,6 +6116,20 @@ static void handle_screen_move(enum action sel)
case SEL_END:
move_cursor(ndents - 1, 1);
break;
case SEL_YOUNG:
{
for (int r = cur;;) {
if (++r >= ndents)
r = 0;
if (r == cur)
break;
if (pdents[r].flags & FILE_YOUNG) {
move_cursor(r, 0);
break;
}
}
break;
}
default: /* case SEL_FIRST */
{
int c = get_input(messages[MSG_FIRST]);
Expand Down Expand Up @@ -7196,7 +7211,8 @@ static bool browse(char *ipath, const char *session, int pkey)
case SEL_HOME: // fallthrough
case SEL_END: // fallthrough
case SEL_FIRST: // fallthrough
case SEL_JUMP:
case SEL_JUMP: // fallthrough
case SEL_YOUNG:
if (ndents) {
g_state.move = 1;
handle_screen_move(sel);
Expand Down
2 changes: 2 additions & 0 deletions src/nnn.h
Original file line number Diff line number Diff line change
Expand Up @@ -58,6 +58,7 @@ enum action {
SEL_END,
SEL_FIRST,
SEL_JUMP,
SEL_YOUNG,
SEL_CDHOME,
SEL_CDBEGIN,
SEL_CDLAST,
Expand Down Expand Up @@ -164,6 +165,7 @@ static struct key bindings[] = {
{ '\'', SEL_FIRST },
/* Jump to an entry number/offset */
{ 'J', SEL_JUMP },
{ CONTROL('Y'), SEL_YOUNG },
/* HOME */
{ '~', SEL_CDHOME },
/* Initial directory */
Expand Down

0 comments on commit d65a095

Please sign in to comment.