diff --git a/src/sv_sys_unix.c b/src/sv_sys_unix.c index 89c5d4b0..b985cf2b 100644 --- a/src/sv_sys_unix.c +++ b/src/sv_sys_unix.c @@ -179,8 +179,8 @@ dir_t Sys_listdir (const char *path, const char *ext, int sort_type) } strlcpy (list[dir.numfiles].name, oneentry->d_name, MAX_DEMO_NAME); - if (++dir.numfiles == MAX_DIRFILES - 1) - break; + if (dir.numfiles != MAX_DIRFILES - 1) dir.numfiles++; + } closedir(d); if (!all) diff --git a/src/sv_sys_win.c b/src/sv_sys_win.c index 1c319440..7bfe946f 100644 --- a/src/sv_sys_win.c +++ b/src/sv_sys_win.c @@ -231,8 +231,7 @@ dir_t Sys_listdir (const char *path, const char *ext, int sort_type) } strlcpy (list[dir.numfiles].name, fd.cFileName, sizeof(list[0].name)); - if (++dir.numfiles == MAX_DIRFILES - 1) - break; + if (dir.numfiles != MAX_DIRFILES - 1) dir.numfiles++; } while (FindNextFile(h, &fd)); diff --git a/src/sys.h b/src/sys.h index ce950cd1..ac979fc5 100644 --- a/src/sys.h +++ b/src/sys.h @@ -40,17 +40,17 @@ Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. typedef struct { char name[MAX_DEMO_NAME]; - int size; - int time; + size_t size; + time_t time; qbool isdir; //bliP: list dir } file_t; typedef struct { - file_t *files; - int size; - int numfiles; - int numdirs; + file_t *files; + size_t size; + size_t numfiles; + size_t numdirs; } dir_t; int Sys_FileTime (const char *path);