diff options
-rw-r--r-- | src/main.c | 11 | ||||
-rw-r--r-- | src/sockutil.c | 2 | ||||
-rw-r--r-- | version.log | 6 |
3 files changed, 11 insertions, 8 deletions
diff --git a/src/main.c b/src/main.c index 6359cedec..aee7a0520 100644 --- a/src/main.c +++ b/src/main.c @@ -557,7 +557,6 @@ int main(int ac, char **av, char **envp) while (!quitting) { time_t t = time(NULL); - char *sgetbuf = NULL; if (debug >= 2) alog("debug: Top of main loop"); @@ -599,13 +598,13 @@ int main(int ac, char **av, char **envp) } waiting = 1; - /* fixing this nasty, nasty typecast. why should we typecast - a char pointer to a long int? -Certus */ - sgetbuf = sgets2(inbuf, sizeof(inbuf), servsock); + /* this is a nasty nasty typecast. we need to rewrite the + socket stuff -Certus */ + i = (int) (long) sgets2(inbuf, sizeof(inbuf), servsock); waiting = 0; - if (sgetbuf) { + if ((i>0) || (i<(-1))) { process(); - } else { + } else if (i == 0) { int errno_save = errno; quitmsg = scalloc(BUFSIZE, 1); if (quitmsg) { diff --git a/src/sockutil.c b/src/sockutil.c index 049f181d3..2308dd528 100644 --- a/src/sockutil.c +++ b/src/sockutil.c @@ -453,7 +453,7 @@ char *sgets2(char *buf, int len, ano_socket_t s) char *str = sgets(buf, len, s); if (!str || str == (char *) -1) - return NULL; + return str; str = buf + strlen(buf) - 1; if (*str == '\n') *str-- = 0; diff --git a/version.log b/version.log index ba278ea35..b68f56dbc 100644 --- a/version.log +++ b/version.log @@ -9,10 +9,14 @@ VERSION_MAJOR="1" VERSION_MINOR="7" VERSION_PATCH="14" VERSION_EXTRA="" -VERSION_BUILD="1105" +VERSION_BUILD="1106" # $Log$ # +# BUILD : 1.7.14 (1106) +# BUGS : +# NOTES : applied heinz's fix for the gcc hardened issue +# # BUILD : 1.7.14 (1105) # BUGS : 558 # NOTES : fixed usermode stuff for ratbox and shadow |