summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/modules/m_blockcolor.cpp38
1 files changed, 32 insertions, 6 deletions
diff --git a/src/modules/m_blockcolor.cpp b/src/modules/m_blockcolor.cpp
index f63caf6c5..6f612f6b2 100644
--- a/src/modules/m_blockcolor.cpp
+++ b/src/modules/m_blockcolor.cpp
@@ -63,13 +63,26 @@ class ModuleBlockColor : public Module
{
chanrec* c = (chanrec*)dest;
char ctext[MAXBUF];
+ char *ctptr = ctext;
snprintf(ctext,MAXBUF,"%s",text.c_str());
+
+
if (c->IsCustomModeSet('c'))
{
- if ((strchr(ctext,'\2')) || (strchr(ctext,'\3')) || (strchr(ctext,31)))
+ /* Instead of using strchr() here, do our own loop. Hopefully faster. --w00t */
+ while (ctptr && *ctptr)
{
- WriteServ(user->fd,"404 %s %s :Can't send colors to channel (+c set)",user->nick, c->name);
- return 1;
+ switch (*ctptr)
+ {
+ case 2:
+ case 3:
+ case 31:
+ WriteServ(user->fd,"404 %s %s :Can't send colors to channel (+c set)",user->nick, c->name);
+ return 1;
+ break;
+ }
+
+ *ctptr++;
}
}
}
@@ -82,13 +95,26 @@ class ModuleBlockColor : public Module
{
chanrec* c = (chanrec*)dest;
char ctext[MAXBUF];
+ char *ctptr = ctext;
snprintf(ctext,MAXBUF,"%s",text.c_str());
+
+
if (c->IsCustomModeSet('c'))
{
- if ((strchr(ctext,'\2')) || (strchr(ctext,'\3')) || (strchr(ctext,31)))
+ /* Instead of using strchr() here, do our own loop. Hopefully faster. --w00t */
+ while (ctptr && *ctptr)
{
- WriteServ(user->fd,"404 %s %s :Can't send colors to channel (+c set)",user->nick, c->name);
- return 1;
+ switch (*ctptr)
+ {
+ case 2:
+ case 3:
+ case 31:
+ WriteServ(user->fd,"404 %s %s :Can't send colors to channel (+c set)",user->nick, c->name);
+ return 1;
+ break;
+ }
+
+ *ctptr++;
}
}
}