From cae4fc7df7b2cf5a863a86cf9fd266efbb90d70c Mon Sep 17 00:00:00 2001 From: Bobbi Webber-Manners Date: Mon, 24 Feb 2020 23:05:59 -0500 Subject: [PATCH] Added case-insensitive sort option --- bobbi/sortdir.1#040000 | 4 ++++ bobbi/sortdir.c#b00008 | 37 +++++++++++++++++++++++++++++++++---- 2 files changed, 37 insertions(+), 4 deletions(-) diff --git a/bobbi/sortdir.1#040000 b/bobbi/sortdir.1#040000 index 652ad46..f9b02a6 100644 --- a/bobbi/sortdir.1#040000 +++ b/bobbi/sortdir.1#040000 @@ -23,6 +23,10 @@ n: Sort by filename, in ascending ASCII order .HP N: Sort by filename, in descending ASCII order .HP +i: Sort by filename, in ascending ASCII order - case insensitive +.HP +I: Sort by filename, in descending ASCII order - case insensitive +.HP d: Sort by modification date (or creation date if \fB-c\fR flag is given), in ascending order .HP D: Sort by modification date (or creation date if \fB-c\fR flag is given), in descending order diff --git a/bobbi/sortdir.c#b00008 b/bobbi/sortdir.c#b00008 index 4b4a793..f87e94d 100644 --- a/bobbi/sortdir.c#b00008 +++ b/bobbi/sortdir.c#b00008 @@ -2,7 +2,6 @@ * Bobbi January-February 2020 * * TODO: Fix mode - * TODO: Case insensitive sort option * TODO: Tool for 'extending' volume dir to more than 4 blocks * TODO: Legacy/extended date format conversion * TODO: Trimming unused directory blocks @@ -184,6 +183,8 @@ void enqueuesubdir(uint blocknum, uint subdiridx); int readdir(uint device, uint blocknum); int cmp_name_asc(const void *a, const void *b); int cmp_name_desc(const void *a, const void *b); +int cmp_name_asc_ci(const void *a, const void *b); +int cmp_name_desc_ci(const void *a, const void *b); int cmp_datetime_asc(const void *a, const void *b); int cmp_datetime_desc(const void *a, const void *b); int cmp_type_asc(const void *a, const void *b); @@ -1033,7 +1034,7 @@ int readdir(uint device, uint blocknum) { */ int cmp_name_asc(const void *a, const void *b) { return strncmp(((struct fileent*)a)->name, - ((struct fileent*)b)->name, NMLEN); + ((struct fileent*)b)->name, NMLEN); } /* @@ -1044,6 +1045,22 @@ int cmp_name_desc(const void *a, const void *b) { ((struct fileent*)a)->name, NMLEN); } +/* + * Compare - filename sort in ascending order - case insensitive + */ +int cmp_name_asc_ci(const void *a, const void *b) { + return strncasecmp(((struct fileent*)a)->name, + ((struct fileent*)b)->name, NMLEN); +} + +/* + * Compare - filename sort in descending order - case insensitive + */ +int cmp_name_desc_ci(const void *a, const void *b) { + return strncasecmp(((struct fileent*)b)->name, + ((struct fileent*)a)->name, NMLEN); +} + /* * Compare - date/time sort in ascending order */ @@ -1185,6 +1202,14 @@ void sortlist(char s) { qsort(filelist, numfiles, sizeof(struct fileent), cmp_name_desc); break; + case 'i': + qsort(filelist, numfiles, sizeof(struct fileent), + cmp_name_asc_ci); + break; + case 'I': + qsort(filelist, numfiles, sizeof(struct fileent), + cmp_name_desc_ci); + break; case 'd': qsort(filelist, numfiles, sizeof(struct fileent), cmp_datetime_asc); @@ -1394,6 +1419,8 @@ void usage(void) { printf("to sort. The sort options are processed left-to-right.\n"); printf(" n sort by filename ascending\n"); printf(" N sort by filename descending\n"); + printf(" i sort by filename ascending - case insensitive\n"); + printf(" I sort by filename descending - case insensitive\n"); printf(" d sort by modify (or create [-c]) date ascending\n"); printf(" D sort by modify (or create [-c]) date descending\n"); printf(" t sort by type ascending\n"); @@ -1454,12 +1481,14 @@ done: * block should either be marked free or marked used. */ void checkfreeandused(void) { - printf("Total blocks on volume %u\n", totblks); + printf("Total blocks on volume\t%u\n", totblks); uint freeblks = 0; for (uint i=0; i