diff options
author | brain <brain@e03df62e-2008-0410-955e-edbf42e46eb7> | 2005-12-12 22:29:06 +0000 |
---|---|---|
committer | brain <brain@e03df62e-2008-0410-955e-edbf42e46eb7> | 2005-12-12 22:29:06 +0000 |
commit | 7d283ead756f22b2c659414b89938777ad97599f (patch) | |
tree | 5f658ddae1ed059e127e9939bd2ab6e651240d8a /src/inspircd.cpp | |
parent | 4d6d3859d208d5576e7149de9a0a5576b7cf5153 (diff) |
Efficiency suggestion by w00t, faster processing of module sockets at the expense of a bit of ram
git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@2357 e03df62e-2008-0410-955e-edbf42e46eb7
Diffstat (limited to 'src/inspircd.cpp')
-rw-r--r-- | src/inspircd.cpp | 25 |
1 files changed, 14 insertions, 11 deletions
diff --git a/src/inspircd.cpp b/src/inspircd.cpp index 5b4b8f5d1..ccf0257e7 100644 --- a/src/inspircd.cpp +++ b/src/inspircd.cpp @@ -121,6 +121,8 @@ char addrs[MAXBUF][255]; socklen_t length; char configToken[MAXBUF], Addr[MAXBUF], Type[MAXBUF]; +extern InspSocket* socket_ref[65535]; + time_t TIME = time(NULL), OLDTIME = time(NULL); SocketEngine* SE = NULL; @@ -2639,8 +2641,9 @@ int InspIRCd(char** argv, int argc) int incomingSockfd; userrec* cu = NULL; InspSocket* s = NULL; + InspSocket* s_del = NULL; char target[MAXBUF]; - unsigned int numsockets, numberactive; + unsigned int numberactive; /* Beta 7 moved all this stuff out of the main function * into smaller sub-functions, much tidier -- Brain @@ -2755,23 +2758,23 @@ int InspIRCd(char** argv, int argc) * Modules are encouraged to inherit their sockets from * InspSocket so we can process them neatly like this. */ - numsockets = module_sockets.size(); - for (std::vector<InspSocket*>::iterator a = module_sockets.begin(); a < module_sockets.end(); a++) + s = socket_ref[activefds[activefd]]; + + if ((s) && (!s->Poll())) { - s = (InspSocket*)*a; - if ((s) && (s->GetFd() == activefds[activefd])) + log(DEBUG,"Socket poll returned false, close and bail"); + SE->DelFd(s->GetFd()); + for (std::vector<InspSocket*>::iterator a = module_sockets.begin(); a < module_sockets.end(); a++) { - if (!s->Poll()) + s_del = (InspSocket*)*a; + if ((s_del) && (s_del->GetFd() == activefds[activefd])) { - log(DEBUG,"Socket poll returned false, close and bail"); - SE->DelFd(s->GetFd()); - s->Close(); module_sockets.erase(a); - delete s; break; } - if (module_sockets.size() != numsockets) break; } + s->Close(); + delete s; } break; |