summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--include/globals.h1
-rw-r--r--include/message.h1
-rw-r--r--include/modules.h6
-rw-r--r--include/users.h6
-rw-r--r--src/message.cpp35
-rw-r--r--src/modules.cpp5
-rw-r--r--src/users.cpp34
7 files changed, 38 insertions, 50 deletions
diff --git a/include/globals.h b/include/globals.h
index d3aac6571..a6e39066e 100644
--- a/include/globals.h
+++ b/include/globals.h
@@ -33,7 +33,6 @@ typedef std::multimap< std::string, KeyValList > ConfigDataHash;
void WriteOpers(char* text, ...);
void do_log(int level, char *text, ...);
-int common_channels(userrec *u, userrec *u2);
int isnick(const char *n);
chanrec* FindChan(const char* chan);
void readfile(file_cache &F, const char* fname);
diff --git a/include/message.h b/include/message.h
index f7fcba278..edcda3da9 100644
--- a/include/message.h
+++ b/include/message.h
@@ -28,7 +28,6 @@
#include "users.h"
#include "channels.h"
-int common_channels(userrec *u, userrec *u2);
void Blocking(int s);
void NonBlocking(int s);
int c_count(userrec* u);
diff --git a/include/modules.h b/include/modules.h
index 392047a35..cb105c60e 100644
--- a/include/modules.h
+++ b/include/modules.h
@@ -1327,12 +1327,6 @@ class Server : public Extensible
*/
virtual void Log(int level, const std::string &s);
- /** Returns true if two users share a common channel.
- * This method is used internally by the NICK and QUIT commands, and the Server::SendCommon
- * method.
- */
- virtual bool CommonChannels(userrec* u1, userrec* u2);
-
/** Returns true if a nick is valid.
* Nicks for unregistered connections will return false.
*/
diff --git a/include/users.h b/include/users.h
index 5e6225dfb..cc7074004 100644
--- a/include/users.h
+++ b/include/users.h
@@ -627,9 +627,11 @@ class userrec : public connection
*/
void WriteCommonExcept(const std::string &text);
- void userrec::WriteWallOps(const char* text, ...);
+ void WriteWallOps(const char* text, ...);
- void userrec::WriteWallOps(const std::string &text);
+ void WriteWallOps(const std::string &text);
+
+ bool SharesChannelWith(userrec *other);
/** Default destructor
*/
diff --git a/src/message.cpp b/src/message.cpp
index a786c60cb..9b56cc8ca 100644
--- a/src/message.cpp
+++ b/src/message.cpp
@@ -48,41 +48,6 @@ extern std::vector<ircd_module*> factory;
extern time_t TIME;
extern ServerConfig* Config;
-/* return 0 or 1 depending if users u and u2 share one or more common channels
- * (used by QUIT, NICK etc which arent channel specific notices)
- *
- * The old algorithm in 1.0 for this was relatively inefficient, iterating over
- * the first users channels then the second users channels within the outer loop,
- * therefore it was a maximum of x*y iterations (upon returning 0 and checking
- * all possible iterations). However this new function instead checks against the
- * channel's userlist in the inner loop which is a std::map<userrec*,userrec*>
- * and saves us time as we already know what pointer value we are after.
- * Don't quote me on the maths as i am not a mathematician or computer scientist,
- * but i believe this algorithm is now x+(log y) maximum iterations instead.
- */
-int common_channels(userrec *u, userrec *u2)
-{
- if ((!u) || (!u2) || (u->registered != REG_ALL) || (u2->registered != REG_ALL))
- return 0;
-
- /* Outer loop */
- for (std::vector<ucrec*>::const_iterator i = u->chans.begin(); i != u->chans.end(); i++)
- {
- /* Fetch the channel from the user */
- ucrec* user_channel = *i;
-
- if (user_channel->channel)
- {
- /* Eliminate the inner loop (which used to be ~equal in size to the outer loop)
- * by replacing it with a map::find which *should* be more efficient
- */
- if (user_channel->channel->HasUser(u2))
- return 1;
- }
- }
- return 0;
-}
-
void Blocking(int s)
{
int flags = fcntl(s, F_GETFL, 0);
diff --git a/src/modules.cpp b/src/modules.cpp
index d8557fc2e..d9f13987f 100644
--- a/src/modules.cpp
+++ b/src/modules.cpp
@@ -444,11 +444,6 @@ void Server::SendMode(const char** parameters, int pcnt, userrec *user)
ServerInstance->ModeGrok->Process(parameters,pcnt,user,true);
}
-bool Server::CommonChannels(userrec* u1, userrec* u2)
-{
- return (common_channels(u1,u2) != 0);
-}
-
void Server::DumpText(userrec* User, const std::string &LinePrefix, stringstream &TextStream)
{
std::string CompleteLine = LinePrefix;
diff --git a/src/users.cpp b/src/users.cpp
index 5086bd093..929caf19c 100644
--- a/src/users.cpp
+++ b/src/users.cpp
@@ -1564,3 +1564,37 @@ void userrec::WriteWallOps(const char* text, ...)
this->WriteWallOps(std::string(textbuffer));
}
+/* return 0 or 1 depending if users u and u2 share one or more common channels
+ * (used by QUIT, NICK etc which arent channel specific notices)
+ *
+ * The old algorithm in 1.0 for this was relatively inefficient, iterating over
+ * the first users channels then the second users channels within the outer loop,
+ * therefore it was a maximum of x*y iterations (upon returning 0 and checking
+ * all possible iterations). However this new function instead checks against the
+ * channel's userlist in the inner loop which is a std::map<userrec*,userrec*>
+ * and saves us time as we already know what pointer value we are after.
+ * Don't quote me on the maths as i am not a mathematician or computer scientist,
+ * but i believe this algorithm is now x+(log y) maximum iterations instead.
+ */
+bool userrec::SharesChannelWith(userrec *other)
+{
+ if ((!other) || (this->registered != REG_ALL) || (other->registered != REG_ALL))
+ return false;
+
+ /* Outer loop */
+ for (std::vector<ucrec*>::const_iterator i = this->chans.begin(); i != this->chans.end(); i++)
+ {
+ /* Fetch the channel from the user */
+ ucrec* user_channel = *i;
+
+ if (user_channel->channel)
+ {
+ /* Eliminate the inner loop (which used to be ~equal in size to the outer loop)
+ * by replacing it with a map::find which *should* be more efficient
+ */
+ if (user_channel->channel->HasUser(other))
+ return true;
+ }
+ }
+ return false;
+}