X-Git-Url: http://winboard.nl/cgi-bin?a=blobdiff_plain;f=filebrowser%2Fselfile.c;h=860ed8b4e60727ffeff42b0cab973ea54c667e16;hb=b62693239eb893af0c242295d37f28ba84cd7c10;hp=c0a2ce270e417b9a2bc0b0fa1853e826961c4b1d;hpb=18c9024957df2892adb21cd851cb7a27b9502d54;p=xboard.git diff --git a/filebrowser/selfile.c b/filebrowser/selfile.c index c0a2ce2..860ed8b 100644 --- a/filebrowser/selfile.c +++ b/filebrowser/selfile.c @@ -61,6 +61,16 @@ extern int errno; #include #include "selfile.h" +#include "xstat.h" + +/* added missing prototypes */ +extern void SFdrawList(int,int); +extern void SFinitFont(); +extern void SFcreateGC(); +extern int SFchdir(char *); +extern void SFupdatePath(); +extern void SFsetText(char *); +extern char SFstatChar(struct stat*); #ifndef MAXPATHLEN #define MAXPATHLEN 1024 @@ -146,7 +156,7 @@ SFexposeList(w, n, event, cont) return; } - SFdrawList(n, SF_DO_NOT_SCROLL); + SFdrawList((int)n, SF_DO_NOT_SCROLL); } /* ARGSUSED */ @@ -593,11 +603,11 @@ SFtextChanged() { if ((SFtextBuffer[0] == '/') || (SFtextBuffer[0] == '~')) { - (void) strcpy(SFcurrentPath, SFtextBuffer); + (void) strncpy(SFcurrentPath, SFtextBuffer, MAXPATHLEN); SFtextPos = XawTextGetInsertionPoint(selFileField); } else { - (void) strcat(strcpy(SFcurrentPath, SFstartDir), SFtextBuffer); + (void) strcat(strncpy(SFcurrentPath, SFstartDir, MAXPATHLEN), SFtextBuffer); SFtextPos = XawTextGetInsertionPoint(selFileField) + strlen(SFstartDir); @@ -697,11 +707,11 @@ XsraSelFile(toplevel, prompt, ok, cancel, failed, XtAppError(SFapp, "XsraSelFile: can't get current directory"); } (void) strcat(SFstartDir, "/"); - (void) strcpy(SFcurrentDir, SFstartDir); + (void) strncpy(SFcurrentDir, SFstartDir, MAXPATHLEN); if (init_path) { if (init_path[0] == '/') { - (void) strcpy(SFcurrentPath, init_path); + (void) strncpy(SFcurrentPath, init_path, MAXPATHLEN); if (strncmp( SFcurrentPath, SFstartDir, @@ -712,12 +722,12 @@ XsraSelFile(toplevel, prompt, ok, cancel, failed, SFsetText(&(SFcurrentPath[strlen(SFstartDir)])); } } else { - (void) strcat(strcpy(SFcurrentPath, SFstartDir), + (void) strcat(strncpy(SFcurrentPath, SFstartDir, MAXPATHLEN), init_path); SFsetText(&(SFcurrentPath[strlen(SFstartDir)])); } } else { - (void) strcpy(SFcurrentPath, SFstartDir); + (void) strncpy(SFcurrentPath, SFstartDir, MAXPATHLEN); } SFfunc = show_entry;