X-Git-Url: https://git.librecmc.org/?a=blobdiff_plain;f=cde%2Fprograms%2Fdtstyle%2FBackdrop.c;h=2168a13a1d8b5f9df81bf220195035e6d7226a8e;hb=4f5e7fe5e3b8ef48be3b7129d0a4411c2a100170;hp=33c48e1d9bdb31bb9ffa382b6fc2542c9349bfe7;hpb=dcdd21df3431e532728b9dbda6d2519921336f8e;p=oweals%2Fcde.git diff --git a/cde/programs/dtstyle/Backdrop.c b/cde/programs/dtstyle/Backdrop.c index 33c48e1d..2168a13a 100644 --- a/cde/programs/dtstyle/Backdrop.c +++ b/cde/programs/dtstyle/Backdrop.c @@ -16,7 +16,7 @@ * details. * * You should have received a copy of the GNU Lesser General Public - * License along with these librararies and programs; if not, write + * License along with these libraries and programs; if not, write * to the Free Software Foundation, Inc., 51 Franklin Street, Fifth * Floor, Boston, MA 02110-1301 USA */ @@ -42,7 +42,10 @@ /* include files */ /*+++++++++++++++++++++++++++++++++++++++*/ #include +#include +#include #include +#include #if defined(_AIX) || defined(__apollo) #include @@ -423,10 +426,10 @@ CreateBackdropDialog( XtFree(bd_desc); /* Set up DialogBox button labels. */ - strings[0] = XmStringCreateLocalized (_DtOkString); - strings[1] = XmStringCreateLocalized (_DtApplyString); - strings[2] = XmStringCreateLocalized (_DtCloseString); - strings[3] = XmStringCreateLocalized (_DtHelpString); + strings[0] = XmStringCreateLocalized ((String) _DtOkString); + strings[1] = XmStringCreateLocalized ((String) _DtApplyString); + strings[2] = XmStringCreateLocalized ((String) _DtCloseString); + strings[3] = XmStringCreateLocalized ((String) _DtHelpString); /* saveRestore * Note that save.poscnt has been initialized elsewhere. @@ -538,6 +541,17 @@ MoreBitmaps( void ) backdrops.maxNumBitmaps += 100; } +/************************************************************************ + * cmpstringp() + * qsort() sort function, used for sorting bitmap names into alphabetical order + * can't use strcmp() due to char** rather than char* + ************************************************************************/ +static int +cmpstringp(const void *p1, const void *p2) +{ + return strcmp(*(char * const *) p1, *(char * const *) p2); +} + /************************************************************************ * ReadBitmaps() * Create an array of bitmaps by reading backdrop directories in the @@ -580,10 +594,12 @@ static /* read the directory $HOME/.dt/backdrops */ string = (char *)XtMalloc(strlen(style.home) + strlen("/.dt/backdrops") + 1); - sprintf(string, "%s/.dt/backdrops", style.home); - ReadBitmapDirectory(string); if (string != NULL) + { + sprintf(string, "%s/.dt/backdrops", style.home); + ReadBitmapDirectory(string); XtFree(string); + } if (backdrops.tmpNumBitmaps == 0) { @@ -595,6 +611,9 @@ static free_dirList(backdrops.dirList, backdrops.dirCount); return 0; } + + /* Sort the list into alphanetical order */ + qsort(backdrops.tmpBitmapNames, backdrops.tmpNumBitmaps, sizeof(char *), cmpstringp); /* get the fg/bg colors from Dtwm */ if (backdrops.newColors) @@ -720,12 +739,20 @@ ReadBitmapDirectory( filep = readdir(dirp); continue; } - - /* strip suffix off filename */ name = (char *) XtMalloc(strlen(filep->d_name) + 1); strcpy (name, filep->d_name); - (void)strtok(name, "."); + + /* strip suffix off filename if it's a .pm or .bm + * motif requires other formats like jpg, png etc to + * have the extension on to work with the XmGetPixmap() calls */ + if(strlen(name) > 3 + && (0 == strcmp(name + strlen(name) - 3, ".pm") + || 0 == strcmp(name + strlen(name) - 3, ".bm"))) + { + (void)strtok(name, "."); + } + /* check for duplicates */ duplicate = 0; @@ -1219,7 +1246,9 @@ saveBackdrop( backdrops.selected); sprintf(bufr, "%s*backdropsDialog.selectedItem: %s\n", bufr, backdrops.bitmapNames[backdrops.selected]); - write (fd, bufr, strlen(bufr)); + if(-1 == write (fd, bufr, strlen(bufr))) { + perror(strerror(errno)); + } } }