summaryrefslogtreecommitdiff
path: root/src/filelist.c
diff options
context:
space:
mode:
authorulteq <ulteq@web.de>2018-01-18 11:07:45 +0100
committerulteq <ulteq@web.de>2018-01-23 19:29:40 +0100
commit7acf83ea6d6f36e418f43a3408632944fbb7bcde (patch)
tree2a129172891e5515dbf4b6f518ed47a417d8b487 /src/filelist.c
parent886bea1e034c6878f4466a7e427302351281043e (diff)
Add natural sort of (version) numbers
Diffstat (limited to 'src/filelist.c')
-rw-r--r--src/filelist.c19
1 files changed, 15 insertions, 4 deletions
diff --git a/src/filelist.c b/src/filelist.c
index b569b8a..3157e32 100644
--- a/src/filelist.c
+++ b/src/filelist.c
@@ -399,12 +399,18 @@ void feh_file_dirname(char *dst, feh_file * f, int maxlen)
int feh_cmp_filename(void *file1, void *file2)
{
- return(strcmp(FEH_FILE(file1)->filename, FEH_FILE(file2)->filename));
+ if (!opt.version_sort)
+ return(strcmp(FEH_FILE(file1)->filename, FEH_FILE(file2)->filename));
+ else
+ return(strverscmp(FEH_FILE(file1)->filename, FEH_FILE(file2)->filename));
}
int feh_cmp_name(void *file1, void *file2)
{
- return(strcmp(FEH_FILE(file1)->name, FEH_FILE(file2)->name));
+ if (!opt.version_sort)
+ return(strcmp(FEH_FILE(file1)->name, FEH_FILE(file2)->name));
+ else
+ return(strverscmp(FEH_FILE(file1)->name, FEH_FILE(file2)->name));
}
int feh_cmp_dirname(void *file1, void *file2)
@@ -413,8 +419,13 @@ int feh_cmp_dirname(void *file1, void *file2)
int cmp;
feh_file_dirname(dir1, FEH_FILE(file1), PATH_MAX);
feh_file_dirname(dir2, FEH_FILE(file2), PATH_MAX);
- if ((cmp = strcmp(dir1, dir2)) != 0)
- return(cmp);
+ if (!opt.version_sort) {
+ if ((cmp = strcmp(dir1, dir2)) != 0)
+ return(cmp);
+ } else {
+ if ((cmp = strverscmp(dir1, dir2)) != 0)
+ return(cmp);
+ }
return(feh_cmp_name(file1, file2));
}