]> git.netwichtig.de Git - user/henk/code/inspircd.git/blobdiff - src/modes/cmode_v.cpp
Add a perl script which will abort compiles for warning messages that don't have...
[user/henk/code/inspircd.git] / src / modes / cmode_v.cpp
index 26e176bc5009e258240320808a576d1ab1921a46..66e58a479bca670b4cc32e2d3cf1a8fa8611803b 100644 (file)
@@ -1,29 +1,39 @@
-#include <string>
-#include <vector>
-#include "inspircd_config.h"
-#include "configreader.h"
-#include "hash_map.h"
+/*       +------------------------------------+
+ *       | Inspire Internet Relay Chat Daemon |
+ *       +------------------------------------+
+ *
+ *  InspIRCd: (C) 2002-2008 InspIRCd Development Team
+ * See: http://www.inspircd.org/wiki/index.php/Credits
+ *
+ * This program is free but copyrighted software; see
+ *            the file COPYING for details.
+ *
+ * ---------------------------------------------------
+ */
+
 #include "inspircd.h"
+#include "configreader.h"
 #include "mode.h"
 #include "channels.h"
 #include "users.h"
-#include "helperfuncs.h"
-#include "commands.h"
 #include "modules.h"
-#include "inspstring.h"
-#include "hashcomp.h"
 #include "modes/cmode_v.h"
 
-ModeChannelVoice::ModeChannelVoice(InspIRCd* Instance) : ModeHandler(Instance, 'v', 1, 1, true, MODETYPE_CHANNEL, false)
+ModeChannelVoice::ModeChannelVoice(InspIRCd* Instance) : ModeHandler(Instance, 'v', 1, 1, true, MODETYPE_CHANNEL, false, '+')
+{
+}
+
+unsigned int ModeChannelVoice::GetPrefixRank()
 {
+       return VOICE_VALUE;
 }
 
-ModePair ModeChannelVoice::ModeSet(userrec* source, userrec* dest, chanrec* channel, const std::string &parameter)
+ModePair ModeChannelVoice::ModeSet(User*, User*, Channel* channel, const std::string &parameter)
 {
-       userrec* x = ServerInstance->FindNick(parameter);
+       User* x = ServerInstance->FindNick(parameter);
        if (x)
        {
-               if (channel->GetStatus(x) == STATUS_VOICE)
+               if (channel->GetStatusFlags(x) & UCMODE_VOICE)
                {
                        return std::make_pair(true, x->nick);
                }
@@ -35,7 +45,31 @@ ModePair ModeChannelVoice::ModeSet(userrec* source, userrec* dest, chanrec* chan
        return std::make_pair(false, parameter);
 }
 
-ModeAction ModeChannelVoice::OnModeChange(userrec* source, userrec* dest, chanrec* channel, std::string &parameter, bool adding)
+void ModeChannelVoice::RemoveMode(Channel* channel)
+{
+       CUList* list = channel->GetVoicedUsers();
+       CUList copy;
+       char moderemove[MAXBUF];
+
+       for (CUList::iterator i = list->begin(); i != list->end(); i++)
+       {
+               User* n = i->first;
+               copy.insert(std::make_pair(n,n->nick));
+       }
+
+       for (CUList::iterator i = copy.begin(); i != copy.end(); i++)
+       {
+               sprintf(moderemove,"-%c",this->GetModeChar());
+               const char* parameters[] = { channel->name, moderemove, i->first->nick };
+               ServerInstance->SendMode(parameters, 3, ServerInstance->FakeClient);
+       }
+}
+
+void ModeChannelVoice::RemoveMode(User*)
+{
+}
+
+ModeAction ModeChannelVoice::OnModeChange(User* source, User*, Channel* channel, std::string &parameter, bool adding)
 {
        int status = channel->GetStatus(source);
 
@@ -53,12 +87,15 @@ ModeAction ModeChannelVoice::OnModeChange(userrec* source, userrec* dest, chanre
         * the return value and is always MODEACTION_DENY if the mode is supposed to have
         * a parameter.
         */
-       return MODEACTION_ALLOW;
+       if (parameter.length())
+               return MODEACTION_ALLOW;
+       else
+               return MODEACTION_DENY;
 }
 
-std::string ModeChannelVoice::AddVoice(userrec *user,const char* dest,chanrec *chan,int status)
+std::string ModeChannelVoice::AddVoice(User *user,const char* dest,Channel *chan,int status)
 {
-       userrec *d = ServerInstance->ModeGrok->SanityChecks(user,dest,chan,status);
+       User *d = ServerInstance->Modes->SanityChecks(user,dest,chan,status);
 
        if (d)
        {
@@ -71,7 +108,7 @@ std::string ModeChannelVoice::AddVoice(userrec *user,const char* dest,chanrec *c
                                return "";
                        if (MOD_RESULT == ACR_DEFAULT)
                        {
-                               if ((status < STATUS_HOP) && (!is_uline(user->server)))
+                               if ((status < STATUS_HOP) && (!ServerInstance->ULine(user->server)))
                                {
                                        user->WriteServ("482 %s %s :You're not a channel (half)operator",user->nick, chan->name);
                                        return "";
@@ -79,14 +116,14 @@ std::string ModeChannelVoice::AddVoice(userrec *user,const char* dest,chanrec *c
                        }
                }
 
-               return ServerInstance->ModeGrok->Grant(d,chan,UCMODE_VOICE);
+               return ServerInstance->Modes->Grant(d,chan,UCMODE_VOICE);
        }
        return "";
 }
 
-std::string ModeChannelVoice::DelVoice(userrec *user,const char *dest,chanrec *chan,int status)
+std::string ModeChannelVoice::DelVoice(User *user,const char *dest,Channel *chan,int status)
 {
-       userrec *d = ServerInstance->ModeGrok->SanityChecks(user,dest,chan,status);
+       User *d = ServerInstance->Modes->SanityChecks(user,dest,chan,status);
 
        if (d)
        {
@@ -99,7 +136,7 @@ std::string ModeChannelVoice::DelVoice(userrec *user,const char *dest,chanrec *c
                                return "";
                        if (MOD_RESULT == ACR_DEFAULT)
                        {
-                               if ((status < STATUS_HOP) && (!is_uline(user->server)))
+                               if ((status < STATUS_HOP) && (!ServerInstance->ULine(user->server)))
                                {
                                        user->WriteServ("482 %s %s :You are not a channel (half)operator",user->nick, chan->name);
                                        return "";
@@ -107,7 +144,7 @@ std::string ModeChannelVoice::DelVoice(userrec *user,const char *dest,chanrec *c
                        }
                }
 
-               return ServerInstance->ModeGrok->Revoke(d,chan,UCMODE_VOICE);
+               return ServerInstance->Modes->Revoke(d,chan,UCMODE_VOICE);
        }
        return "";
 }