browser: make the calculation of files-per-line a straightforward one
There is no need to iterate through all the file names, as we already know the length of the longest. From this it's easy to calculate how many names fit on a line.master
parent
c6ec435ae9
commit
8ddc5e7b93
|
@ -416,14 +416,6 @@ void browser_init(const char *path, DIR *dir)
|
||||||
{
|
{
|
||||||
const struct dirent *nextdir;
|
const struct dirent *nextdir;
|
||||||
size_t i = 0, path_len = strlen(path);
|
size_t i = 0, path_len = strlen(path);
|
||||||
int col = 0;
|
|
||||||
/* The maximum number of columns that the filenames will take
|
|
||||||
* up. */
|
|
||||||
int line = 0;
|
|
||||||
/* The maximum number of lines that the filenames will take
|
|
||||||
* up. */
|
|
||||||
int filesperline = 0;
|
|
||||||
/* The number of files that we can display per line. */
|
|
||||||
|
|
||||||
assert(path != NULL && path[strlen(path) - 1] == '/' && dir != NULL);
|
assert(path != NULL && path[strlen(path) - 1] == '/' && dir != NULL);
|
||||||
|
|
||||||
|
@ -477,35 +469,10 @@ void browser_init(const char *path, DIR *dir)
|
||||||
|
|
||||||
closedir(dir);
|
closedir(dir);
|
||||||
|
|
||||||
/* Set width to zero, just before we initialize it. */
|
/* Calculate how many files fit on a line -- feigning room for two
|
||||||
width = 0;
|
* spaces beyond the right edge, and adding two spaces of padding
|
||||||
|
* between columns. */
|
||||||
for (i = 0; i < filelist_len && line < editwinrows; i++) {
|
width = (COLS + 2) / (longest + 2);
|
||||||
/* Calculate the number of columns one filename will take up. */
|
|
||||||
col += longest;
|
|
||||||
filesperline++;
|
|
||||||
|
|
||||||
/* Add some space between the columns. */
|
|
||||||
col += 2;
|
|
||||||
|
|
||||||
/* If the next entry isn't going to fit on the current line,
|
|
||||||
* move to the next line. */
|
|
||||||
if (col > COLS - longest) {
|
|
||||||
line++;
|
|
||||||
col = 0;
|
|
||||||
|
|
||||||
/* If width isn't initialized yet, and we've taken up more
|
|
||||||
* than one line, it means that width is equal to
|
|
||||||
* filesperline. */
|
|
||||||
if (width == 0)
|
|
||||||
width = filesperline;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* If width isn't initialized yet, and we've taken up only one line,
|
|
||||||
* it means that width is equal to longest. */
|
|
||||||
if (width == 0)
|
|
||||||
width = longest;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Return the function that is bound to the given key, accepting certain
|
/* Return the function that is bound to the given key, accepting certain
|
||||||
|
|
Loading…
Reference in New Issue