aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorGravatar Arun Prakash Jana <engineerarun@gmail.com>2018-11-12 23:29:29 +0530
committerGravatar Arun Prakash Jana <engineerarun@gmail.com>2018-11-12 23:29:29 +0530
commitd9ff3a3588e551ed1eaffd5a5fb51fe7626aba81 (patch)
tree4a5027dec059e8d708fb343fa8847259f6313d10 /src
parent48e64c2a7999e292ffa0bf300a0a60d47c60c15d (diff)
downloadnnn-d9ff3a3588e551ed1eaffd5a5fb51fe7626aba81.tar.gz
Convert keys to int
Diffstat (limited to 'src')
-rw-r--r--src/nnn.c41
1 files changed, 13 insertions, 28 deletions
diff --git a/src/nnn.c b/src/nnn.c
index cab2912..9b446dd 100644
--- a/src/nnn.c
+++ b/src/nnn.c
@@ -236,7 +236,7 @@ typedef struct entry {
/* Bookmark */
typedef struct {
- char *key;
+ int key;
char *loc;
} bm;
@@ -1368,31 +1368,19 @@ static int parsebmstr()
return 0;
while (*bms && i < BM_MAX) {
- bookmark[i].key = bms;
+ bookmark[i].key = *bms;
- ++bms;
- while (*bms && *bms != ':') {
- ++bms;
-
- /*
- * Use single-char keys to combine with Leader key.
- * Fail here to ensure keys are single char.
- * To support multiple char keys remove the return
- * and add appropriate check to enable smart-detect.
- */
- return -1;
- }
-
- if (!*bms) {
- bookmark[i].key = NULL;
+ if (!*++bms) {
+ bookmark[i].key = '\0';
break;
}
- *bms = '\0';
+ if (*bms != ':')
+ return -1; /* We support single char keys only */
bookmark[i].loc = ++bms;
if (bookmark[i].loc[0] == '\0' || bookmark[i].loc[0] == ';') {
- bookmark[i].key = NULL;
+ bookmark[i].key = '\0';
break;
}
@@ -1417,15 +1405,12 @@ static int parsebmstr()
* NULL is returned in case of no match, path resolution failure etc.
* buf would be modified, so check return value before access
*/
-static char *get_bm_loc(char *key, char *buf)
+static char *get_bm_loc(int key, char *buf)
{
int r;
- if (!key || !key[0])
- return NULL;
-
for (r = 0; bookmark[r].key && r < BM_MAX; ++r) {
- if (strcmp(bookmark[r].key, key) == 0) {
+ if (bookmark[r].key == key) {
if (bookmark[r].loc[0] == '~') {
char *home = getenv("HOME");
@@ -2026,7 +2011,7 @@ static int show_help(char *path)
dprintf(fd, "BOOKMARKS\n");
for (; i < BM_MAX; ++i)
if (bookmark[i].key)
- dprintf(fd, " %s: %s\n", bookmark[i].key, bookmark[i].loc);
+ dprintf(fd, " %c: %s\n", (char)bookmark[i].key, bookmark[i].loc);
else
break;
dprintf(fd, "\n");
@@ -2728,7 +2713,7 @@ nochange:
case '~': //fallthrough
case '-': //fallthrough
case '&':
- presel = (char)fd;
+ presel = fd;
goto nochange;
case '>':
case '.':
@@ -2782,7 +2767,7 @@ nochange:
goto begin;
}
- if (get_bm_loc((char)fd, newpath) == NULL) {
+ if (get_bm_loc(fd, newpath) == NULL) {
printmsg(messages[STR_INVBM_KEY]);
goto nochange;
}
@@ -3461,7 +3446,7 @@ int main(int argc, char *argv[])
}
if (ipath) { /* Open a bookmark directly */
- if (get_bm_loc(ipath, cwd) == NULL) {
+ if (ipath[1] || get_bm_loc(*ipath, cwd) == NULL) {
fprintf(stderr, "%s\n", messages[STR_INVBM_KEY]);
exit(1);
}