summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorbrain <brain@e03df62e-2008-0410-955e-edbf42e46eb7>2004-04-08 15:45:03 +0000
committerbrain <brain@e03df62e-2008-0410-955e-edbf42e46eb7>2004-04-08 15:45:03 +0000
commit64f837e0d3fb6f9d495e5a9e2930a9d76dc3748c (patch)
treed5b350b3c5e71b0ada68cd97c83d8d8f45bcf5cd
parenta14617e12c1dbd0b7e1a176779b0a4f04aa96fb2 (diff)
Tons of buffering fixes and optimisations for user connections
Fixes to command handler and input parser git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@454 e03df62e-2008-0410-955e-edbf42e46eb7
-rw-r--r--include/users.h2
-rw-r--r--src/InspIRCd.layout18
-rw-r--r--src/inspircd.cpp118
-rw-r--r--src/users.cpp1
4 files changed, 89 insertions, 50 deletions
diff --git a/include/users.h b/include/users.h
index d20de55a3..dbb237c5f 100644
--- a/include/users.h
+++ b/include/users.h
@@ -113,6 +113,8 @@ class userrec : public connection
*/
char result[256];
+ char carryover[MAXBUF];
+
unsigned long timeout;
userrec();
diff --git a/src/InspIRCd.layout b/src/InspIRCd.layout
index 7cf802964..da4a53abf 100644
--- a/src/InspIRCd.layout
+++ b/src/InspIRCd.layout
@@ -13,8 +13,8 @@ LeftChar=1
[Editor_1]
Open=1
Top=1
-CursorCol=19
-CursorRow=5504
+CursorCol=3
+CursorRow=5544
TopLine=5465
LeftChar=1
@@ -53,8 +53,8 @@ LeftChar=1
[Editor_6]
Open=1
Top=0
-CursorCol=2
-CursorRow=16
+CursorCol=1
+CursorRow=36
TopLine=1
LeftChar=1
@@ -67,7 +67,7 @@ TopLine=6
LeftChar=1
[Editor_8]
-Open=0
+Open=1
Top=0
CursorCol=1
CursorRow=33
@@ -179,11 +179,11 @@ TopLine=1
LeftChar=1
[Editor_22]
-Open=0
+Open=1
Top=0
-CursorCol=24
+CursorCol=25
CursorRow=116
-TopLine=59
+TopLine=74
LeftChar=1
[Editor_23]
@@ -275,7 +275,7 @@ CursorRow=25
TopLine=1
LeftChar=1
[Editor_36]
-Open=0
+Open=1
Top=0
CursorCol=1
CursorRow=34
diff --git a/src/inspircd.cpp b/src/inspircd.cpp
index 9cc69a68b..f7fd1fa72 100644
--- a/src/inspircd.cpp
+++ b/src/inspircd.cpp
@@ -81,6 +81,8 @@ vector<string> module_names;
extern vector<ircd_module*> factory;
vector<int> fd_reap;
+int client_exit = 0;
+
extern int MODCOUNT;
bool nofork = false;
@@ -456,8 +458,9 @@ void NonBlocking(int s)
{
int flags;
log(DEBUG,"NonBlocking: %d",s);
- flags = fcntl(s, F_GETFL, 0);
- fcntl(s, F_SETFL, flags | O_NONBLOCK);
+ //flags = fcntl(s, F_GETFL, 0);
+ fcntl(s, F_SETFL, O_NONBLOCK);
+ //fcntl(s, F_SETFL, flags | O_NONBLOCK);
}
@@ -3225,6 +3228,8 @@ void kill_link(userrec *user,const char* r)
if (user->registered == 7) {
purge_empty_chans();
}
+
+ client_exit = 1;
}
@@ -3924,6 +3929,8 @@ void handle_quit(char **parameters, int pcnt, userrec *user)
if (user->registered == 7) {
purge_empty_chans();
}
+
+ client_exit = 1;
}
void handle_who(char **parameters, int pcnt, userrec *user)
@@ -4745,7 +4752,8 @@ void process_command(userrec *user, char* cmd)
{
cmd[i] = toupper(cmd[i]);
}
- log(DEBUG,"Preprocess done");
+ log(DEBUG,"Preprocess done length=%d",strlen(cmd));
+ command = cmd;
}
else
{
@@ -4789,6 +4797,7 @@ void process_command(userrec *user, char* cmd)
}
}
+ log(DEBUG,"A %d %s",strlen(cmd),cmd);
cmd_found = 0;
@@ -4798,6 +4807,8 @@ void process_command(userrec *user, char* cmd)
return;
}
+ log(DEBUG,"A %d %s",strlen(cmd),cmd);
+
for (int x = 0; x < strlen(command); x++)
{
if (((command[x] < 'A') || (command[x] > 'Z')) && (command[x] != '.'))
@@ -4973,7 +4984,7 @@ void SetupCommandTable(void)
createcommand("MODULES",handle_modules,'o',0);
}
-void process_buffer(userrec *user)
+void process_buffer(char* cmdbuf,userrec *user)
{
if (!user)
{
@@ -4982,16 +4993,16 @@ void process_buffer(userrec *user)
}
char cmd[MAXBUF];
int i;
- if (!user->inbuf)
+ if (!cmdbuf)
{
log(DEFAULT,"*** BUG *** process_buffer was given an invalid parameter");
return;
}
- if (!strcmp(user->inbuf,""))
+ if (!strcmp(cmdbuf,""))
{
return;
}
- strncpy(cmd,user->inbuf,MAXBUF);
+ strncpy(cmd,cmdbuf,MAXBUF);
if (!strcmp(cmd,""))
{
return;
@@ -5004,7 +5015,7 @@ void process_buffer(userrec *user)
{
cmd[strlen(cmd)-1] = '\0';
}
- strcpy(user->inbuf,"");
+
if (!strcmp(cmd,""))
{
return;
@@ -5509,15 +5520,35 @@ int InspIRCd(void)
for (user_hash::iterator count2a = xcount; count2a != endingiter; count2a++)
{
result = EAGAIN;
- if (FD_ISSET (count2a->second->fd, &sfd))
+ if ((FD_ISSET (count2a->second->fd, &sfd)) || (strlen(count2a->second->carryover)))
{
- result = read(count2a->second->fd, data, 1);
+ //result = read(count2a->second->fd, data, 1);
+ int foo = 0;
+ NonBlocking(count2a->second->fd);
+
+ if (strlen(count2a->second->carryover))
+ {
+ strncpy(data,count2a->second->carryover,MAXBUF);
+ strcpy(count2a->second->carryover,"");
+ foo = strlen(data);
+ }
+
+ if (!foo)
+ {
+ result = read(count2a->second->fd, data, 256);
+ }
+ else
+ {
+ result = foo;
+ }
+
if ((result == -1) && (errno != EAGAIN) && (errno != EINTR))
{
log(DEBUG,"killing: %s",count2a->second->nick);
kill_link(count2a->second,strerror(errno));
goto label;
}
+ data[result] = '\0'; // pad the data
}
// result EAGAIN means nothing read
if (result == EAGAIN)
@@ -5540,39 +5571,44 @@ int InspIRCd(void)
if (count2a->second)
{
- // until the buffer is at 509 chars anything can be inserted into it.
- if ((strlen(count2a->second->inbuf) < 509) && (data[0] != '\0')) {
- strncat(count2a->second->inbuf, data, result);
- }
-
- // once you reach 509 chars, only a \r or \n can be inserted,
- // completing the line.
- if ((strlen(count2a->second->inbuf) >= 509) && ((data[0] == '\r') || (data[0] == '\n'))) {
- count2a->second->inbuf[509] = '\r';
- count2a->second->inbuf[510] = '\n';
- count2a->second->inbuf[511] = '\0';
- process_buffer(count2a->second);
- goto label;
- }
-
- if (strchr(count2a->second->inbuf, '\n') || strchr(count2a->second->inbuf, '\r') || (strlen(count2a->second->inbuf) > 509))
+ char d[2];
+ d[1] = '\0';
+
+ for(int chr = 0; chr < result; chr++)
{
- /* at least one complete line is waiting to be processed */
- if (!count2a->second->fd)
- goto label;
- else
- {
- if (strlen(count2a->second->inbuf)<512)
- {
- // double check the length before processing!
- process_buffer(count2a->second);
- }
- else
- {
- strcpy(count2a->second->inbuf,"");
- }
- goto label;
+ d[0] = data[chr];
+
+ // until the buffer is at 509 chars anything can be inserted into it.
+ if (d[0] != '\0')
+ {
+ strncat(count2a->second->inbuf, d, MAXBUF);
}
+
+
+ if ((d[0] == '\n') || (d[0] == '\r'))
+ {
+ char cmdbuf[MAXBUF];
+ strncpy(cmdbuf,count2a->second->inbuf,MAXBUF);
+ strcpy(count2a->second->inbuf,"");
+ char* x = data+chr;
+ if ((x != NULL) && (chr < 255))
+ {
+ if (strlen(x))
+ {
+ if ((x[0] == '\n') || (x[0] == '\r')) x++;
+ if ((x[0] == '\n') || (x[0] == '\r')) x++;
+ if (strlen(x))
+ {
+ strncpy(count2a->second->carryover,x,MAXBUF);
+ }
+ }
+ }
+ if (strlen(cmdbuf)>1)
+ {
+ process_buffer(cmdbuf,count2a->second);
+ }
+ goto label;
+ }
}
}
}
diff --git a/src/users.cpp b/src/users.cpp
index 3211a029f..4c7173e30 100644
--- a/src/users.cpp
+++ b/src/users.cpp
@@ -33,6 +33,7 @@ userrec::userrec()
invites.clear();
}
+
char* userrec::GetFullHost()
{