mirror of
https://github.com/jarun/nnn.git
synced 2024-11-28 13:51:31 +00:00
Use preincr and predecr
This commit is contained in:
parent
7a2b1babdd
commit
b66fa0325d
92
nnn.c
92
nnn.c
|
@ -228,8 +228,9 @@ max_openfds()
|
||||||
static void
|
static void
|
||||||
xstrlcpy(char *dest, const char *src, size_t n)
|
xstrlcpy(char *dest, const char *src, size_t n)
|
||||||
{
|
{
|
||||||
while (--n && (*dest++ = *src++))
|
while (--n && (*dest = *src))
|
||||||
;
|
++dest, ++src;
|
||||||
|
|
||||||
if (!n)
|
if (!n)
|
||||||
*dest = '\0';
|
*dest = '\0';
|
||||||
}
|
}
|
||||||
|
@ -248,9 +249,13 @@ xmemrchr(const void *s, unsigned char ch, size_t n)
|
||||||
|
|
||||||
p = (unsigned char *)s + n - 1;
|
p = (unsigned char *)s + n - 1;
|
||||||
|
|
||||||
while (n--)
|
while (n) {
|
||||||
if ((*p--) == ch)
|
if (*p == ch)
|
||||||
return ++p;
|
return p;
|
||||||
|
|
||||||
|
--p;
|
||||||
|
--n;
|
||||||
|
}
|
||||||
|
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
@ -332,10 +337,8 @@ all_dots(const char *ptr)
|
||||||
|
|
||||||
int count = 0;
|
int count = 0;
|
||||||
|
|
||||||
while (*ptr == '.') {
|
while (*ptr == '.')
|
||||||
count++;
|
++count, ++ptr;
|
||||||
ptr++;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (*ptr)
|
if (*ptr)
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -451,19 +454,19 @@ xstricmp(char *s1, char *s2)
|
||||||
|
|
||||||
c1 = s1;
|
c1 = s1;
|
||||||
while (isspace(*c1))
|
while (isspace(*c1))
|
||||||
c1++;
|
++c1;
|
||||||
if (*c1 == '-' || *c1 == '+')
|
if (*c1 == '-' || *c1 == '+')
|
||||||
c1++;
|
++c1;
|
||||||
while (*c1 >= '0' && *c1 <= '9')
|
while (*c1 >= '0' && *c1 <= '9')
|
||||||
c1++;
|
++c1;
|
||||||
|
|
||||||
c2 = s2;
|
c2 = s2;
|
||||||
while (isspace(*c2))
|
while (isspace(*c2))
|
||||||
c2++;
|
++c2;
|
||||||
if (*c2 == '-' || *c2 == '+')
|
if (*c2 == '-' || *c2 == '+')
|
||||||
c2++;
|
++c2;
|
||||||
while (*c2 >= '0' && *c2 <= '9')
|
while (*c2 >= '0' && *c2 <= '9')
|
||||||
c2++;
|
++c2;
|
||||||
|
|
||||||
if (*c1 == '\0' && *c2 == '\0') {
|
if (*c1 == '\0' && *c2 == '\0') {
|
||||||
static long long num1, num2;
|
static long long num1, num2;
|
||||||
|
@ -482,7 +485,7 @@ xstricmp(char *s1, char *s2)
|
||||||
return 1;
|
return 1;
|
||||||
|
|
||||||
while (*s2 && *s1 && TOUPPER(*s1) == TOUPPER(*s2))
|
while (*s2 && *s1 && TOUPPER(*s1) == TOUPPER(*s2))
|
||||||
s1++, s2++;
|
++s1, ++s2;
|
||||||
|
|
||||||
/* In case of alphabetically same names, make sure
|
/* In case of alphabetically same names, make sure
|
||||||
* lower case one comes before upper case one
|
* lower case one comes before upper case one
|
||||||
|
@ -503,11 +506,11 @@ strstrip(char *s)
|
||||||
size_t len = strlen(s) - 1;
|
size_t len = strlen(s) - 1;
|
||||||
|
|
||||||
while (len != 0 && (isspace(s[len]) || s[len] == '/'))
|
while (len != 0 && (isspace(s[len]) || s[len] == '/'))
|
||||||
len--;
|
--len;
|
||||||
s[len + 1] = '\0';
|
s[len + 1] = '\0';
|
||||||
|
|
||||||
while (*s && isspace(*s))
|
while (*s && isspace(*s))
|
||||||
s++;
|
++s;
|
||||||
|
|
||||||
return s;
|
return s;
|
||||||
}
|
}
|
||||||
|
@ -519,7 +522,7 @@ getmime(char *file)
|
||||||
unsigned int i;
|
unsigned int i;
|
||||||
static unsigned int len = LEN(assocs);
|
static unsigned int len = LEN(assocs);
|
||||||
|
|
||||||
for (i = 0; i < len; i++) {
|
for (i = 0; i < len; ++i) {
|
||||||
if (regcomp(®ex, assocs[i].regex,
|
if (regcomp(®ex, assocs[i].regex,
|
||||||
REG_NOSUB | REG_EXTENDED | REG_ICASE) != 0)
|
REG_NOSUB | REG_EXTENDED | REG_ICASE) != 0)
|
||||||
continue;
|
continue;
|
||||||
|
@ -649,11 +652,11 @@ nextsel(char **run, char **env, int *presel)
|
||||||
*presel = 0;
|
*presel = 0;
|
||||||
|
|
||||||
if (c == -1)
|
if (c == -1)
|
||||||
idle++;
|
++idle;
|
||||||
else
|
else
|
||||||
idle = 0;
|
idle = 0;
|
||||||
|
|
||||||
for (i = 0; i < len; i++)
|
for (i = 0; i < len; ++i)
|
||||||
if (c == bindings[i].sym) {
|
if (c == bindings[i].sym) {
|
||||||
*run = bindings[i].run;
|
*run = bindings[i].run;
|
||||||
*env = bindings[i].env;
|
*env = bindings[i].env;
|
||||||
|
@ -672,7 +675,7 @@ fill(struct entry **dents,
|
||||||
{
|
{
|
||||||
static int count;
|
static int count;
|
||||||
|
|
||||||
for (count = 0; count < ndents; count++) {
|
for (count = 0; count < ndents; ++count) {
|
||||||
if (filter(re, (*dents)[count].name) == 0) {
|
if (filter(re, (*dents)[count].name) == 0) {
|
||||||
if (count != --ndents) {
|
if (count != --ndents) {
|
||||||
static struct entry _dent;
|
static struct entry _dent;
|
||||||
|
@ -701,7 +704,7 @@ fill(struct entry **dents,
|
||||||
(*dents)[ndents].size = _dent.size;
|
(*dents)[ndents].size = _dent.size;
|
||||||
(*dents)[ndents].bsize = _dent.bsize;
|
(*dents)[ndents].bsize = _dent.bsize;
|
||||||
|
|
||||||
count--;
|
--count;
|
||||||
}
|
}
|
||||||
|
|
||||||
continue;
|
continue;
|
||||||
|
@ -786,7 +789,8 @@ readln(char *path)
|
||||||
case CONTROL('Q'):
|
case CONTROL('Q'):
|
||||||
goto end;
|
goto end;
|
||||||
default:
|
default:
|
||||||
wln[len++] = (wchar_t)*ch;
|
wln[len] = (wchar_t)*ch;
|
||||||
|
++len;
|
||||||
wln[len] = '\0';
|
wln[len] = '\0';
|
||||||
wcstombs(ln, wln, LINE_MAX << 2);
|
wcstombs(ln, wln, LINE_MAX << 2);
|
||||||
ndents = total;
|
ndents = total;
|
||||||
|
@ -875,9 +879,9 @@ parsebmstr(char *bms)
|
||||||
while (*bms && i < MAX_BM) {
|
while (*bms && i < MAX_BM) {
|
||||||
bookmark[i].key = bms;
|
bookmark[i].key = bms;
|
||||||
|
|
||||||
bms++;
|
++bms;
|
||||||
while (*bms && *bms != ':')
|
while (*bms && *bms != ':')
|
||||||
bms++;
|
++bms;
|
||||||
|
|
||||||
if (!*bms) {
|
if (!*bms) {
|
||||||
bookmark[i].key = NULL;
|
bookmark[i].key = NULL;
|
||||||
|
@ -893,15 +897,15 @@ parsebmstr(char *bms)
|
||||||
}
|
}
|
||||||
|
|
||||||
while (*bms && *bms != ';')
|
while (*bms && *bms != ';')
|
||||||
bms++;
|
++bms;
|
||||||
|
|
||||||
if (*bms)
|
if (*bms)
|
||||||
*bms = '\0';
|
*bms = '\0';
|
||||||
else
|
else
|
||||||
break;
|
break;
|
||||||
|
|
||||||
bms++;
|
++bms;
|
||||||
i++;
|
++i;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -936,7 +940,7 @@ replace_escape(const char *str)
|
||||||
if (*buf <= '\x1f' || *buf == '\x7f')
|
if (*buf <= '\x1f' || *buf == '\x7f')
|
||||||
*buf = '\?';
|
*buf = '\?';
|
||||||
|
|
||||||
buf++;
|
++buf;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Convert wide char to multi-byte */
|
/* Convert wide char to multi-byte */
|
||||||
|
@ -993,7 +997,7 @@ coolsize(off_t size)
|
||||||
tmp = size;
|
tmp = size;
|
||||||
size >>= 10;
|
size >>= 10;
|
||||||
rem = tmp - (size << 10);
|
rem = tmp - (size << 10);
|
||||||
i++;
|
++i;
|
||||||
}
|
}
|
||||||
|
|
||||||
snprintf(size_buf, 12, "%.*Lf%s", i, size + rem * div_2_pow_10, U[i]);
|
snprintf(size_buf, 12, "%.*Lf%s", i, size + rem * div_2_pow_10, U[i]);
|
||||||
|
@ -1300,7 +1304,7 @@ show_stats(char *fpath, char *fname, struct stat *sb)
|
||||||
begin = p + 1;
|
begin = p + 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
p++;
|
++p;
|
||||||
}
|
}
|
||||||
dprintf(fd, " %s", begin);
|
dprintf(fd, " %s", begin);
|
||||||
}
|
}
|
||||||
|
@ -1380,7 +1384,7 @@ show_help(void)
|
||||||
|
|
||||||
if (getenv("NNN_BMS")) {
|
if (getenv("NNN_BMS")) {
|
||||||
dprintf(fd, "BOOKMARKS\n");
|
dprintf(fd, "BOOKMARKS\n");
|
||||||
for (; i < MAX_BM; i++)
|
for (; i < MAX_BM; ++i)
|
||||||
if (bookmark[i].key)
|
if (bookmark[i].key)
|
||||||
dprintf(fd, " %s: %s\n",
|
dprintf(fd, " %s: %s\n",
|
||||||
bookmark[i].key, bookmark[i].loc);
|
bookmark[i].key, bookmark[i].loc);
|
||||||
|
@ -1511,7 +1515,7 @@ dentfill(char *path, struct entry **dents,
|
||||||
(*dents)[n].bsize = sb.st_blocks;
|
(*dents)[n].bsize = sb.st_blocks;
|
||||||
}
|
}
|
||||||
|
|
||||||
n++;
|
++n;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (bsizeorder) {
|
if (bsizeorder) {
|
||||||
|
@ -1552,7 +1556,7 @@ dentfind(struct entry *dents, int n, char *path)
|
||||||
p = basename(path);
|
p = basename(path);
|
||||||
DPRINTF_S(p);
|
DPRINTF_S(p);
|
||||||
|
|
||||||
for (i = 0; i < n; i++)
|
for (i = 0; i < n; ++i)
|
||||||
if (strcmp(p, dents[i].name) == 0)
|
if (strcmp(p, dents[i].name) == 0)
|
||||||
return i;
|
return i;
|
||||||
|
|
||||||
|
@ -1594,7 +1598,7 @@ redraw(char *path)
|
||||||
erase();
|
erase();
|
||||||
|
|
||||||
/* Strip trailing slashes */
|
/* Strip trailing slashes */
|
||||||
for (i = strlen(path) - 1; i > 0; i--)
|
for (i = strlen(path) - 1; i > 0; --i)
|
||||||
if (path[i] == '/')
|
if (path[i] == '/')
|
||||||
path[i] = '\0';
|
path[i] = '\0';
|
||||||
else
|
else
|
||||||
|
@ -1617,17 +1621,17 @@ redraw(char *path)
|
||||||
|
|
||||||
/* Print listing */
|
/* Print listing */
|
||||||
if (cur < (nlines >> 1)) {
|
if (cur < (nlines >> 1)) {
|
||||||
for (i = 0; i < nlines; i++)
|
for (i = 0; i < nlines; ++i)
|
||||||
printptr(&dents[i], i == cur);
|
printptr(&dents[i], i == cur);
|
||||||
} else if (cur >= ndents - (nlines >> 1)) {
|
} else if (cur >= ndents - (nlines >> 1)) {
|
||||||
for (i = ndents - nlines; i < ndents; i++)
|
for (i = ndents - nlines; i < ndents; ++i)
|
||||||
printptr(&dents[i], i == cur);
|
printptr(&dents[i], i == cur);
|
||||||
} else {
|
} else {
|
||||||
static int odd;
|
static int odd;
|
||||||
|
|
||||||
odd = ISODD(nlines);
|
odd = ISODD(nlines);
|
||||||
nlines >>= 1;
|
nlines >>= 1;
|
||||||
for (i = cur - nlines; i < cur + nlines + odd; i++)
|
for (i = cur - nlines; i < cur + nlines + odd; ++i)
|
||||||
printptr(&dents[i], i == cur);
|
printptr(&dents[i], i == cur);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1850,14 +1854,14 @@ nochange:
|
||||||
break;
|
break;
|
||||||
case SEL_NEXT:
|
case SEL_NEXT:
|
||||||
if (cur < ndents - 1)
|
if (cur < ndents - 1)
|
||||||
cur++;
|
++cur;
|
||||||
else if (ndents)
|
else if (ndents)
|
||||||
/* Roll over, set cursor to first entry */
|
/* Roll over, set cursor to first entry */
|
||||||
cur = 0;
|
cur = 0;
|
||||||
break;
|
break;
|
||||||
case SEL_PREV:
|
case SEL_PREV:
|
||||||
if (cur > 0)
|
if (cur > 0)
|
||||||
cur--;
|
--cur;
|
||||||
else if (ndents)
|
else if (ndents)
|
||||||
/* Roll over, set cursor to last entry */
|
/* Roll over, set cursor to last entry */
|
||||||
cur = ndents - 1;
|
cur = ndents - 1;
|
||||||
|
@ -1945,10 +1949,10 @@ nochange:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
r--;
|
--r;
|
||||||
dir = path;
|
dir = path;
|
||||||
|
|
||||||
for (fd = 0; fd < r; fd++) {
|
for (fd = 0; fd < r; ++fd) {
|
||||||
/* Reached / ? */
|
/* Reached / ? */
|
||||||
if (path[0] == '/' && path[1] == '\0') {
|
if (path[0] == '/' && path[1] == '\0') {
|
||||||
/* If it's a cd .. at / */
|
/* If it's a cd .. at / */
|
||||||
|
@ -2090,7 +2094,7 @@ nochange:
|
||||||
|
|
||||||
clearprompt();
|
clearprompt();
|
||||||
|
|
||||||
for (r = 0; bookmark[r].key && r < MAX_BM; r++) {
|
for (r = 0; bookmark[r].key && r < MAX_BM; ++r) {
|
||||||
if (strcmp(bookmark[r].key, tmp) == 0) {
|
if (strcmp(bookmark[r].key, tmp) == 0) {
|
||||||
if (bookmark[r].loc[0] == '~') {
|
if (bookmark[r].loc[0] == '~') {
|
||||||
/* Expand ~ to HOME */
|
/* Expand ~ to HOME */
|
||||||
|
|
Loading…
Reference in a new issue