diff options
author | certus certus@31f1291d-b8d6-0310-a050-a5561fc1590b <certus certus@31f1291d-b8d6-0310-a050-a5561fc1590b@5417fbe8-f217-4b02-8779-1006273d7864> | 2006-08-03 12:06:36 +0000 |
---|---|---|
committer | certus certus@31f1291d-b8d6-0310-a050-a5561fc1590b <certus certus@31f1291d-b8d6-0310-a050-a5561fc1590b@5417fbe8-f217-4b02-8779-1006273d7864> | 2006-08-03 12:06:36 +0000 |
commit | f978c93b2c1aa778c49e306a275cf053530d7704 (patch) | |
tree | a30cee15cead6c652efc5ca409f0fa047b526f74 /src/main.c | |
parent | 7824683cb2780920ec1dceeaedd1c0bb851be04c (diff) |
# BUILD : 1.7.14 (1106) # BUGS : # NOTES : applied heinz's fix for the gcc hardened issue
git-svn-id: svn://svn.anope.org/anope/trunk@1106 31f1291d-b8d6-0310-a050-a5561fc1590b
git-svn-id: http://anope.svn.sourceforge.net/svnroot/anope/trunk@830 5417fbe8-f217-4b02-8779-1006273d7864
Diffstat (limited to 'src/main.c')
-rw-r--r-- | src/main.c | 11 |
1 files changed, 5 insertions, 6 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) { |